Struct git_object::CommitRef

source ·
pub struct CommitRef<'a> {
    pub tree: &'a BStr,
    pub parents: SmallVec<[&'a BStr; 1]>,
    pub author: SignatureRef<'a>,
    pub committer: SignatureRef<'a>,
    pub encoding: Option<&'a BStr>,
    pub message: &'a BStr,
    pub extra_headers: Vec<(&'a BStr, Cow<'a, BStr>)>,
}
Expand description

A git commit parsed using from_bytes().

A commit encapsulates information about a point in time at which the state of the repository is recorded, usually after a change which is documented in the commit message.

Fields§

§tree: &'a BStr

HEX hash of tree object we point to. Usually 40 bytes long.

Use tree() to obtain a decoded version of it.

§parents: SmallVec<[&'a BStr; 1]>

HEX hash of each parent commit. Empty for first commit in repository.

§author: SignatureRef<'a>

Who wrote this commit. Name and email might contain whitespace and are not trimmed to ensure round-tripping.

Use the author() method to received a trimmed version of it.

§committer: SignatureRef<'a>

Who committed this commit. Name and email might contain whitespace and are not trimmed to ensure round-tripping.

Use the committer() method to received a trimmed version of it.

This may be different from the author in case the author couldn’t write to the repository themselves and is commonly encountered with contributed commits.

§encoding: Option<&'a BStr>

The name of the message encoding, otherwise UTF-8 should be assumed.

§message: &'a BStr

The commit message documenting the change.

§extra_headers: Vec<(&'a BStr, Cow<'a, BStr>)>

Extra header fields, in order of them being encountered, made accessible with the iterator returned by extra_headers().

Implementations§

source§

impl<'a> CommitRef<'a>

source

pub fn message_summary(&self) -> Cow<'a, BStr>

Return exactly the same message as MessageRef::summary().

source

pub fn message_trailers(&self) -> Trailers<'a>

Return an iterator over message trailers as obtained from the last paragraph of the commit message. May be empty.

source§

impl<'a> CommitRef<'a>

source

pub fn from_bytes(data: &'a [u8]) -> Result<CommitRef<'a>, Error>

Deserialize a commit from the given data bytes while avoiding most allocations.

source

pub fn tree(&self) -> ObjectId

Return the tree fields hash digest.

source

pub fn parents(&self) -> impl Iterator<Item = ObjectId> + '_

Returns an iterator of parent object ids

source

pub fn extra_headers( &self ) -> ExtraHeaders<impl Iterator<Item = (&BStr, &BStr)>>

Returns a convenient iterator over all extra headers.

source

pub fn author(&self) -> SignatureRef<'a>

Return the author, with whitespace trimmed.

This is different from the author field which may contain whitespace.

source

pub fn committer(&self) -> SignatureRef<'a>

Return the committer, with whitespace trimmed.

This is different from the committer field which may contain whitespace.

source

pub fn message(&self) -> MessageRef<'a>

Returns a partially parsed message from which more information can be derived.

source

pub fn time(&self) -> Time

Returns the time at which this commit was created.

Trait Implementations§

source§

impl<'a> Clone for CommitRef<'a>

source§

fn clone(&self) -> CommitRef<'a>

Returns a copy 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<'a> Debug for CommitRef<'a>

source§

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

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

impl<'de: 'a, 'a> Deserialize<'de> for CommitRef<'a>

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 From<CommitRef<'_>> for Commit

source§

fn from(other: CommitRef<'_>) -> Commit

Converts to this type from the input type.
source§

impl<'a> From<CommitRef<'a>> for ObjectRef<'a>

source§

fn from(v: CommitRef<'a>) -> Self

Converts to this type from the input type.
source§

impl<'a> Hash for CommitRef<'a>

source§

fn hash<__H: Hasher>(&self, state: &mut __H)

Feeds this value into the given Hasher. Read more
1.3.0 · source§

fn hash_slice<H>(data: &[Self], state: &mut H)where H: Hasher, Self: Sized,

Feeds a slice of this type into the given Hasher. Read more
source§

impl<'a> Ord for CommitRef<'a>

source§

fn cmp(&self, other: &CommitRef<'a>) -> Ordering

This method returns an Ordering between self and other. Read more
1.21.0 · source§

fn max(self, other: Self) -> Selfwhere Self: Sized,

Compares and returns the maximum of two values. Read more
1.21.0 · source§

fn min(self, other: Self) -> Selfwhere Self: Sized,

Compares and returns the minimum of two values. Read more
1.50.0 · source§

fn clamp(self, min: Self, max: Self) -> Selfwhere Self: Sized + PartialOrd<Self>,

Restrict a value to a certain interval. Read more
source§

impl<'a> PartialEq<CommitRef<'a>> for CommitRef<'a>

source§

fn eq(&self, other: &CommitRef<'a>) -> bool

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl<'a> PartialOrd<CommitRef<'a>> for CommitRef<'a>

source§

fn partial_cmp(&self, other: &CommitRef<'a>) -> Option<Ordering>

This method returns an ordering between self and other values if one exists. Read more
1.0.0 · source§

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

This method tests less than (for self and other) and is used by the < operator. Read more
1.0.0 · source§

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

This method tests less than or equal to (for self and other) and is used by the <= operator. Read more
1.0.0 · source§

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

This method tests greater than (for self and other) and is used by the > operator. Read more
1.0.0 · source§

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

This method tests greater than or equal to (for self and other) and is used by the >= operator. Read more
source§

impl<'a> Serialize for CommitRef<'a>

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<'a> TryFrom<ObjectRef<'a>> for CommitRef<'a>

§

type Error = ObjectRef<'a>

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

fn try_from(value: ObjectRef<'a>) -> Result<Self, Self::Error>

Performs the conversion.
source§

impl<'a> WriteTo for CommitRef<'a>

source§

fn write_to(&self, out: impl Write) -> Result<()>

Serializes this instance to out in the git serialization format.

source§

fn kind(&self) -> Kind

Returns the type of this object.
source§

fn size(&self) -> usize

Returns the size of this object’s representation (the amount of data which would be written by write_to). Read more
source§

fn loose_header(&self) -> SmallVec<[u8; 28]>

Returns a loose object header based on the object’s data
source§

impl<'a> Eq for CommitRef<'a>

source§

impl<'a> StructuralEq for CommitRef<'a>

source§

impl<'a> StructuralPartialEq for CommitRef<'a>

Auto Trait Implementations§

§

impl<'a> RefUnwindSafe for CommitRef<'a>

§

impl<'a> Send for CommitRef<'a>

§

impl<'a> Sync for CommitRef<'a>

§

impl<'a> Unpin for CommitRef<'a>

§

impl<'a> UnwindSafe for CommitRef<'a>

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

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

const: unstable · 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> ToOwned for Twhere T: Clone,

§

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, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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

§

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

The type returned in the event of a conversion error.
const: unstable · source§

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

Performs the conversion.
source§

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