6 releases

0.1.5 Dec 17, 2024
0.1.4 Dec 17, 2024
0.1.3 Apr 26, 2024
0.1.2 Nov 1, 2023
0.1.1 Jun 29, 2023

#154 in Parser implementations

Download history 3862/week @ 2024-09-13 4106/week @ 2024-09-20 5173/week @ 2024-09-27 5006/week @ 2024-10-04 3530/week @ 2024-10-11 4865/week @ 2024-10-18 4949/week @ 2024-10-25 4922/week @ 2024-11-01 4259/week @ 2024-11-08 5234/week @ 2024-11-15 5108/week @ 2024-11-22 5769/week @ 2024-11-29 4895/week @ 2024-12-06 6098/week @ 2024-12-13 2251/week @ 2024-12-20 1597/week @ 2024-12-27

15,815 downloads per month
Used in 27 crates (5 directly)

MIT license

120KB
2.5K SLoC

PURL parsing, manipulation, and formatting.

A PURL is an identifier that refers to a software package. For example, pkg:cargo/purl refers to this package.

This library supports PURLs at two levels:

  1. The shape and format of a PURL is implemented by GenericPurl. It is possible to work with package-type-agnostic PURLs by using types like GenericPurl<String>. (see also package-url/purl-spec#38)
  2. The behavior of package types is implemented by PackageType and combined with GenericPurl by the type alias Purl. This implementation differs slightly from the PURL specification (see PackageType for details). It is possible to implement different package-type-specific behaviors or support for different package types by implementing the PurlShape trait.

Example

use std::str::FromStr;

use purl::GenericPurl;

fn main() -> Result<(), Box<dyn std::error::Error>> {
    let purl = GenericPurl::<String>::from_str(
        "pkg:NPM/@acme/example@1.2.3?Checksum=sha256:\
        E3B0C44298FC1C149AFBF4C8996FB92427AE41E4649B934CA495991B7852B855",
    )?;
    assert_eq!("npm", purl.package_type());
    assert_eq!(Some("@acme"), purl.namespace());
    assert_eq!("example", purl.name());
    assert_eq!(Some("1.2.3"), purl.version());
    // Normalization is performed during parsing.
    assert_eq!(
        "sha256:e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
        purl.qualifiers()["checksum"],
    );
    assert_eq!(
        "pkg:npm/%40acme/example@1.2.3?checksum=sha256:\
        e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855",
        &purl.to_string(),
    );

    let purl = purl.into_builder().without_version().without_qualifier("checksum").build()?;
    assert_eq!("pkg:npm/%40acme/example", &purl.to_string(),);
    Ok(())
}

Features

  • package-type: PackageType and related types
  • serde: PURLs can be serialized and deserialized from strings
  • smartstring: The smartstring crate is used to reduce heap allocations

Dependencies

~0.4–1MB
~22K SLoC