Struct semver::VersionReq
[−]
[src]
pub struct VersionReq { // some fields omitted }
A VersionReq
is a struct containing a list of predicates that can apply to ranges of version
numbers. Matching operations can then be done with the VersionReq
against a particular
version to see if it satisfies some or all of the constraints.
Methods
impl VersionReq
fn any() -> VersionReq
any()
is a factory method which creates a VersionReq
with no constraints. In other
words, any version will match against it.
Examples
use semver::VersionReq; let anything = VersionReq::any();
fn parse(input: &str) -> Result<VersionReq, ReqParseError>
parse()
is the main constructor of a VersionReq
. It turns a string like "^1.2.3"
and turns it into a VersionReq
that matches that particular constraint.
A Result
is returned which contains a ReqParseError
if there was a problem parsing the
VersionReq
.
Examples
use semver::VersionReq; let version = VersionReq::parse("=1.2.3"); let version = VersionReq::parse(">1.2.3"); let version = VersionReq::parse("<1.2.3"); let version = VersionReq::parse("~1.2.3"); let version = VersionReq::parse("^1.2.3"); let version = VersionReq::parse("<=1.2.3"); let version = VersionReq::parse(">=1.2.3");
This example demonstrates error handling, and will panic.
use semver::VersionReq;
let version = match VersionReq::parse("not a version") {
Ok(version) => version,
Err(e) => panic!("There was a problem parsing: {}", e),
}
fn exact(version: &Version) -> VersionReq
exact()
is a factory method which creates a VersionReq
with one exact constraint.
Examples
use semver::VersionReq; use semver::Version; let version = Version { major: 1, minor: 1, patch: 1, pre: vec![], build: vec![] }; let exact = VersionReq::exact(&version);
fn matches(&self, version: &Version) -> bool
matches()
matches a given Version
against this VersionReq
.
Examples
use semver::VersionReq; use semver::Version; let version = Version { major: 1, minor: 1, patch: 1, pre: vec![], build: vec![] }; let exact = VersionReq::exact(&version); assert!(exact.matches(&version));