Skip to main content

ProtocolVersion

Struct ProtocolVersion 

Source
pub struct ProtocolVersion {
    pub semantic: String,
    pub git_describe: Option<String>,
    pub git_hash: Option<String>,
}
Expand description

Protocol version information

Contains version information for compatibility checking between rcp and rcpd. The semantic version is used for compatibility checks, while git information provides additional debugging context.

Fields§

§semantic: String

Semantic version from Cargo.toml (e.g., “0.22.0”)

This is the primary version used for compatibility checking.

§git_describe: Option<String>

Git describe output (e.g., “v0.21.1-7-g644da27”)

Optional. Provides detailed version information including:

  • Most recent tag
  • Number of commits since tag
  • Short commit hash
  • “-dirty” suffix if working tree has uncommitted changes
§git_hash: Option<String>

Full git commit hash

Optional. Useful for exact build identification and debugging.

Implementations§

Source§

impl ProtocolVersion

Source

pub fn current() -> Self

Get the current protocol version

Reads version information from environment variables set at compile time by build.rs. The semantic version is always available, while git information may be absent if the build was done without git available.

Source

pub fn is_compatible_with(&self, other: &Self) -> bool

Check if this version is compatible with another version

Currently implements exact version matching: versions are compatible only if their semantic versions match exactly.

§Examples
use common::version::ProtocolVersion;

let v1 = ProtocolVersion {
    semantic: "0.22.0".to_string(),
    git_describe: None,
    git_hash: None,
};

let v2 = ProtocolVersion {
    semantic: "0.22.0".to_string(),
    git_describe: Some("v0.21.1-7-g644da27".to_string()),
    git_hash: None,
};

assert!(v1.is_compatible_with(&v2));
Source

pub fn display(&self) -> String

Get a human-readable version string

Returns the semantic version, optionally including git describe information if available.

§Examples
use common::version::ProtocolVersion;

let v = ProtocolVersion {
    semantic: "0.22.0".to_string(),
    git_describe: Some("v0.21.1-7-g644da27".to_string()),
    git_hash: None,
};

assert_eq!(v.display(), "0.22.0 (v0.21.1-7-g644da27)");
Source

pub fn to_json(&self) -> Result<String>

Serialize to JSON string

§Errors

Returns an error if JSON serialization fails.

Source

pub fn from_json(json: &str) -> Result<Self>

Deserialize from JSON string

§Errors

Returns an error if JSON deserialization fails or the format is invalid.

Trait Implementations§

Source§

impl Clone for ProtocolVersion

Source§

fn clone(&self) -> ProtocolVersion

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for ProtocolVersion

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl<'de> Deserialize<'de> for ProtocolVersion

Source§

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 ProtocolVersion

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for ProtocolVersion

Source§

fn eq(&self, other: &ProtocolVersion) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Serialize for ProtocolVersion

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more
Source§

impl Eq for ProtocolVersion

Source§

impl StructuralPartialEq for ProtocolVersion

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Checks if this value is equivalent to the given key. Read more
Source§

impl<Q, K> Equivalent<K> for Q
where Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,

Source§

fn equivalent(&self, key: &K) -> bool

Compare self to key and return true if they are equal.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> FromRef<T> for T
where T: Clone,

Source§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<L> LayerExt<L> for L

Source§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in Layered.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T> ToString for T
where T: Display + ?Sized,

Source§

fn to_string(&self) -> String

Converts the given value to a String. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,