An extremely fast Python package and project manager, written in Rust.
Find a file
Charlie Marsh f03398bee3
Copy over pep440-rs crate (#30)
This PR copies over the `pep440-rs` crate at commit
`a8303b01ffef6fccfdce562a887f6b110d482ef3` with no modifications.

It won't pass CI, but modifications will intentionally be confined to
later PRs.
2023-10-06 20:11:52 -04:00
.cargo Add basic CI via GitHub Actions (#10) 2023-10-05 13:42:58 -04:00
.github/workflows Add basic CI via GitHub Actions (#10) 2023-10-05 13:42:58 -04:00
crates Copy over pep440-rs crate (#30) 2023-10-06 20:11:52 -04:00
.gitignore Check in Cargo.lock (#29) 2023-10-06 20:59:17 +00:00
Cargo.lock Check in Cargo.lock (#29) 2023-10-06 20:59:17 +00:00
Cargo.toml Migrate to tokio (#27) 2023-10-06 20:31:03 +00:00
LICENSE-APACHE Add README and LICENSE files 2023-10-05 12:45:38 -04:00
LICENSE-MIT Add README and LICENSE files 2023-10-05 12:45:38 -04:00
README.md Migrate to tokio (#27) 2023-10-06 20:31:03 +00:00
requirements.in Move puffin-installer to its own crate (#23) 2023-10-06 19:31:21 +00:00
requirements.txt Update README 2023-10-06 01:03:07 -04:00
rust-toolchain.toml Add basic CI via GitHub Actions (#10) 2023-10-05 13:42:58 -04:00

puffin

An experimental Python package manager.

Usage

To resolve a requirements.in file:

cargo run -p puffin-cli -- compile requirements.in

To install from a resolved requirements.txt file:

cargo run -p puffin-cli -- sync requirements.txt

Benchmarks

To compare a warm run of puffin to pip:

hyperfine --runs 10 --warmup 3 \
    "./target/release/puffin-cli sync requirements.txt" \
    "pip install -r requirements.txt"

To compare a cold run of puffin to pip:

hyperfine --runs 10 --warmup 3 \
    "./target/release/puffin-cli sync requirements.txt --no-cache" \
    "pip install -r requirements.txt --ignore-installed --no-cache-dir"

License

Puffin is licensed under either of

at your option.

Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in Puffin by you, as defined in the Apache-2.0 license, shall be dually licensed as above, without any additional terms or conditions.