pub mod comp_op;
pub mod version;
pub mod version_part;
#[cfg(test)]
mod test;
use comp_op::CompOp;
use version::Version;
pub struct VersionCompare { }
impl VersionCompare {
pub fn compare(a: &str, b: &str) -> Result<CompOp, ()> {
let a_ver = Version::from(a);
let b_ver = Version::from(b);
if a_ver.is_none() || b_ver.is_none() {
return Err(());
}
Ok(a_ver.unwrap().compare(&b_ver.unwrap()))
}
pub fn compare_to(a: &str, b: &str, operator: &CompOp) -> Result<bool, ()> {
let a_ver = Version::from(a);
let b_ver = Version::from(b);
if a_ver.is_none() || b_ver.is_none() {
return Err(());
}
Ok(a_ver.unwrap().compare_to(&b_ver.unwrap(), &operator))
}
}
#[cfg(test)]
mod tests {
use comp_op::CompOp;
use test::test_version_set::TEST_VERSION_SETS;
use super::VersionCompare;
#[test]
fn compare() {
for entry in TEST_VERSION_SETS {
assert_eq!(
VersionCompare::compare(&entry.0, &entry.1),
Ok(entry.2.clone())
);
}
}
#[test]
fn compare_to() {
for entry in TEST_VERSION_SETS {
assert!(VersionCompare::compare_to(&entry.0, &entry.1, &entry.2).unwrap());
assert_eq!(VersionCompare::compare_to(&entry.0, &entry.1, &entry.2.invert()).unwrap(), false);
}
assert!(VersionCompare::compare_to("1.2.3", "1.2", &CompOp::Ne).unwrap());
}
}