From 9f02a306dce917f6b03427aa5e0435972d2b237a Mon Sep 17 00:00:00 2001 From: messense Date: Wed, 23 Nov 2022 11:40:34 +0800 Subject: [PATCH] Deprecate `python-source` option in Cargo.toml --- Changelog.md | 1 + README.md | 10 +--------- guide/src/project_layout.md | 11 +---------- src/develop.rs | 4 ++-- src/project_layout.rs | 5 ++++- src/source_distribution.rs | 2 +- test-crates/pyo3-mixed-py-subdir/Cargo.toml | 1 - test-crates/pyo3-mixed-py-subdir/pyproject.toml | 3 +++ 8 files changed, 13 insertions(+), 24 deletions(-) diff --git a/Changelog.md b/Changelog.md index 186c6ba34..c9d50ceec 100644 --- a/Changelog.md +++ b/Changelog.md @@ -9,6 +9,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0 * Tighten src-layout detection logic in [#1281](https://github.com/PyO3/maturin/pull/1282) * Fix generating pep517 sdist for src-layout in [#1288](https://github.com/PyO3/maturin/pull/1288) +* Deprecate `python-source` option in Cargo.toml in [#1291](https://github.com/PyO3/maturin/pull/1291) ## [0.14.1] - 2022-11-20 diff --git a/README.md b/README.md index 9b71dc07b..e04399e66 100644 --- a/README.md +++ b/README.md @@ -114,8 +114,7 @@ my-project    └── lib.rs ``` -You can specify a different python source directory in `pyproject.toml` by setting `tool.maturin.python-source` -or in `Cargo.toml` by setting `package.metadata.maturin.python-source`, for example +You can specify a different python source directory in `pyproject.toml` by setting `tool.maturin.python-source`, for example **pyproject.toml** @@ -124,13 +123,6 @@ or in `Cargo.toml` by setting `package.metadata.maturin.python-source`, for exam python-source = "python" ``` -**Cargo.toml** - -```toml -[package.metadata.maturin] -python-source = "python" -``` - then the project structure would look like this: ``` diff --git a/guide/src/project_layout.md b/guide/src/project_layout.md index e7f591ec4..fe41c6a48 100644 --- a/guide/src/project_layout.md +++ b/guide/src/project_layout.md @@ -80,8 +80,7 @@ modules. A popular way to avoid this is with the `src`-layout, where the Python package is nested within a `src` directory. Unfortunately this interferes with the structure of a typical Rust project. Fortunately, Python is nor particular about the name of the parent source directory. You tell maturin to use a -different Python source directory in `pyproject.toml` by setting `tool.maturin.python-source` -or in `Cargo.toml` by setting `package.metadata.maturin.python-source`, for example +different Python source directory in `pyproject.toml` by setting `tool.maturin.python-source`, for example **pyproject.toml** @@ -90,13 +89,6 @@ or in `Cargo.toml` by setting `package.metadata.maturin.python-source`, for exam python-source = "python" ``` -**Cargo.toml** - -```toml -[package.metadata.maturin] -python-source = "python" -``` - then the project structure would look like this: ``` @@ -117,7 +109,6 @@ If the Python module created by Rust has the same name as the Python package in ```toml [package.metadata.maturin] -python-source = "python" name = "my_project._my_project" ``` diff --git a/src/develop.rs b/src/develop.rs index 546192dc8..99e17ba49 100644 --- a/src/develop.rs +++ b/src/develop.rs @@ -126,13 +126,13 @@ pub fn develop( } if !output.stderr.is_empty() { eprintln!( - "⚠️ Warning: pip raised a warning running {:?}:\n{}", + "⚠️ Warning: pip raised a warning running {:?}:\n{}", &command, String::from_utf8_lossy(&output.stderr).trim(), ); } println!( - "🛠 Installed {}-{}", + "🛠 Installed {}-{}", build_context.metadata21.name, build_context.metadata21.version ); } diff --git a/src/project_layout.rs b/src/project_layout.rs index 8751a91c3..5fd384ff7 100644 --- a/src/project_layout.rs +++ b/src/project_layout.rs @@ -138,7 +138,10 @@ impl ProjectResolver { let py_root = match pyproject.and_then(|x| x.python_source()) { Some(py_src) => py_src.to_path_buf(), None => match extra_metadata.python_source.as_ref() { - Some(py_src) => manifest_dir.join(py_src), + Some(py_src) => { + println!("⚠️ Warning: specify python-source in Cargo.toml is deprecated, use python-source in [tool.maturin] section in pyproject.toml instead"); + manifest_dir.join(py_src) + } None => match pyproject.and_then(|x| x.project_name()) { Some(project_name) => { // Detect src layout diff --git a/src/source_distribution.rs b/src/source_distribution.rs index 351ba5fd4..f0af3c9d7 100644 --- a/src/source_distribution.rs +++ b/src/source_distribution.rs @@ -540,7 +540,7 @@ pub fn source_distribution( let pyproject_dir = pyproject_toml_path.parent().unwrap(); // Add python source files if let Some(python_source) = build_context.project_layout.python_module.as_ref() { - for entry in ignore::Walk::new(python_source) { + for entry in ignore::Walk::new(pyproject_dir.join(python_source)) { let source = entry?.into_path(); // Technically, `ignore` crate should handle this, // but somehow it doesn't on Alpine Linux running in GitHub Actions, diff --git a/test-crates/pyo3-mixed-py-subdir/Cargo.toml b/test-crates/pyo3-mixed-py-subdir/Cargo.toml index 9a286033e..0eb8f1365 100644 --- a/test-crates/pyo3-mixed-py-subdir/Cargo.toml +++ b/test-crates/pyo3-mixed-py-subdir/Cargo.toml @@ -14,5 +14,4 @@ name = "pyo3_mixed_py_subdir" crate-type = ["cdylib"] [package.metadata.maturin] -python-source = "python" name = "pyo3_mixed_py_subdir._pyo3_mixed" diff --git a/test-crates/pyo3-mixed-py-subdir/pyproject.toml b/test-crates/pyo3-mixed-py-subdir/pyproject.toml index 9d465e6b1..d4dec533b 100644 --- a/test-crates/pyo3-mixed-py-subdir/pyproject.toml +++ b/test-crates/pyo3-mixed-py-subdir/pyproject.toml @@ -12,3 +12,6 @@ requires-python = ">=3.6" [project.scripts] get_42 = "pyo3_mixed_py_subdir:get_42" + +[tool.maturin] +python-source = "python"