]> git.proxmox.com Git - rustc.git/blame - extra/git2/src/version.rs
New upstream version 1.73.0+dfsg1
[rustc.git] / extra / git2 / src / version.rs
CommitLineData
0a29b90c
FG
1use crate::raw;
2use libc::c_int;
3use std::fmt;
4
5/// Version information about libgit2 and the capabilities it supports.
6pub struct Version {
7 major: c_int,
8 minor: c_int,
9 rev: c_int,
10 features: c_int,
11}
12
13macro_rules! flag_test {
14 ($features:expr, $flag:expr) => {
15 ($features as u32 & $flag as u32) != 0
16 };
17}
18
19impl Version {
20 /// Returns a [`Version`] which provides information about libgit2.
21 pub fn get() -> Version {
22 let mut v = Version {
23 major: 0,
24 minor: 0,
25 rev: 0,
26 features: 0,
27 };
28 unsafe {
29 raw::git_libgit2_version(&mut v.major, &mut v.minor, &mut v.rev);
30 v.features = raw::git_libgit2_features();
31 }
32 v
33 }
34
35 /// Returns the version of libgit2.
36 ///
37 /// The return value is a tuple of `(major, minor, rev)`
38 pub fn libgit2_version(&self) -> (u32, u32, u32) {
39 (self.major as u32, self.minor as u32, self.rev as u32)
40 }
41
42 /// Returns the version of the libgit2-sys crate.
43 pub fn crate_version(&self) -> &'static str {
44 env!("CARGO_PKG_VERSION")
45 }
46
47 /// Returns true if this was built with the vendored version of libgit2.
48 pub fn vendored(&self) -> bool {
49 raw::vendored()
50 }
51
52 /// Returns true if libgit2 was built thread-aware and can be safely used
53 /// from multiple threads.
54 pub fn threads(&self) -> bool {
55 flag_test!(self.features, raw::GIT_FEATURE_THREADS)
56 }
57
58 /// Returns true if libgit2 was built with and linked against a TLS implementation.
59 ///
60 /// Custom TLS streams may still be added by the user to support HTTPS
61 /// regardless of this.
62 pub fn https(&self) -> bool {
63 flag_test!(self.features, raw::GIT_FEATURE_HTTPS)
64 }
65
66 /// Returns true if libgit2 was built with and linked against libssh2.
67 ///
68 /// A custom transport may still be added by the user to support libssh2
69 /// regardless of this.
70 pub fn ssh(&self) -> bool {
71 flag_test!(self.features, raw::GIT_FEATURE_SSH)
72 }
73
74 /// Returns true if libgit2 was built with support for sub-second
75 /// resolution in file modification times.
76 pub fn nsec(&self) -> bool {
77 flag_test!(self.features, raw::GIT_FEATURE_NSEC)
78 }
79}
80
81impl fmt::Debug for Version {
82 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> Result<(), fmt::Error> {
83 let mut f = f.debug_struct("Version");
84 f.field("major", &self.major)
85 .field("minor", &self.minor)
86 .field("rev", &self.rev)
87 .field("crate_version", &self.crate_version())
88 .field("vendored", &self.vendored())
89 .field("threads", &self.threads())
90 .field("https", &self.https())
91 .field("ssh", &self.ssh())
92 .field("nsec", &self.nsec());
93 f.finish()
94 }
95}