pub struct GitVersion {
major: u64,
minor: u64,
patch: u64,
commits_ahead: u64,
hash: Option<String>,
dirty: bool,
}Expand description
A parsed git describe version string.
Fields§
§major: u64§minor: u64§patch: u64§commits_ahead: u64§hash: Option<String>§dirty: boolImplementations§
Source§impl GitVersion
impl GitVersion
Sourcepub fn parse(version: &str) -> Result<Self, VersionError>
pub fn parse(version: &str) -> Result<Self, VersionError>
Parses a version string in git describe format.
Supported formats:
v0.9.46- Tagged releasev0.9.46-5-gabc123- Development build with commits aheadv0.9.46-5-gabc123-dirty- Dirty working tree
§Errors
Returns VersionError::InvalidFormat if the version string cannot be parsed.
§Examples
use cadmus_core::version::GitVersion;
let v = GitVersion::parse("v0.9.46").unwrap();
assert_eq!(v.major(), 0);
assert_eq!(v.minor(), 9);
assert_eq!(v.patch(), 46);Sourcepub fn commits_ahead(&self) -> u64
pub fn commits_ahead(&self) -> u64
Returns the number of commits ahead of the tag.
Sourcepub fn is_tagged_release(&self) -> bool
pub fn is_tagged_release(&self) -> bool
Returns true if this is a tagged release (no commits ahead).
Sourcepub fn compare(
&self,
other: &GitVersion,
) -> Result<VersionComparison, VersionError>
pub fn compare( &self, other: &GitVersion, ) -> Result<VersionComparison, VersionError>
Compares this version with another.
If both versions contain different git hashes, this method will use the GitHub API to check ancestry relationships.
§Examples
use cadmus_core::version::{GitVersion, VersionComparison};
// Local is newer than remote (higher semver)
let local: GitVersion = "v0.9.46".parse().unwrap();
let remote: GitVersion = "v0.9.45".parse().unwrap();
let result = local.compare(&remote).unwrap();
assert_eq!(result, VersionComparison::Newer);
// Local is older than remote (lower semver)
let local: GitVersion = "v0.9.44".parse().unwrap();
let remote: GitVersion = "v0.9.45".parse().unwrap();
let result = local.compare(&remote).unwrap();
assert_eq!(result, VersionComparison::Older);
// Local equals remote (same version)
let local: GitVersion = "v0.9.46".parse().unwrap();
let remote: GitVersion = "v0.9.46".parse().unwrap();
let result = local.compare(&remote).unwrap();
assert_eq!(result, VersionComparison::Equal);Trait Implementations§
Source§impl Clone for GitVersion
impl Clone for GitVersion
Source§fn clone(&self) -> GitVersion
fn clone(&self) -> GitVersion
Returns a duplicate of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source. Read moreSource§impl Debug for GitVersion
impl Debug for GitVersion
Source§impl<'de> Deserialize<'de> for GitVersion
impl<'de> Deserialize<'de> for GitVersion
Source§fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>where
D: Deserializer<'de>,
Deserialize this value from the given Serde deserializer. Read more
Source§impl Display for GitVersion
impl Display for GitVersion
Source§impl FromStr for GitVersion
impl FromStr for GitVersion
Source§impl PartialEq for GitVersion
impl PartialEq for GitVersion
Source§impl Serialize for GitVersion
impl Serialize for GitVersion
impl Eq for GitVersion
impl StructuralPartialEq for GitVersion
Auto Trait Implementations§
impl Freeze for GitVersion
impl RefUnwindSafe for GitVersion
impl Send for GitVersion
impl Sync for GitVersion
impl Unpin for GitVersion
impl UnwindSafe for GitVersion
Blanket Implementations§
§impl<T> AnyEq for T
impl<T> AnyEq for T
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn Any>
fn into_any(self: Box<T>) -> Box<dyn Any>
Converts
Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be
downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>
Converts
Rc<Trait> (where Trait: Downcast) to Rc<Any>, which can then be further
downcast into Rc<ConcreteType> where ConcreteType implements Trait.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Converts
&Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &Any’s vtable from &Trait’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Converts
&mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot
generate &mut Any’s vtable from &mut Trait’s.§impl<T> DowncastSend for T
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key and return true if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more§impl<T> PolicyExt for Twhere
T: ?Sized,
impl<T> PolicyExt for Twhere
T: ?Sized,
§impl<T> ToStringFallible for Twhere
T: Display,
impl<T> ToStringFallible for Twhere
T: Display,
§fn try_to_string(&self) -> Result<String, TryReserveError>
fn try_to_string(&self) -> Result<String, TryReserveError>
ToString::to_string, but without panic on OOM.