Struct Commit

Source
pub struct Commit<'repo> { /* private fields */ }

Implementations§

Source§

impl<'repo> Commit<'repo>

Source

pub fn sha(&self) -> String

Examples found in repository?
examples/example.rs (line 17)
3fn main() -> Result<(), Box<dyn std::error::Error>> {
4    let path = std::env::args().nth(1).unwrap_or_else(|| String::from("."));
5    let repo = git_commits::open(&path)?;
6
7    for commit in repo.commits()? {
8        let commit = commit?;
9
10        let msg = commit.message_lossy();
11        let first_line = msg.trim().lines().next().unwrap_or_default();
12
13        let committer = commit.committer();
14        let author = commit.author();
15
16        println!();
17        println!("SHA:     {}", commit.sha());
18        println!("Time:    {}", committer.time_local().unwrap()); // same as `commit.time_local()`
19        println!("Author:  {}", author.name_lossy());
20        println!("Message: {first_line}");
21        println!();
22
23        for change in commit.changes()? {
24            let change = change?;
25
26            // The following `match` can be simplified, by simply doing:
27            // println!("  {}", change);
28
29            match change {
30                Change::Added(change) => {
31                    println!(
32                        "  {} {} ({} bytes)",
33                        change.kind().letter(),
34                        change.path().display(),
35                        change.size(),
36                    );
37                }
38                Change::Modified(change) => {
39                    println!(
40                        "  {} {} ({} -> {} bytes)",
41                        change.kind().letter(),
42                        change.path().display(),
43                        change.old_size(),
44                        change.new_size(),
45                    );
46                }
47                Change::Deleted(change) => {
48                    println!(
49                        "  {} {} ({} bytes)",
50                        change.kind().letter(),
51                        change.path().display(),
52                        change.size(),
53                    );
54                }
55                Change::Renamed(change) => {
56                    println!(
57                        "  {} {} -> {} ({} bytes)",
58                        change.kind().letter(),
59                        change.old_path().display(),
60                        change.new_path().display(),
61                        change.size(),
62                    );
63                }
64            }
65        }
66    }
67
68    Ok(())
69}
Source

pub fn message_bytes(&self) -> &[u8]

Source

pub fn message(&self) -> Option<&str>

Source

pub fn message_lossy(&self) -> String

Examples found in repository?
examples/example.rs (line 10)
3fn main() -> Result<(), Box<dyn std::error::Error>> {
4    let path = std::env::args().nth(1).unwrap_or_else(|| String::from("."));
5    let repo = git_commits::open(&path)?;
6
7    for commit in repo.commits()? {
8        let commit = commit?;
9
10        let msg = commit.message_lossy();
11        let first_line = msg.trim().lines().next().unwrap_or_default();
12
13        let committer = commit.committer();
14        let author = commit.author();
15
16        println!();
17        println!("SHA:     {}", commit.sha());
18        println!("Time:    {}", committer.time_local().unwrap()); // same as `commit.time_local()`
19        println!("Author:  {}", author.name_lossy());
20        println!("Message: {first_line}");
21        println!();
22
23        for change in commit.changes()? {
24            let change = change?;
25
26            // The following `match` can be simplified, by simply doing:
27            // println!("  {}", change);
28
29            match change {
30                Change::Added(change) => {
31                    println!(
32                        "  {} {} ({} bytes)",
33                        change.kind().letter(),
34                        change.path().display(),
35                        change.size(),
36                    );
37                }
38                Change::Modified(change) => {
39                    println!(
40                        "  {} {} ({} -> {} bytes)",
41                        change.kind().letter(),
42                        change.path().display(),
43                        change.old_size(),
44                        change.new_size(),
45                    );
46                }
47                Change::Deleted(change) => {
48                    println!(
49                        "  {} {} ({} bytes)",
50                        change.kind().letter(),
51                        change.path().display(),
52                        change.size(),
53                    );
54                }
55                Change::Renamed(change) => {
56                    println!(
57                        "  {} {} -> {} ({} bytes)",
58                        change.kind().letter(),
59                        change.old_path().display(),
60                        change.new_path().display(),
61                        change.size(),
62                    );
63                }
64            }
65        }
66    }
67
68    Ok(())
69}
Source

pub fn author(&self) -> Signature<'_>

The author is the person who wrote the code.

Examples found in repository?
examples/example.rs (line 14)
3fn main() -> Result<(), Box<dyn std::error::Error>> {
4    let path = std::env::args().nth(1).unwrap_or_else(|| String::from("."));
5    let repo = git_commits::open(&path)?;
6
7    for commit in repo.commits()? {
8        let commit = commit?;
9
10        let msg = commit.message_lossy();
11        let first_line = msg.trim().lines().next().unwrap_or_default();
12
13        let committer = commit.committer();
14        let author = commit.author();
15
16        println!();
17        println!("SHA:     {}", commit.sha());
18        println!("Time:    {}", committer.time_local().unwrap()); // same as `commit.time_local()`
19        println!("Author:  {}", author.name_lossy());
20        println!("Message: {first_line}");
21        println!();
22
23        for change in commit.changes()? {
24            let change = change?;
25
26            // The following `match` can be simplified, by simply doing:
27            // println!("  {}", change);
28
29            match change {
30                Change::Added(change) => {
31                    println!(
32                        "  {} {} ({} bytes)",
33                        change.kind().letter(),
34                        change.path().display(),
35                        change.size(),
36                    );
37                }
38                Change::Modified(change) => {
39                    println!(
40                        "  {} {} ({} -> {} bytes)",
41                        change.kind().letter(),
42                        change.path().display(),
43                        change.old_size(),
44                        change.new_size(),
45                    );
46                }
47                Change::Deleted(change) => {
48                    println!(
49                        "  {} {} ({} bytes)",
50                        change.kind().letter(),
51                        change.path().display(),
52                        change.size(),
53                    );
54                }
55                Change::Renamed(change) => {
56                    println!(
57                        "  {} {} -> {} ({} bytes)",
58                        change.kind().letter(),
59                        change.old_path().display(),
60                        change.new_path().display(),
61                        change.size(),
62                    );
63                }
64            }
65        }
66    }
67
68    Ok(())
69}
Source

