From c68dd96cd4e8061146f2f23ff0eba0505e7d2a31 Mon Sep 17 00:00:00 2001 From: Hanno Braun Date: Fri, 4 Nov 2022 10:03:40 +0100 Subject: [PATCH] Disable model version check on Windows See https://github.com/hannobraun/Fornjot/issues/1307 --- crates/fj-host/src/model.rs | 53 +++++++++++++++++++++---------------- 1 file changed, 30 insertions(+), 23 deletions(-) diff --git a/crates/fj-host/src/model.rs b/crates/fj-host/src/model.rs index 61285beb9..838e80b54 100644 --- a/crates/fj-host/src/model.rs +++ b/crates/fj-host/src/model.rs @@ -105,32 +105,39 @@ impl Model { let lib = libloading::Library::new(&self.lib_path) .map_err(Error::LoadingLibrary)?; - let version_pkg: libloading::Symbol RawVersion> = - lib.get(b"version_pkg").map_err(Error::LoadingVersion)?; - - let version_pkg = version_pkg().to_string(); - if fj::version::VERSION_PKG != version_pkg { - let host = String::from_utf8_lossy( - fj::version::VERSION_PKG.as_bytes(), - ) - .into_owned(); - let model = version_pkg; - - return Err(Error::VersionMismatch { host, model }); - } + if cfg!(target_os = "windows") { + warn!( + "Version check is disabled on Windows (see \ + https://github.com/hannobraun/Fornjot/issues/1307)" + ); + } else { + let version_pkg: libloading::Symbol RawVersion> = + lib.get(b"version_pkg").map_err(Error::LoadingVersion)?; + + let version_pkg = version_pkg().to_string(); + if fj::version::VERSION_PKG != version_pkg { + let host = String::from_utf8_lossy( + fj::version::VERSION_PKG.as_bytes(), + ) + .into_owned(); + let model = version_pkg; + + return Err(Error::VersionMismatch { host, model }); + } - let version_full: libloading::Symbol RawVersion> = - lib.get(b"version_full").map_err(Error::LoadingVersion)?; + let version_full: libloading::Symbol RawVersion> = + lib.get(b"version_full").map_err(Error::LoadingVersion)?; - let version_full = version_full().to_string(); - if fj::version::VERSION_FULL != version_full { - let host = String::from_utf8_lossy( - fj::version::VERSION_FULL.as_bytes(), - ) - .into_owned(); - let model = version_full; + let version_full = version_full().to_string(); + if fj::version::VERSION_FULL != version_full { + let host = String::from_utf8_lossy( + fj::version::VERSION_FULL.as_bytes(), + ) + .into_owned(); + let model = version_full; - warn!("{}", Error::VersionMismatch { host, model }); + warn!("{}", Error::VersionMismatch { host, model }); + } } let init: libloading::Symbol = lib