From 742774cdb5dd54ed40e738bca0a15835fa384158 Mon Sep 17 00:00:00 2001 From: messense Date: Sat, 14 May 2022 18:16:40 +0800 Subject: [PATCH 1/2] Auto generate Windows import libraries when using a pyo3 config file --- pyo3-build-config/src/impl_.rs | 21 +++++++++++++++++++++ pyo3-build-config/src/lib.rs | 4 +++- 2 files changed, 24 insertions(+), 1 deletion(-) diff --git a/pyo3-build-config/src/impl_.rs b/pyo3-build-config/src/impl_.rs index f0543dc859b..b83e1f13a46 100644 --- a/pyo3-build-config/src/impl_.rs +++ b/pyo3-build-config/src/impl_.rs @@ -456,6 +456,27 @@ print("mingw", get_platform().startswith("mingw")) }) } + pub fn fixup_import_libs(&mut self) -> Result<()> { + let target = target_triple_from_env(); + if self.lib_name.is_none() && target.operating_system == OperatingSystem::Windows { + self.lib_name = Some(default_lib_name_windows( + self.version, + self.implementation, + self.abi3, + false, + )); + } + // Auto generate python3.dll import libraries for Windows targets. + #[cfg(feature = "python3-dll-a")] + { + if self.lib_dir.is_none() { + let py_version = if self.abi3 { None } else { Some(self.version) }; + self.lib_dir = self::import_lib::generate_import_lib(&target, py_version)?; + } + } + Ok(()) + } + #[doc(hidden)] /// Serialize the `InterpreterConfig` and print it to the environment for Cargo to pass along /// to dependent packages during build time. diff --git a/pyo3-build-config/src/lib.rs b/pyo3-build-config/src/lib.rs index c227d6a321a..6d20fd8f362 100644 --- a/pyo3-build-config/src/lib.rs +++ b/pyo3-build-config/src/lib.rs @@ -177,7 +177,9 @@ pub mod pyo3_build_script_impl { #[cfg(feature = "resolve-config")] pub fn resolve_interpreter_config() -> Result { if !CONFIG_FILE.is_empty() { - InterpreterConfig::from_reader(Cursor::new(CONFIG_FILE)) + let mut interperter_config = InterpreterConfig::from_reader(Cursor::new(CONFIG_FILE))?; + interperter_config.fixup_import_libs()?; + Ok(interperter_config) } else if let Some(interpreter_config) = make_cross_compile_config()? { // This is a cross compile and need to write the config file. let path = resolve_cross_compile_config_path() From ded0d9fc9330090ec00048cf051b8c4960760619 Mon Sep 17 00:00:00 2001 From: messense Date: Sat, 14 May 2022 19:33:16 +0800 Subject: [PATCH 2/2] Allow false positive `clippy::unnecessary-wraps` lint --- pyo3-build-config/src/impl_.rs | 1 + 1 file changed, 1 insertion(+) diff --git a/pyo3-build-config/src/impl_.rs b/pyo3-build-config/src/impl_.rs index b83e1f13a46..4fa2a49cb1e 100644 --- a/pyo3-build-config/src/impl_.rs +++ b/pyo3-build-config/src/impl_.rs @@ -456,6 +456,7 @@ print("mingw", get_platform().startswith("mingw")) }) } + #[allow(clippy::unnecessary_wraps)] pub fn fixup_import_libs(&mut self) -> Result<()> { let target = target_triple_from_env(); if self.lib_name.is_none() && target.operating_system == OperatingSystem::Windows {