pub fn committer(&self) -> Signature<'_>

The committer is the person who committed the code, on behalf of the author.

Examples found in repository?
examples/example.rs (line 13)
3fn main() -> Result<(), Box<dyn std::error::Error>> {
4    let path = std::env::args().nth(1).unwrap_or_else(|| String::from("."));
5    let repo = git_commits::open(&path)?;
6
7    for commit in repo.commits()? {
8        let commit = commit?;
9
10        let msg = commit.message_lossy();
11        let first_line = msg.trim().lines().next().unwrap_or_default();
12
13        let committer = commit.committer();
14        let author = commit.author();
15
16        println!();
17        println!("SHA:     {}", commit.sha());
18        println!("Time:    {}", committer.time_local().unwrap()); // same as `commit.time_local()`
19        println!("Author:  {}", author.name_lossy());
20        println!("Message: {first_line}");
21        println!();
22
23        for change in commit.changes()? {
24            let change = change?;
25
26            // The following `match` can be simplified, by simply doing:
27            // println!("  {}", change);
28
29            match change {
30                Change::Added(change) => {
31                    println!(
32                        "  {} {} ({} bytes)",
33                        change.kind().letter(),
34                        change.path().display(),
35                        change.size(),
36                    );
37                }
38                Change::Modified(change) => {
39                    println!(
40                        "  {} {} ({} -> {} bytes)",
41                        change.kind().letter(),
42                        change.path().display(),
43                        change.old_size(),
44                        change.new_size(),
45                    );
46                }
47                Change::Deleted(change) => {
48                    println!(
49                        "  {} {} ({} bytes)",
50                        change.kind().letter(),
51                        change.path().display(),
52                        change.size(),
53                    );
54                }
55                Change::Renamed(change) => {
56                    println!(
57                        "  {} {} -> {} ({} bytes)",
58                        change.kind().letter(),
59                        change.old_path().display(),
60                        change.new_path().display(),
61                        change.size(),
62                    );
63                }
64            }
65        }
66    }
67
68    Ok(())
69}
Source

pub fn when(&self) -> (i64, i32)

Returns the commit time (i.e. committer time) of a commit.

Returns (seconds, offset_minutes).

See also .time() for a chrono DateTime.

Source

pub fn time(&self) -> Option<DateTime<FixedOffset>>

Returns the commit time (i.e. committer time) of a commit.

Returns None for an invalid timestamp.

Source

pub fn time_utc(&self) -> Option<DateTime<Utc>>

Returns the commit time (i.e. committer time) of a commit.

Returns None for an invalid timestamp.

Source

pub fn time_local(&self) -> Option<DateTime<Local>>

Returns the commit time (i.e. committer time) of a commit.

Returns None for an invalid timestamp.

Source

pub fn changes(&self) -> Result<Changes<'repo, '_>, GitError>

Returns an iterator that produces all changes this commit performed.

Examples found in repository?
examples/example.rs (line 23)
3fn main() -> Result<(), Box<dyn std::error::Error>> {
4    let path = std::env::args().nth(1).unwrap_or_else(|| String::from("."));
5    let repo = git_commits::open(&path)?;
6
7    for commit in repo.commits()? {
8        let commit = commit?;
9
10        let msg = commit.message_lossy();
11        let first_line = msg.trim().lines().next().unwrap_or_default();
12
13        let committer = commit.committer();
14        let author = commit.author();
15
16        println!();
17        println!("SHA:     {}", commit.sha());
18        println!("Time:    {}", committer.time_local().unwrap()); // same as `commit.time_local()`
19        println!("Author:  {}", author.name_lossy());
20        println!("Message: {first_line}");
21        println!();
22
23        for change in commit.changes()? {
24            let change = change?;
25
26            // The following `match` can be simplified, by simply doing:
27            // println!("  {}", change);
28
29            match change {
30                Change::Added(change) => {
31                    println!(
32                        "  {} {} ({} bytes)",
33                        change.kind().letter(),
34                        change.path().display(),
35                        change.size(),
36                    );
37                }
38                Change::Modified(change) => {
39                    println!(
40                        "  {} {} ({} -> {} bytes)",
41                        change.kind().letter(),
42                        change.path().display(),
43                        change.old_size(),
44                        change.new_size(),
45                    );
46                }
47                Change::Deleted(change) => {
48                    println!(
49                        "  {} {} ({} bytes)",
50                        change.kind().letter(),
51                        change.path().display(),
52                        change.size(),
53                    );
54                }
55                Change::Renamed(change) => {
56                    println!(
57                        "  {} {} -> {} ({} bytes)",
58                        change.kind().letter(),
59                        change.old_path().display(),
60                        change.new_path().display(),
61                        change.size(),
62                    );
63                }
64            }
65        }
66    }
67
68    Ok(())
69}

Trait Implementations§

Source§

impl Display for Commit<'_>

Source§

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

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<'repo> Freeze for Commit<'repo>

§

impl<'repo> RefUnwindSafe for Commit<'repo>

§

impl<'repo> !Send for Commit<'repo>

§

impl<'repo> !Sync for Commit<'repo>

§

impl<'repo> Unpin for Commit<'repo>

§

impl<'repo> UnwindSafe for Commit<'repo>

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> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

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> 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> ErasedDestructor for T
where T: 'static,