From 2ab4626fb1f736547a78a10dde1b35e9f97460c0 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 27 Aug 2023 20:41:26 +0100 Subject: [PATCH 01/13] small fixes to test-crates --- test-crates/license-test/check_installed/check_installed.py | 2 +- test-crates/pyo3-mixed-py-subdir/README.md | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/test-crates/license-test/check_installed/check_installed.py b/test-crates/license-test/check_installed/check_installed.py index 286755e90..a49bb636a 100644 --- a/test-crates/license-test/check_installed/check_installed.py +++ b/test-crates/license-test/check_installed/check_installed.py @@ -2,7 +2,7 @@ def main(): - output = check_output(["hello-world"]).decode("utf-8").strip() + output = check_output(["license-test"]).decode("utf-8").strip() if not output == "Hello, world!": raise Exception(output) print("SUCCESS") diff --git a/test-crates/pyo3-mixed-py-subdir/README.md b/test-crates/pyo3-mixed-py-subdir/README.md index 038375070..a148582ec 100644 --- a/test-crates/pyo3-mixed-py-subdir/README.md +++ b/test-crates/pyo3-mixed-py-subdir/README.md @@ -1,6 +1,6 @@ # pyo3-mixed -A package for testing maturin with a mixed pyo3/python project. +A package for testing maturin with a mixed pyo3/python project and a non-default package name. ## Usage @@ -9,8 +9,8 @@ pip install . ``` ```python -import pyo3_mixed -assert pyo3_mixed.get_42() == 42 +import pyo3_mixed_py_subdir +assert pyo3_mixed_py_subdir.get_42() == 42 ``` ## Testing From 40af7ee62bd96447c7531a6975bb590f5b27e072 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 27 Aug 2023 20:43:43 +0100 Subject: [PATCH 02/13] added pyo3-mixed-with-path-dep test crate --- .../pyo3-mixed-with-path-dep/Cargo.lock | 304 ++++++++++++++++++ .../pyo3-mixed-with-path-dep/Cargo.toml | 14 + .../pyo3-mixed-with-path-dep/README.md | 30 ++ .../check_installed/check_installed.py | 9 + .../pyo3_mixed_with_path_dep/__init__.py | 7 + .../pyo3-mixed-with-path-dep/pyproject.toml | 11 + .../pyo3-mixed-with-path-dep/src/lib.rs | 27 ++ .../tests/test_pyo3_mixed_with_path_dep.py | 7 + test-crates/pyo3-mixed-with-path-dep/tox.ini | 7 + 9 files changed, 416 insertions(+) create mode 100644 test-crates/pyo3-mixed-with-path-dep/Cargo.lock create mode 100644 test-crates/pyo3-mixed-with-path-dep/Cargo.toml create mode 100644 test-crates/pyo3-mixed-with-path-dep/README.md create mode 100755 test-crates/pyo3-mixed-with-path-dep/check_installed/check_installed.py create mode 100644 test-crates/pyo3-mixed-with-path-dep/pyo3_mixed_with_path_dep/__init__.py create mode 100644 test-crates/pyo3-mixed-with-path-dep/pyproject.toml create mode 100644 test-crates/pyo3-mixed-with-path-dep/src/lib.rs create mode 100644 test-crates/pyo3-mixed-with-path-dep/tests/test_pyo3_mixed_with_path_dep.py create mode 100644 test-crates/pyo3-mixed-with-path-dep/tox.ini diff --git a/test-crates/pyo3-mixed-with-path-dep/Cargo.lock b/test-crates/pyo3-mixed-with-path-dep/Cargo.lock new file mode 100644 index 000000000..d8e5841db --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/Cargo.lock @@ -0,0 +1,304 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "cc" +version = "1.0.81" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "6c6b2562119bf28c3439f7f02db99faf0aa1a8cdfe5772a2ee155d32227239f0" +dependencies = [ + "libc", +] + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "indoc" +version = "1.0.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bfa799dd5ed20a7e349f3b4639aa80d74549c81716d9ec4f994c9b5815598306" + +[[package]] +name = "libc" +version = "0.2.147" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b4668fb0ea861c1df094127ac5f1da3409a82116a4ba74fca2e58ef927159bb3" + +[[package]] +name = "lock_api" +version = "0.4.10" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "c1cc9717a20b1bb222f333e6a92fd32f7d8a18ddc5a3191a11af45dcbf4dcd16" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "memoffset" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5a634b1c61a95585bd15607c6ab0c4e5b226e695ff2800ba0cdccddf208c406c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "once_cell" +version = "1.18.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dd8b5dd2ae5ed71462c540258bedcb51965123ad7e7ccf4b9a8cafaa4a63576d" + +[[package]] +name = "parking_lot" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.8" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "93f00c865fe7cabf650081affecd3871070f26767e7b2070a3ffae14c654b447" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets", +] + +[[package]] +name = "proc-macro2" +version = "1.0.66" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "18fb31db3f9bddb2ea821cde30a9f70117e3f119938b5ee630b7403aa6e2ead9" +dependencies = [ + "unicode-ident", +] + +[[package]] +name = "pyo3" +version = "0.19.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e681a6cfdc4adcc93b4d3cf993749a4552018ee0a9b65fc0ccfad74352c72a38" +dependencies = [ + "cfg-if", + "indoc", + "libc", + "memoffset", + "parking_lot", + "pyo3-build-config", + "pyo3-ffi", + "pyo3-macros", + "unindent", +] + +[[package]] +name = "pyo3-build-config" +version = "0.19.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "076c73d0bc438f7a4ef6fdd0c3bb4732149136abd952b110ac93e4edb13a6ba5" +dependencies = [ + "once_cell", + "python3-dll-a", + "target-lexicon", +] + +[[package]] +name = "pyo3-ffi" +version = "0.19.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e53cee42e77ebe256066ba8aa77eff722b3bb91f3419177cf4cd0f304d3284d9" +dependencies = [ + "libc", + "pyo3-build-config", +] + +[[package]] +name = "pyo3-macros" +version = "0.19.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dfeb4c99597e136528c6dd7d5e3de5434d1ceaf487436a3f03b2d56b6fc9efd1" +dependencies = [ + "proc-macro2", + "pyo3-macros-backend", + "quote", + "syn", +] + +[[package]] +name = "pyo3-macros-backend" +version = "0.19.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "947dc12175c254889edc0c02e399476c2f652b4b9ebd123aa655c224de259536" +dependencies = [ + "proc-macro2", + "quote", + "syn", +] + +[[package]] +name = "pyo3-mixed-with-path-dep" +version = "2.1.3" +dependencies = [ + "pyo3", + "some_path_dep", +] + +[[package]] +name = "python3-dll-a" +version = "0.2.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d5f07cd4412be8fa09a721d40007c483981bbe072cd6a21f2e83e04ec8f8343f" +dependencies = [ + "cc", +] + +[[package]] +name = "quote" +version = "1.0.32" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "50f3b39ccfb720540debaa0164757101c08ecb8d326b15358ce76a62c7e85965" +dependencies = [ + "proc-macro2", +] + +[[package]] +name = "redox_syscall" +version = "0.3.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "567664f262709473930a4bf9e51bf2ebf3348f2e748ccc50dea20646858f8f29" +dependencies = [ + "bitflags", +] + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + +[[package]] +name = "smallvec" +version = "1.11.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "62bb4feee49fdd9f707ef802e22365a35de4b7b299de4763d44bfea899442ff9" + +[[package]] +name = "some_path_dep" +version = "0.1.0" +dependencies = [ + "transitive_path_dep", +] + +[[package]] +name = "syn" +version = "1.0.109" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +dependencies = [ + "proc-macro2", + "quote", + "unicode-ident", +] + +[[package]] +name = "target-lexicon" +version = "0.12.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9d0e916b1148c8e263850e1ebcbd046f333e0683c724876bb0da63ea4373dc8a" + +[[package]] +name = "transitive_path_dep" +version = "0.1.0" + +[[package]] +name = "unicode-ident" +version = "1.0.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "301abaae475aa91687eb82514b328ab47a211a533026cb25fc3e519b86adfc3c" + +[[package]] +name = "unindent" +version = "0.1.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e1766d682d402817b5ac4490b3c3002d91dfa0d22812f341609f97b08757359c" + +[[package]] +name = "windows-targets" +version = "0.48.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "05d4b17490f70499f20b9e791dcf6a299785ce8af4d709018206dc5b4953e95f" +dependencies = [ + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "91ae572e1b79dba883e0d315474df7305d12f569b400fcf90581b06062f7e1bc" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "b2ef27e0d7bdfcfc7b868b317c1d32c641a6fe4629c171b8928c7b08d98d7cf3" + +[[package]] +name = "windows_i686_gnu" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "622a1962a7db830d6fd0a69683c80a18fda201879f0f447f065a3b7467daa241" + +[[package]] +name = "windows_i686_msvc" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4542c6e364ce21bf45d69fdd2a8e455fa38d316158cfd43b3ac1c5b1b19f8e00" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ca2b8a661f7628cbd23440e50b05d705db3686f894fc9580820623656af974b1" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "7896dbc1f41e08872e9d5e8f8baa8fdd2677f29468c4e156210174edc7f7b953" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "1a515f5799fe4961cb532f983ce2b23082366b898e52ffbce459c86f67c8378a" diff --git a/test-crates/pyo3-mixed-with-path-dep/Cargo.toml b/test-crates/pyo3-mixed-with-path-dep/Cargo.toml new file mode 100644 index 000000000..ad022c116 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/Cargo.toml @@ -0,0 +1,14 @@ +[package] +authors = [] +name = "pyo3-mixed-with-path-dep" +version = "2.1.3" +description = "a library using " +edition = "2021" + +[dependencies] +pyo3 = { version = "0.19.0", features = ["extension-module", "generate-import-lib"] } +some_path_dep = { path = "../some_path_dep" } + +[lib] +name = "pyo3_mixed_with_path_dep" +crate-type = ["cdylib"] diff --git a/test-crates/pyo3-mixed-with-path-dep/README.md b/test-crates/pyo3-mixed-with-path-dep/README.md new file mode 100644 index 000000000..29e76130f --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/README.md @@ -0,0 +1,30 @@ +# pyo3-mixed + +A package for testing maturin with a mixed pyo3/python project. + +## Usage + +```bash +pip install . +``` + +```python +import pyo3_mixed_with_path_dep +assert pyo3_mixed_with_path_dep.get_42() == 42 +``` + +## Testing + +Install tox: + +```bash +pip install tox +``` + +Run it: + +```bash +tox +``` + +The tests are in `tests/test_pyo3_mixed_with_path_dep.py`, while the configuration is in tox.ini diff --git a/test-crates/pyo3-mixed-with-path-dep/check_installed/check_installed.py b/test-crates/pyo3-mixed-with-path-dep/check_installed/check_installed.py new file mode 100755 index 000000000..21d947dfc --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/check_installed/check_installed.py @@ -0,0 +1,9 @@ +#!/usr/bin/env python3 +import pyo3_mixed_with_path_dep + +assert pyo3_mixed_with_path_dep.get_42() == 42, "get_42 did not return 42" + +assert pyo3_mixed_with_path_dep.is_half(21, 42), "21 is not half of 42" +assert not pyo3_mixed_with_path_dep.is_half(21, 73), "21 is half of 63" + +print("SUCCESS") diff --git a/test-crates/pyo3-mixed-with-path-dep/pyo3_mixed_with_path_dep/__init__.py b/test-crates/pyo3-mixed-with-path-dep/pyo3_mixed_with_path_dep/__init__.py new file mode 100644 index 000000000..54a76f703 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/pyo3_mixed_with_path_dep/__init__.py @@ -0,0 +1,7 @@ +from .pyo3_mixed_with_path_dep import get_21, add_21, is_half + +__all__ = ["get_21", "add_21", "is_half", "get_42"] + + +def get_42() -> int: + return add_21(get_21()) diff --git a/test-crates/pyo3-mixed-with-path-dep/pyproject.toml b/test-crates/pyo3-mixed-with-path-dep/pyproject.toml new file mode 100644 index 000000000..cc54d0ae3 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/pyproject.toml @@ -0,0 +1,11 @@ +[build-system] +requires = ["maturin>=1.0,<2.0"] +build-backend = "maturin" + +[project] +name = "pyo3-mixed-with-path-dep" +classifiers = [ + "Programming Language :: Python", + "Programming Language :: Rust" +] +requires-python = ">=3.7" diff --git a/test-crates/pyo3-mixed-with-path-dep/src/lib.rs b/test-crates/pyo3-mixed-with-path-dep/src/lib.rs new file mode 100644 index 000000000..1b7194289 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/src/lib.rs @@ -0,0 +1,27 @@ +use pyo3::prelude::*; +use some_path_dep::{add, is_sum}; + +#[pyfunction] +fn get_21() -> usize { + 21 +} + +#[pyfunction] +fn add_21(num: usize) -> usize { + add(num, get_21()) +} + +#[pyfunction] +fn is_half(a: usize, b: usize) -> bool { + is_sum(a, a, b) +} + + +#[pymodule] +fn pyo3_mixed_with_path_dep(_py: Python, m: &PyModule) -> PyResult<()> { + m.add_wrapped(wrap_pyfunction!(get_21))?; + m.add_wrapped(wrap_pyfunction!(add_21))?; + m.add_wrapped(wrap_pyfunction!(is_half))?; + + Ok(()) +} diff --git a/test-crates/pyo3-mixed-with-path-dep/tests/test_pyo3_mixed_with_path_dep.py b/test-crates/pyo3-mixed-with-path-dep/tests/test_pyo3_mixed_with_path_dep.py new file mode 100644 index 000000000..d77884fe8 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/tests/test_pyo3_mixed_with_path_dep.py @@ -0,0 +1,7 @@ +#!/usr/bin/env python3 + +import pyo3_mixed_with_path_dep + + +def test_get_42(): + assert pyo3_mixed_with_path_dep.get_42() == 42 diff --git a/test-crates/pyo3-mixed-with-path-dep/tox.ini b/test-crates/pyo3-mixed-with-path-dep/tox.ini new file mode 100644 index 000000000..421774193 --- /dev/null +++ b/test-crates/pyo3-mixed-with-path-dep/tox.ini @@ -0,0 +1,7 @@ +[tox] +envlist = py36,py37,py38 +isolated_build = True + +[testenv] +deps = pytest +commands = pytest tests/ From 760a45a478be248c1e533494b556ebf7cd581567 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Thu, 4 Jan 2024 00:01:30 +0000 Subject: [PATCH 03/13] moved fixing of direct_url.json into maturin itself. Also refactored develop.rs --- Cargo.toml | 4 +- src/develop.rs | 258 +++++++++++++++++++++++++++++++++++++------------ 2 files changed, 196 insertions(+), 66 deletions(-) diff --git a/Cargo.toml b/Cargo.toml index 0e6806804..8999e9535 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -75,6 +75,7 @@ path-slash = "0.2.1" pep440_rs = { version = "0.5.0", features = ["serde", "tracing"] } pep508_rs = { version = "0.4.2", features = ["serde", "tracing"] } time = "0.3.17" +url = "2.5.0" # cli clap = { version = "4.0.0", features = ["derive", "env", "wrap_help", "unstable-styles"] } @@ -104,7 +105,6 @@ rustls = { version = "0.22.2", optional = true } rustls-pemfile = { version = "2.0.0", optional = true } keyring = { version = "2.0.0", default-features = false, features = ["linux-no-secret-service"], optional = true } wild = { version = "2.1.0", optional = true } -url = { version = "2.3.0", optional = true } [dev-dependencies] expect-test = "1.4.1" @@ -124,7 +124,7 @@ log = ["tracing-subscriber"] cli-completion = ["dep:clap_complete_command"] -upload = ["ureq", "multipart", "configparser", "bytesize", "dialoguer/password", "url", "wild", "dep:dirs"] +upload = ["ureq", "multipart", "configparser", "bytesize", "dialoguer/password", "wild", "dep:dirs"] # keyring doesn't support *BSD so it's not enabled in `full` by default password-storage = ["upload", "keyring"] diff --git a/src/develop.rs b/src/develop.rs index f6ed88a4f..ff1de80b5 100644 --- a/src/develop.rs +++ b/src/develop.rs @@ -1,5 +1,6 @@ use crate::build_options::CargoOptions; use crate::target::Arch; +use crate::BuildContext; use crate::BuildOptions; use crate::PlatformTag; use crate::PythonInterpreter; @@ -7,10 +8,13 @@ use crate::Target; use anyhow::{anyhow, bail, Context, Result}; use cargo_options::heading; use pep508_rs::{MarkerExpression, MarkerOperator, MarkerTree, MarkerValue}; +use regex::Regex; +use std::fs; use std::path::Path; use std::path::PathBuf; use std::process::Command; use tempfile::TempDir; +use url::Url; /// Install the crate as module in the current virtualenv #[derive(Debug, clap::Parser)] @@ -72,6 +76,142 @@ fn make_pip_command(python_path: &Path, pip_path: Option<&Path>) -> Command { } } +fn install_dependencies( + build_context: &BuildContext, + extras: &[String], + interpreter: &PythonInterpreter, + pip_path: Option<&Path>, +) -> Result<()> { + if !build_context.metadata21.requires_dist.is_empty() { + let mut args = vec!["install".to_string()]; + args.extend(build_context.metadata21.requires_dist.iter().map(|x| { + let mut pkg = x.clone(); + // Remove extra marker to make it installable with pip + // Keep in sync with `Metadata21::merge_pyproject_toml()`! + for extra in extras { + pkg.marker = pkg.marker.and_then(|marker| -> Option { + match marker.clone() { + MarkerTree::Expression(MarkerExpression { + l_value: MarkerValue::Extra, + operator: MarkerOperator::Equal, + r_value: MarkerValue::QuotedString(extra_value), + }) if &extra_value == extra => None, + MarkerTree::And(and) => match &*and { + [existing, MarkerTree::Expression(MarkerExpression { + l_value: MarkerValue::Extra, + operator: MarkerOperator::Equal, + r_value: MarkerValue::QuotedString(extra_value), + })] if extra_value == extra => Some(existing.clone()), + _ => Some(marker), + }, + _ => Some(marker), + } + }); + } + pkg.to_string() + })); + let status = make_pip_command(&interpreter.executable, pip_path) + .args(&args) + .status() + .context("Failed to run pip install")?; + if !status.success() { + bail!(r#"pip install finished with "{}""#, status) + } + } + Ok(()) +} + +fn pip_install_wheel( + build_context: &BuildContext, + python: &Path, + venv_dir: &Path, + pip_path: Option<&Path>, + wheel_filename: &Path, +) -> Result<()> { + let mut pip_cmd = make_pip_command(&python, pip_path); + let output = pip_cmd + .args(["install", "--no-deps", "--force-reinstall"]) + .arg(dunce::simplified(wheel_filename)) + .output() + .context(format!( + "pip install failed (ran {:?} with {:?})", + pip_cmd.get_program(), + &pip_cmd.get_args().collect::>(), + ))?; + if !output.status.success() { + bail!( + "pip install in {} failed running {:?}: {}\n--- Stdout:\n{}\n--- Stderr:\n{}\n---\n", + venv_dir.display(), + &pip_cmd.get_args().collect::>(), + output.status, + String::from_utf8_lossy(&output.stdout).trim(), + String::from_utf8_lossy(&output.stderr).trim(), + ); + } + if !output.stderr.is_empty() { + eprintln!( + "⚠️ Warning: pip raised a warning running {:?}:\n{}", + &pip_cmd.get_args().collect::>(), + String::from_utf8_lossy(&output.stderr).trim(), + ); + } + fix_direct_url(build_context, python, pip_path)?; + Ok(()) +} + +/// Each editable-installed python package has a direct_url.json file that includes a file:// URL +/// indicating the location of the source code of that project. The maturin import hook uses this +/// URL to locate and rebuild editable-installed projects. +/// +/// When a maturin package is installed using `pip install -e`, pip takes care of writing the +/// correct URL, however when a maturin package is installed with `maturin develop`, the URL is +/// set to the path to the temporary wheel file created during installation. +fn fix_direct_url( + build_context: &BuildContext, + python: &Path, + pip_path: Option<&Path>, +) -> Result<()> { + println!("✏️ Setting installed package as editable"); + let mut pip_cmd = make_pip_command(&python, pip_path); + let output = pip_cmd + .args(["show", "--files"]) + .arg(&build_context.metadata21.name) + .output() + .context(format!( + "pip show failed (ran {:?} with {:?})", + pip_cmd.get_program(), + &pip_cmd.get_args().collect::>(), + ))?; + if let Some(direct_url_path) = parse_direct_url_path(&String::from_utf8_lossy(&output.stdout))? + { + let project_dir = build_context + .pyproject_toml_path + .parent() + .ok_or_else(|| anyhow!("failed to get project directory"))?; + let uri = Url::from_file_path(project_dir) + .map_err(|_| anyhow!("failed to convert project directory to file URL"))?; + let content = format!("{{\"dir_info\": {{\"editable\": true}}, \"url\": \"{uri}\"}}"); + fs::write(direct_url_path, content)?; + } + Ok(()) +} + +fn parse_direct_url_path(pip_show_output: &str) -> Result> { + if let Some(Some(location)) = Regex::new(r"Location: (.*)")? + .captures(pip_show_output) + .map(|c| c.get(1)) + { + if let Some(Some(direct_url_path)) = Regex::new(r" (.*direct_url.json)")? + .captures(pip_show_output) + .map(|c| c.get(1)) + { + let absolute_path = PathBuf::from(location.as_str()).join(direct_url_path.as_str()); + return Ok(Some(absolute_path)); + } + } + Ok(None) +} + /// Installs a crate by compiling it and copying the shared library to site-packages. /// Also adds the dist-info directory to make sure pip and other tools detect the library /// @@ -137,74 +277,18 @@ pub fn develop(develop_options: DevelopOptions, venv_dir: &Path) -> Result<()> { || anyhow!("Expected `python` to be a python interpreter inside a virtualenv ಠ_ಠ"), )?; - // Install dependencies - if !build_context.metadata21.requires_dist.is_empty() { - let mut args = vec!["install".to_string()]; - args.extend(build_context.metadata21.requires_dist.iter().map(|x| { - let mut pkg = x.clone(); - // Remove extra marker to make it installable with pip - // Keep in sync with `Metadata21::merge_pyproject_toml()`! - for extra in &extras { - pkg.marker = pkg.marker.and_then(|marker| -> Option { - match marker.clone() { - MarkerTree::Expression(MarkerExpression { - l_value: MarkerValue::Extra, - operator: MarkerOperator::Equal, - r_value: MarkerValue::QuotedString(extra_value), - }) if &extra_value == extra => None, - MarkerTree::And(and) => match &*and { - [existing, MarkerTree::Expression(MarkerExpression { - l_value: MarkerValue::Extra, - operator: MarkerOperator::Equal, - r_value: MarkerValue::QuotedString(extra_value), - })] if extra_value == extra => Some(existing.clone()), - _ => Some(marker), - }, - _ => Some(marker), - } - }); - } - pkg.to_string() - })); - let status = make_pip_command(&interpreter.executable, pip_path.as_deref()) - .args(&args) - .status() - .context("Failed to run pip install")?; - if !status.success() { - bail!(r#"pip install finished with "{}""#, status) - } - } + install_dependencies(&build_context, &extras, &interpreter, pip_path.as_deref())?; let wheels = build_context.build_wheels()?; if !skip_install { for (filename, _supported_version) in wheels.iter() { - let mut pip_cmd = make_pip_command(&python, pip_path.as_deref()); - let output = pip_cmd - .args(["install", "--no-deps", "--force-reinstall"]) - .arg(dunce::simplified(filename)) - .output() - .context(format!( - "pip install failed (ran {:?} with {:?})", - pip_cmd.get_program(), - &pip_cmd.get_args().collect::>(), - ))?; - if !output.status.success() { - bail!( - "pip install in {} failed running {:?}: {}\n--- Stdout:\n{}\n--- Stderr:\n{}\n---\n", - venv_dir.display(), - &pip_cmd.get_args().collect::>(), - output.status, - String::from_utf8_lossy(&output.stdout).trim(), - String::from_utf8_lossy(&output.stderr).trim(), - ); - } - if !output.stderr.is_empty() { - eprintln!( - "⚠️ Warning: pip raised a warning running {:?}:\n{}", - &pip_cmd.get_args().collect::>(), - String::from_utf8_lossy(&output.stderr).trim(), - ); - } + pip_install_wheel( + &build_context, + &python, + venv_dir, + pip_path.as_deref(), + filename, + )?; eprintln!( "🛠 Installed {}-{}", build_context.metadata21.name, build_context.metadata21.version @@ -214,3 +298,49 @@ pub fn develop(develop_options: DevelopOptions, venv_dir: &Path) -> Result<()> { Ok(()) } + +#[cfg(test)] +mod test { + use std::path::PathBuf; + + use super::parse_direct_url_path; + + #[test] + fn test_parse_direct_url() { + let example_with_direct_url = "\ +Name: my-project +Version: 0.1.0 +Location: /foo bar/venv/lib/pythonABC/site-packages +Editable project location: /tmp/temporary.whl +Files: + my_project-0.1.0+abc123de.dist-info/INSTALLER + my_project-0.1.0+abc123de.dist-info/METADATA + my_project-0.1.0+abc123de.dist-info/RECORD + my_project-0.1.0+abc123de.dist-info/REQUESTED + my_project-0.1.0+abc123de.dist-info/WHEEL + my_project-0.1.0+abc123de.dist-info/direct_url.json + my_project-0.1.0+abc123de.dist-info/entry_points.txt + my_project.pth +"; + assert_eq!(parse_direct_url_path(example_with_direct_url).unwrap(), Some(PathBuf::from("/foo bar/venv/lib/pythonABC/site-packages/my_project-0.1.0.dist-info/direct_url.json"))); + + let example_without_direct_url = "\ +Name: my-project +Version: 0.1.0 +Location: /foo bar/venv/lib/pythonABC/site-packages +Files: + my_project-0.1.0+abc123de.dist-info/INSTALLER + my_project-0.1.0+abc123de.dist-info/METADATA + my_project-0.1.0+abc123de.dist-info/RECORD + my_project-0.1.0+abc123de.dist-info/REQUESTED + my_project-0.1.0+abc123de.dist-info/WHEEL + my_project-0.1.0+abc123de.dist-info/entry_points.txt + my_project.pth +"; + + assert_eq!( + parse_direct_url_path(example_without_direct_url).unwrap(), + None + ); + } +} From 4ebc92ffdd52cf9710f05631dc9a6655f3716fe8 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Thu, 4 Jan 2024 00:19:58 +0000 Subject: [PATCH 04/13] renamed document to match title --- guide/src/{develop.md => local_development.md} | 0 1 file changed, 0 insertions(+), 0 deletions(-) rename guide/src/{develop.md => local_development.md} (100%) diff --git a/guide/src/develop.md b/guide/src/local_development.md similarity index 100% rename from guide/src/develop.md rename to guide/src/local_development.md From e65b697601546c6b0cdb45257672de65e8e5f110 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Thu, 4 Jan 2024 00:28:42 +0000 Subject: [PATCH 05/13] small fixes --- src/develop.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/develop.rs b/src/develop.rs index ff1de80b5..7642e12a5 100644 --- a/src/develop.rs +++ b/src/develop.rs @@ -128,7 +128,7 @@ fn pip_install_wheel( pip_path: Option<&Path>, wheel_filename: &Path, ) -> Result<()> { - let mut pip_cmd = make_pip_command(&python, pip_path); + let mut pip_cmd = make_pip_command(python, pip_path); let output = pip_cmd .args(["install", "--no-deps", "--force-reinstall"]) .arg(dunce::simplified(wheel_filename)) @@ -172,7 +172,7 @@ fn fix_direct_url( pip_path: Option<&Path>, ) -> Result<()> { println!("✏️ Setting installed package as editable"); - let mut pip_cmd = make_pip_command(&python, pip_path); + let mut pip_cmd = make_pip_command(python, pip_path); let output = pip_cmd .args(["show", "--files"]) .arg(&build_context.metadata21.name) @@ -322,7 +322,7 @@ Files: my_project-0.1.0+abc123de.dist-info/entry_points.txt my_project.pth "; - assert_eq!(parse_direct_url_path(example_with_direct_url).unwrap(), Some(PathBuf::from("/foo bar/venv/lib/pythonABC/site-packages/my_project-0.1.0.dist-info/direct_url.json"))); + assert_eq!(parse_direct_url_path(example_with_direct_url).unwrap(), Some(PathBuf::from("/foo bar/venv/lib/pythonABC/site-packages/my_project-0.1.0+abc123de.dist-info/direct_url.json"))); let example_without_direct_url = "\ Name: my-project From ba1bc41335a49cf11d79bff7a03709451ef236e7 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Thu, 4 Jan 2024 21:50:46 +0000 Subject: [PATCH 06/13] support windows style paths when fixing direct_url.json --- src/develop.rs | 39 +++++++++++++++++++++++++++++++++++---- 1 file changed, 35 insertions(+), 4 deletions(-) diff --git a/src/develop.rs b/src/develop.rs index 7642e12a5..aed9d2c28 100644 --- a/src/develop.rs +++ b/src/develop.rs @@ -197,7 +197,7 @@ fn fix_direct_url( } fn parse_direct_url_path(pip_show_output: &str) -> Result> { - if let Some(Some(location)) = Regex::new(r"Location: (.*)")? + if let Some(Some(location)) = Regex::new(r"Location: ([^\r\n]*)")? .captures(pip_show_output) .map(|c| c.get(1)) { @@ -205,8 +205,9 @@ fn parse_direct_url_path(pip_show_output: &str) -> Result> { .captures(pip_show_output) .map(|c| c.get(1)) { - let absolute_path = PathBuf::from(location.as_str()).join(direct_url_path.as_str()); - return Ok(Some(absolute_path)); + return Ok(Some( + PathBuf::from(location.as_str()).join(direct_url_path.as_str()), + )); } } Ok(None) @@ -306,6 +307,7 @@ mod test { use super::parse_direct_url_path; #[test] + #[cfg(not(target_os = "windows"))] fn test_parse_direct_url() { let example_with_direct_url = "\ Name: my-project @@ -322,7 +324,11 @@ Files: my_project-0.1.0+abc123de.dist-info/entry_points.txt my_project.pth "; - assert_eq!(parse_direct_url_path(example_with_direct_url).unwrap(), Some(PathBuf::from("/foo bar/venv/lib/pythonABC/site-packages/my_project-0.1.0+abc123de.dist-info/direct_url.json"))); + let expected_path = PathBuf::from("/foo bar/venv/lib/pythonABC/site-packages/my_project-0.1.0+abc123de.dist-info/direct_url.json"); + assert_eq!( + parse_direct_url_path(example_with_direct_url).unwrap(), + Some(expected_path) + ); let example_without_direct_url = "\ Name: my-project @@ -343,4 +349,29 @@ Files: None ); } + + #[test] + #[cfg(target_os = "windows")] + fn test_parse_direct_url_windows() { + let example_with_direct_url_windows = "\ +Name: my-project\r +Version: 0.1.0\r +Location: C:\\foo bar\\venv\\Lib\\site-packages\r +Files:\r + my_project-0.1.0+abc123de.dist-info\\INSTALLER\r + my_project-0.1.0+abc123de.dist-info\\METADATA\r + my_project-0.1.0+abc123de.dist-info\\RECORD\r + my_project-0.1.0+abc123de.dist-info\\REQUESTED\r + my_project-0.1.0+abc123de.dist-info\\WHEEL\r + my_project-0.1.0+abc123de.dist-info\\direct_url.json\r + my_project-0.1.0+abc123de.dist-info\\entry_points.txt\r + my_project.pth\r +"; + + let expected_path = PathBuf::from("C:\\foo bar\\venv\\Lib\\site-packages\\my_project-0.1.0+abc123de.dist-info\\direct_url.json"); + assert_eq!( + parse_direct_url_path(example_with_direct_url_windows).unwrap(), + Some(expected_path) + ); + } } From cce686b2ef1cd0b4cfce78ebaef516490af14078 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 21 Jan 2024 13:38:28 +0000 Subject: [PATCH 07/13] fixes to test crate --- test-crates/pyo3-mixed-with-path-dep/Cargo.toml | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/test-crates/pyo3-mixed-with-path-dep/Cargo.toml b/test-crates/pyo3-mixed-with-path-dep/Cargo.toml index ad022c116..14a4ecbfc 100644 --- a/test-crates/pyo3-mixed-with-path-dep/Cargo.toml +++ b/test-crates/pyo3-mixed-with-path-dep/Cargo.toml @@ -2,11 +2,10 @@ authors = [] name = "pyo3-mixed-with-path-dep" version = "2.1.3" -description = "a library using " edition = "2021" [dependencies] -pyo3 = { version = "0.19.0", features = ["extension-module", "generate-import-lib"] } +pyo3 = { version = "0.20.0", features = ["extension-module", "generate-import-lib"] } some_path_dep = { path = "../some_path_dep" } [lib] From cca286526bb65e5758cb013311bbb45bbcf66ec9 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 21 Jan 2024 13:43:49 +0000 Subject: [PATCH 08/13] updated guide --- guide/src/local_development.md | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/guide/src/local_development.md b/guide/src/local_development.md index 8ee68b754..1f80890b2 100644 --- a/guide/src/local_development.md +++ b/guide/src/local_development.md @@ -117,15 +117,26 @@ requires = ["maturin>=1.0,<2.0"] build-backend = "maturin" ``` -Editable installs right now is only useful in mixed Rust/Python project so you -don't have to recompile and reinstall when only Python source code changes. For -example when using pip you can make an editable installation with +Editable installs can be used with mixed Rust/Python projects so you +don't have to recompile and reinstall when only Python source code changes. +They can also be used with mixed and pure projects together with the +import hook so that recompilation/re-installation occurs automatically +when Python or Rust source code changes. + +To install a package in editable mode with pip: ```bash +cd my-project pip install -e . ``` +or +```bash +cd my-project +maturin develop +``` -Then Python source code changes will take effect immediately. +Then Python source code changes will take effect immediately because the interpreter looks +for the modules directly in the project source tree. ## Import Hook From 4a93fb10a7df15e4ea142d2b92f162523b2da025 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 21 Jan 2024 13:48:31 +0000 Subject: [PATCH 09/13] updated lockfile --- .../pyo3-mixed-with-path-dep/Cargo.lock | 39 +++++++++++-------- 1 file changed, 23 insertions(+), 16 deletions(-) diff --git a/test-crates/pyo3-mixed-with-path-dep/Cargo.lock b/test-crates/pyo3-mixed-with-path-dep/Cargo.lock index d8e5841db..278ea1cd0 100644 --- a/test-crates/pyo3-mixed-with-path-dep/Cargo.lock +++ b/test-crates/pyo3-mixed-with-path-dep/Cargo.lock @@ -29,11 +29,17 @@ version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + [[package]] name = "indoc" -version = "1.0.9" +version = "2.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfa799dd5ed20a7e349f3b4639aa80d74549c81716d9ec4f994c9b5815598306" +checksum = "1e186cfbae8084e513daff4240b4797e342f988cecda4fb6c939150f96315fd8" [[package]] name = "libc" @@ -100,9 +106,9 @@ dependencies = [ [[package]] name = "pyo3" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e681a6cfdc4adcc93b4d3cf993749a4552018ee0a9b65fc0ccfad74352c72a38" +checksum = "9a89dc7a5850d0e983be1ec2a463a171d20990487c3cfcd68b5363f1ee3d6fe0" dependencies = [ "cfg-if", "indoc", @@ -117,9 +123,9 @@ dependencies = [ [[package]] name = "pyo3-build-config" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "076c73d0bc438f7a4ef6fdd0c3bb4732149136abd952b110ac93e4edb13a6ba5" +checksum = "07426f0d8fe5a601f26293f300afd1a7b1ed5e78b2a705870c5f30893c5163be" dependencies = [ "once_cell", "python3-dll-a", @@ -128,9 +134,9 @@ dependencies = [ [[package]] name = "pyo3-ffi" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e53cee42e77ebe256066ba8aa77eff722b3bb91f3419177cf4cd0f304d3284d9" +checksum = "dbb7dec17e17766b46bca4f1a4215a85006b4c2ecde122076c562dd058da6cf1" dependencies = [ "libc", "pyo3-build-config", @@ -138,9 +144,9 @@ dependencies = [ [[package]] name = "pyo3-macros" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfeb4c99597e136528c6dd7d5e3de5434d1ceaf487436a3f03b2d56b6fc9efd1" +checksum = "05f738b4e40d50b5711957f142878cfa0f28e054aa0ebdfc3fd137a843f74ed3" dependencies = [ "proc-macro2", "pyo3-macros-backend", @@ -150,10 +156,11 @@ dependencies = [ [[package]] name = "pyo3-macros-backend" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "947dc12175c254889edc0c02e399476c2f652b4b9ebd123aa655c224de259536" +checksum = "0fc910d4851847827daf9d6cdd4a823fbdaab5b8818325c5e97a86da79e8881f" dependencies = [ + "heck", "proc-macro2", "quote", "syn", @@ -215,9 +222,9 @@ dependencies = [ [[package]] name = "syn" -version = "1.0.109" +version = "2.0.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +checksum = "239814284fd6f1a4ffe4ca893952cdd93c224b6a1571c9a9eadd670295c0c9e2" dependencies = [ "proc-macro2", "quote", @@ -242,9 +249,9 @@ checksum = "301abaae475aa91687eb82514b328ab47a211a533026cb25fc3e519b86adfc3c" [[package]] name = "unindent" -version = "0.1.11" +version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1766d682d402817b5ac4490b3c3002d91dfa0d22812f341609f97b08757359c" +checksum = "c7de7d73e1754487cb58364ee906a499937a0dfabd86bcb980fa99ec8c8fa2ce" [[package]] name = "windows-targets" From 4ecccbbb56207f7982b3ed81f005a2a8d2cbd181 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Sun, 28 Jan 2024 19:48:07 +0000 Subject: [PATCH 10/13] updated test crate lock files --- .../lib_with_disallowed_lib/Cargo.lock | 39 ++-- test-crates/lib_with_path_dep/Cargo.lock | 212 ++++++++++++++++++ 2 files changed, 235 insertions(+), 16 deletions(-) create mode 100644 test-crates/lib_with_path_dep/Cargo.lock diff --git a/test-crates/lib_with_disallowed_lib/Cargo.lock b/test-crates/lib_with_disallowed_lib/Cargo.lock index 1f66fdb7f..ff33cdf2b 100644 --- a/test-crates/lib_with_disallowed_lib/Cargo.lock +++ b/test-crates/lib_with_disallowed_lib/Cargo.lock @@ -29,11 +29,17 @@ version = "1.0.0" source = "registry+https://github.com/rust-lang/crates.io-index" checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" +[[package]] +name = "heck" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "95505c38b4572b2d910cecb0281560f54b440a19336cbbcb27bf6ce6adc6f5a8" + [[package]] name = "indoc" -version = "1.0.9" +version = "2.0.4" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bfa799dd5ed20a7e349f3b4639aa80d74549c81716d9ec4f994c9b5815598306" +checksum = "1e186cfbae8084e513daff4240b4797e342f988cecda4fb6c939150f96315fd8" [[package]] name = "lib_with_disallowed_lib" @@ -125,9 +131,9 @@ dependencies = [ [[package]] name = "pyo3" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e681a6cfdc4adcc93b4d3cf993749a4552018ee0a9b65fc0ccfad74352c72a38" +checksum = "9a89dc7a5850d0e983be1ec2a463a171d20990487c3cfcd68b5363f1ee3d6fe0" dependencies = [ "cfg-if", "indoc", @@ -142,9 +148,9 @@ dependencies = [ [[package]] name = "pyo3-build-config" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "076c73d0bc438f7a4ef6fdd0c3bb4732149136abd952b110ac93e4edb13a6ba5" +checksum = "07426f0d8fe5a601f26293f300afd1a7b1ed5e78b2a705870c5f30893c5163be" dependencies = [ "once_cell", "target-lexicon", @@ -152,9 +158,9 @@ dependencies = [ [[package]] name = "pyo3-ffi" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e53cee42e77ebe256066ba8aa77eff722b3bb91f3419177cf4cd0f304d3284d9" +checksum = "dbb7dec17e17766b46bca4f1a4215a85006b4c2ecde122076c562dd058da6cf1" dependencies = [ "libc", "pyo3-build-config", @@ -162,9 +168,9 @@ dependencies = [ [[package]] name = "pyo3-macros" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dfeb4c99597e136528c6dd7d5e3de5434d1ceaf487436a3f03b2d56b6fc9efd1" +checksum = "05f738b4e40d50b5711957f142878cfa0f28e054aa0ebdfc3fd137a843f74ed3" dependencies = [ "proc-macro2", "pyo3-macros-backend", @@ -174,10 +180,11 @@ dependencies = [ [[package]] name = "pyo3-macros-backend" -version = "0.19.2" +version = "0.20.2" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "947dc12175c254889edc0c02e399476c2f652b4b9ebd123aa655c224de259536" +checksum = "0fc910d4851847827daf9d6cdd4a823fbdaab5b8818325c5e97a86da79e8881f" dependencies = [ + "heck", "proc-macro2", "quote", "syn", @@ -215,9 +222,9 @@ checksum = "62bb4feee49fdd9f707ef802e22365a35de4b7b299de4763d44bfea899442ff9" [[package]] name = "syn" -version = "1.0.109" +version = "2.0.32" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "72b64191b275b66ffe2469e8af2c1cfe3bafa67b529ead792a6d0160888b4237" +checksum = "239814284fd6f1a4ffe4ca893952cdd93c224b6a1571c9a9eadd670295c0c9e2" dependencies = [ "proc-macro2", "quote", @@ -238,9 +245,9 @@ checksum = "301abaae475aa91687eb82514b328ab47a211a533026cb25fc3e519b86adfc3c" [[package]] name = "unindent" -version = "0.1.11" +version = "0.2.3" source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e1766d682d402817b5ac4490b3c3002d91dfa0d22812f341609f97b08757359c" +checksum = "c7de7d73e1754487cb58364ee906a499937a0dfabd86bcb980fa99ec8c8fa2ce" [[package]] name = "vcpkg" diff --git a/test-crates/lib_with_path_dep/Cargo.lock b/test-crates/lib_with_path_dep/Cargo.lock new file mode 100644 index 000000000..d8f1f8cea --- /dev/null +++ b/test-crates/lib_with_path_dep/Cargo.lock @@ -0,0 +1,212 @@ +# This file is automatically @generated by Cargo. +# It is not intended for manual editing. +version = 3 + +[[package]] +name = "autocfg" +version = "1.1.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" + +[[package]] +name = "bitflags" +version = "1.3.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" + +[[package]] +name = "cfg-if" +version = "1.0.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" + +[[package]] +name = "lib_with_path_dep" +version = "0.1.0" +dependencies = [ + "pyo3", + "some_path_dep", +] + +[[package]] +name = "libc" +version = "0.2.152" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "13e3bf6590cbc649f4d1a3eefc9d5d6eb746f5200ffb04e5e142700b8faa56e7" + +[[package]] +name = "lock_api" +version = "0.4.11" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" +dependencies = [ + "autocfg", + "scopeguard", +] + +[[package]] +name = "memoffset" +version = "0.9.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "5a634b1c61a95585bd15607c6ab0c4e5b226e695ff2800ba0cdccddf208c406c" +dependencies = [ + "autocfg", +] + +[[package]] +name = "once_cell" +version = "1.19.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" + +[[package]] +name = "parking_lot" +version = "0.12.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" +dependencies = [ + "lock_api", + "parking_lot_core", +] + +[[package]] +name = "parking_lot_core" +version = "0.9.9" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" +dependencies = [ + "cfg-if", + "libc", + "redox_syscall", + "smallvec", + "windows-targets", +] + +[[package]] +name = "pyo3" +version = "0.20.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a89dc7a5850d0e983be1ec2a463a171d20990487c3cfcd68b5363f1ee3d6fe0" +dependencies = [ + "cfg-if", + "libc", + "memoffset", + "parking_lot", + "pyo3-build-config", + "pyo3-ffi", +] + +[[package]] +name = "pyo3-build-config" +version = "0.20.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "07426f0d8fe5a601f26293f300afd1a7b1ed5e78b2a705870c5f30893c5163be" +dependencies = [ + "once_cell", + "target-lexicon", +] + +[[package]] +name = "pyo3-ffi" +version = "0.20.2" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dbb7dec17e17766b46bca4f1a4215a85006b4c2ecde122076c562dd058da6cf1" +dependencies = [ + "libc", + "pyo3-build-config", +] + +[[package]] +name = "redox_syscall" +version = "0.4.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" +dependencies = [ + "bitflags", +] + +[[package]] +name = "scopeguard" +version = "1.2.0" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" + +[[package]] +name = "smallvec" +version = "1.13.1" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" + +[[package]] +name = "some_path_dep" +version = "0.1.0" +dependencies = [ + "transitive_path_dep", +] + +[[package]] +name = "target-lexicon" +version = "0.12.13" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "69758bda2e78f098e4ccb393021a0963bb3442eac05f135c30f61b7370bbafae" + +[[package]] +name = "transitive_path_dep" +version = "0.1.0" + +[[package]] +name = "windows-targets" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" +dependencies = [ + "windows_aarch64_gnullvm", + "windows_aarch64_msvc", + "windows_i686_gnu", + "windows_i686_msvc", + "windows_x86_64_gnu", + "windows_x86_64_gnullvm", + "windows_x86_64_msvc", +] + +[[package]] +name = "windows_aarch64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" + +[[package]] +name = "windows_aarch64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" + +[[package]] +name = "windows_i686_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" + +[[package]] +name = "windows_i686_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" + +[[package]] +name = "windows_x86_64_gnu" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" + +[[package]] +name = "windows_x86_64_gnullvm" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" + +[[package]] +name = "windows_x86_64_msvc" +version = "0.48.5" +source = "registry+https://github.com/rust-lang/crates.io-index" +checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" From 5cfc0646b1f28ec17fce875b1ad4a53cbb24d9c6 Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Tue, 27 Feb 2024 11:49:34 +0000 Subject: [PATCH 11/13] removed lock file that was supposed to be missing --- test-crates/lib_with_path_dep/Cargo.lock | 212 ----------------------- 1 file changed, 212 deletions(-) delete mode 100644 test-crates/lib_with_path_dep/Cargo.lock diff --git a/test-crates/lib_with_path_dep/Cargo.lock b/test-crates/lib_with_path_dep/Cargo.lock deleted file mode 100644 index d8f1f8cea..000000000 --- a/test-crates/lib_with_path_dep/Cargo.lock +++ /dev/null @@ -1,212 +0,0 @@ -# This file is automatically @generated by Cargo. -# It is not intended for manual editing. -version = 3 - -[[package]] -name = "autocfg" -version = "1.1.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "d468802bab17cbc0cc575e9b053f41e72aa36bfa6b7f55e3529ffa43161b97fa" - -[[package]] -name = "bitflags" -version = "1.3.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "bef38d45163c2f1dde094a7dfd33ccf595c92905c8f8f4fdc18d06fb1037718a" - -[[package]] -name = "cfg-if" -version = "1.0.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd" - -[[package]] -name = "lib_with_path_dep" -version = "0.1.0" -dependencies = [ - "pyo3", - "some_path_dep", -] - -[[package]] -name = "libc" -version = "0.2.152" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "13e3bf6590cbc649f4d1a3eefc9d5d6eb746f5200ffb04e5e142700b8faa56e7" - -[[package]] -name = "lock_api" -version = "0.4.11" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3c168f8615b12bc01f9c17e2eb0cc07dcae1940121185446edc3744920e8ef45" -dependencies = [ - "autocfg", - "scopeguard", -] - -[[package]] -name = "memoffset" -version = "0.9.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "5a634b1c61a95585bd15607c6ab0c4e5b226e695ff2800ba0cdccddf208c406c" -dependencies = [ - "autocfg", -] - -[[package]] -name = "once_cell" -version = "1.19.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3fdb12b2476b595f9358c5161aa467c2438859caa136dec86c26fdd2efe17b92" - -[[package]] -name = "parking_lot" -version = "0.12.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "3742b2c103b9f06bc9fff0a37ff4912935851bee6d36f3c02bcc755bcfec228f" -dependencies = [ - "lock_api", - "parking_lot_core", -] - -[[package]] -name = "parking_lot_core" -version = "0.9.9" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4c42a9226546d68acdd9c0a280d17ce19bfe27a46bf68784e4066115788d008e" -dependencies = [ - "cfg-if", - "libc", - "redox_syscall", - "smallvec", - "windows-targets", -] - -[[package]] -name = "pyo3" -version = "0.20.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a89dc7a5850d0e983be1ec2a463a171d20990487c3cfcd68b5363f1ee3d6fe0" -dependencies = [ - "cfg-if", - "libc", - "memoffset", - "parking_lot", - "pyo3-build-config", - "pyo3-ffi", -] - -[[package]] -name = "pyo3-build-config" -version = "0.20.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "07426f0d8fe5a601f26293f300afd1a7b1ed5e78b2a705870c5f30893c5163be" -dependencies = [ - "once_cell", - "target-lexicon", -] - -[[package]] -name = "pyo3-ffi" -version = "0.20.2" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dbb7dec17e17766b46bca4f1a4215a85006b4c2ecde122076c562dd058da6cf1" -dependencies = [ - "libc", - "pyo3-build-config", -] - -[[package]] -name = "redox_syscall" -version = "0.4.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "4722d768eff46b75989dd134e5c353f0d6296e5aaa3132e776cbdb56be7731aa" -dependencies = [ - "bitflags", -] - -[[package]] -name = "scopeguard" -version = "1.2.0" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "94143f37725109f92c262ed2cf5e59bce7498c01bcc1502d7b9afe439a4e9f49" - -[[package]] -name = "smallvec" -version = "1.13.1" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "e6ecd384b10a64542d77071bd64bd7b231f4ed5940fba55e98c3de13824cf3d7" - -[[package]] -name = "some_path_dep" -version = "0.1.0" -dependencies = [ - "transitive_path_dep", -] - -[[package]] -name = "target-lexicon" -version = "0.12.13" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "69758bda2e78f098e4ccb393021a0963bb3442eac05f135c30f61b7370bbafae" - -[[package]] -name = "transitive_path_dep" -version = "0.1.0" - -[[package]] -name = "windows-targets" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "9a2fa6e2155d7247be68c096456083145c183cbbbc2764150dda45a87197940c" -dependencies = [ - "windows_aarch64_gnullvm", - "windows_aarch64_msvc", - "windows_i686_gnu", - "windows_i686_msvc", - "windows_x86_64_gnu", - "windows_x86_64_gnullvm", - "windows_x86_64_msvc", -] - -[[package]] -name = "windows_aarch64_gnullvm" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "2b38e32f0abccf9987a4e3079dfb67dcd799fb61361e53e2882c3cbaf0d905d8" - -[[package]] -name = "windows_aarch64_msvc" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "dc35310971f3b2dbbf3f0690a219f40e2d9afcf64f9ab7cc1be722937c26b4bc" - -[[package]] -name = "windows_i686_gnu" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "a75915e7def60c94dcef72200b9a8e58e5091744960da64ec734a6c6e9b3743e" - -[[package]] -name = "windows_i686_msvc" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "8f55c233f70c4b27f66c523580f78f1004e8b5a8b659e05a4eb49d4166cca406" - -[[package]] -name = "windows_x86_64_gnu" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "53d40abd2583d23e4718fddf1ebec84dbff8381c07cae67ff7768bbf19c6718e" - -[[package]] -name = "windows_x86_64_gnullvm" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "0b7b52767868a23d5bab768e390dc5f5c55825b6d30b86c844ff2dc7414044cc" - -[[package]] -name = "windows_x86_64_msvc" -version = "0.48.5" -source = "registry+https://github.com/rust-lang/crates.io-index" -checksum = "ed94fce61571a4006852b7389a063ab983c02eb1bb37b47f8272ce92d06d9538" From 1a5c1882b4fbf1668b30aa073ca5f4bb279f5d5a Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Tue, 27 Feb 2024 13:27:08 +0000 Subject: [PATCH 12/13] updated link in SUMMARY.md --- guide/src/SUMMARY.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/guide/src/SUMMARY.md b/guide/src/SUMMARY.md index f7041481f..696d8bdaa 100644 --- a/guide/src/SUMMARY.md +++ b/guide/src/SUMMARY.md @@ -11,7 +11,7 @@ - [Python Metadata](./metadata.md) - [Configuration](./config.md) - [Environment Variables](./environment-variables.md) -- [Local Development](./develop.md) +- [Local Development](./local_development.md) - [Distribution](./distribution.md) - [Sphinx Integration](./sphinx.md) From 4a68f7701ca2139b7f8a17c853ae309dfd3262ab Mon Sep 17 00:00:00 2001 From: Matthew Broadway Date: Tue, 27 Feb 2024 14:20:17 +0000 Subject: [PATCH 13/13] added tests for pyo3-mixed-with-path-dep --- tests/run.rs | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) diff --git a/tests/run.rs b/tests/run.rs index f85c00198..dad1c68dd 100644 --- a/tests/run.rs +++ b/tests/run.rs @@ -64,6 +64,16 @@ fn develop_pyo3_mixed_submodule() { )); } +#[test] +fn develop_pyo3_mixed_with_path_dep() { + handle_result(develop::test_develop( + "test-crates/pyo3-mixed-with-path-dep", + None, + "develop-pyo3-mixed-with-path-dep", + false, + )); +} + #[test] fn develop_pyo3_mixed_implicit() { handle_result(develop::test_develop( @@ -239,6 +249,17 @@ fn integration_pyo3_mixed_submodule() { )); } +#[test] +fn integration_pyo3_mixed_with_path_dep() { + handle_result(integration::test_integration( + "test-crates/pyo3-mixed-with-path-dep", + None, + "integration-pyo3-mixed-with-path-dep", + false, + None, + )); +} + #[test] fn integration_pyo3_mixed_implicit() { handle_result(integration::test_integration(