arxiv

Crates.ioarxiv
lib.rsarxiv
version1.0.1
sourcesrc
created_at2023-03-28 08:26:40.39698
updated_at2024-11-06 07:03:45.491693
descriptionRust library to parse arXiv identifiers and references
homepage
repositoryhttps://github.com/neoncitylights/arxiv
max_upload_size
id822847
size50,439
Samantha (neoncitylights)

documentation

README

arXiv

License CI Nightly Docs Docs.rs

A Rust library for parsing arXiv categories, identifiers and references.

Install

cargo add arxiv

Usage

Identifiers

use arxiv::{ArticleId, ArticleVersion};

let id = ArticleId::try_from("arXiv:9912.12345v2").unwrap();
assert_eq!(id.month(), 12);
assert_eq!(id.year(), 2099);
assert_eq!(id.number(), "12345");
assert_eq!(id.version(), ArticleVersion::Num(2));

Categories

use arxiv::{Archive, CategoryId, Group};

let category = CategoryId::try_from("astro-ph.HE").unwrap();
assert_eq!(category.group(), Group::Physics);
assert_eq!(category.archive(), Archive::AstroPh);
assert_eq!(category.subject(), "HE");

Stamps

use arxiv::{Archive, CategoryId, Stamp};

let stamp = Stamp::try_from("arXiv:0706.0001v1 [q-bio.CB] 1 Jun 2007").unwrap();
assert_eq!(stamp.category, CategoryId::try_new(Archive::QBio, "CB").unwrap());
assert_eq!(stamp.submitted.year(), 2007);

Feature flags

The crate has the following feature flags:

  • url (default): Enables converting types into URLs where possible, such as converting an article identifier into a URL that leads to its abstract page.

License

Licensed under either of

at your option.

Contribution

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

Commit count: 33

cargo fmt