Merge #3211
3211: Enable v2 resolver on the workspace to enable dropping PYO3_CI workaround r=davidhewitt a=adamreichold Co-authored-by: Adam Reichold <adam.reichold@t-online.de>
This commit is contained in:
commit
894b62fba7
3
.github/workflows/build.yml
vendored
3
.github/workflows/build.yml
vendored
|
@ -198,6 +198,3 @@ jobs:
|
|||
RUST_BACKTRACE: 1
|
||||
RUSTFLAGS: "-D warnings"
|
||||
RUSTDOCFLAGS: "-D warnings"
|
||||
# TODO: this is a hack to workaround compile_error! warnings about auto-initialize on PyPy
|
||||
# Once cargo's `resolver = "2"` is stable (~ MSRV Rust 1.52), remove this.
|
||||
PYO3_CI: 1
|
||||
|
|
|
@ -187,6 +187,7 @@ members = [
|
|||
"pytests",
|
||||
"examples",
|
||||
]
|
||||
resolver = "2"
|
||||
|
||||
[package.metadata.docs.rs]
|
||||
no-default-features = true
|
||||
|
|
39
build.rs
39
build.rs
|
@ -4,30 +4,21 @@ use pyo3_build_config::pyo3_build_script_impl::{cargo_env_var, errors::Result};
|
|||
use pyo3_build_config::{bail, print_feature_cfgs, InterpreterConfig};
|
||||
|
||||
fn ensure_auto_initialize_ok(interpreter_config: &InterpreterConfig) -> Result<()> {
|
||||
if cargo_env_var("CARGO_FEATURE_AUTO_INITIALIZE").is_some() {
|
||||
if !interpreter_config.shared {
|
||||
bail!(
|
||||
"The `auto-initialize` feature is enabled, but your python installation only supports \
|
||||
embedding the Python interpreter statically. If you are attempting to run tests, or a \
|
||||
binary which is okay to link dynamically, install a Python distribution which ships \
|
||||
with the Python shared library.\n\
|
||||
\n\
|
||||
Embedding the Python interpreter statically does not yet have first-class support in \
|
||||
PyO3. If you are sure you intend to do this, disable the `auto-initialize` feature.\n\
|
||||
\n\
|
||||
For more information, see \
|
||||
https://pyo3.rs/v{pyo3_version}/\
|
||||
building_and_distribution.html#embedding-python-in-rust",
|
||||
pyo3_version = env::var("CARGO_PKG_VERSION").unwrap()
|
||||
);
|
||||
}
|
||||
|
||||
// TODO: PYO3_CI env is a hack to workaround CI with PyPy, where the `dev-dependencies`
|
||||
// currently cause `auto-initialize` to be enabled in CI.
|
||||
// Once MSRV is 1.51 or higher, use cargo's `resolver = "2"` instead.
|
||||
if interpreter_config.implementation.is_pypy() && env::var_os("PYO3_CI").is_none() {
|
||||
bail!("the `auto-initialize` feature is not supported with PyPy");
|
||||
}
|
||||
if cargo_env_var("CARGO_FEATURE_AUTO_INITIALIZE").is_some() && !interpreter_config.shared {
|
||||
bail!(
|
||||
"The `auto-initialize` feature is enabled, but your python installation only supports \
|
||||
embedding the Python interpreter statically. If you are attempting to run tests, or a \
|
||||
binary which is okay to link dynamically, install a Python distribution which ships \
|
||||
with the Python shared library.\n\
|
||||
\n\
|
||||
Embedding the Python interpreter statically does not yet have first-class support in \
|
||||
PyO3. If you are sure you intend to do this, disable the `auto-initialize` feature.\n\
|
||||
\n\
|
||||
For more information, see \
|
||||
https://pyo3.rs/v{pyo3_version}/\
|
||||
building_and_distribution.html#embedding-python-in-rust",
|
||||
pyo3_version = env::var("CARGO_PKG_VERSION").unwrap()
|
||||
);
|
||||
}
|
||||
Ok(())
|
||||
}
|
||||
|
|
|
@ -662,7 +662,6 @@ def _for_all_version_configs(
|
|||
with tempfile.NamedTemporaryFile("r+") as config:
|
||||
env = os.environ.copy()
|
||||
env["PYO3_CONFIG_FILE"] = config.name
|
||||
env["PYO3_CI"] = "1"
|
||||
|
||||
def _job_with_config(implementation, version) -> bool:
|
||||
config.seek(0)
|
||||
|
|
Loading…
Reference in a new issue