1
0
mirror of https://github.com/Llewellynvdm/starship.git synced 2024-11-24 13:47:38 +00:00

fix(git): upgrade gitoxide to v0.21 (#4277)

* upgrade `gitoxide` to v0.21

This release comes with lenient configuration handling by default,
allowing to open repositories even their configuration values are
invalid (even for git), as long as there are viable defaults.

Furthermore this release adds the ability to open submodule repsitories.

Fixes https://github.com/starship/starship/issues/4266 and
fixes https://github.com/starship/starship/issues/4272

* Assure an object cache is set to speed up `commit.describe()`

Related to https://github.com/starship/starship/issues/4275 bringing
performance to spitting distance compared to git.
This commit is contained in:
Sebastian Thiel 2022-08-18 14:22:51 +08:00 committed by GitHub
parent 12d72de0a6
commit f52ae552d3
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 69 additions and 44 deletions

107
Cargo.lock generated
View File

@ -927,9 +927,9 @@ dependencies = [
[[package]] [[package]]
name = "git-actor" name = "git-actor"
version = "0.11.0" version = "0.11.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "2a5d2a77331398a96dc6464f1602358f80831f8c1d482d9b36b8589b89727b46" checksum = "48c82fe4f9747e12dba0db1a680720014579c6c25a2859a0e756d9333191fdcd"
dependencies = [ dependencies = [
"bstr", "bstr",
"btoi", "btoi",
@ -941,9 +941,9 @@ dependencies = [
[[package]] [[package]]
name = "git-attributes" name = "git-attributes"
version = "0.3.0" version = "0.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "76d0551e2d2931a8af08fe587d1d109a621a521fb3f250bd8745653f70fda27f" checksum = "51845b670130052b90b0938d97d9507c81f3e81f355b232d024729a771293b82"
dependencies = [ dependencies = [
"bstr", "bstr",
"compact_str", "compact_str",
@ -951,15 +951,15 @@ dependencies = [
"git-glob", "git-glob",
"git-path", "git-path",
"git-quote", "git-quote",
"quick-error", "thiserror",
"unicode-bom", "unicode-bom",
] ]
[[package]] [[package]]
name = "git-bitmap" name = "git-bitmap"
version = "0.1.0" version = "0.1.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "7715cc94cd761fe92bb5626a332e4886292c7af88984abfdafad82dd56002475" checksum = "5442ba44b4385121a333f56837f3e6ce5a1b843d080b93d764578960a510507b"
dependencies = [ dependencies = [
"quick-error", "quick-error",
] ]
@ -975,9 +975,9 @@ dependencies = [
[[package]] [[package]]
name = "git-config" name = "git-config"
version = "0.6.0" version = "0.6.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "2517e4a1f8c82266debd70d43aac472ebc6cc403d4b4213e222d2c4d2c67aa97" checksum = "168f2e6bec559afb1e029510ee1746f0971fd35bbd5c20bf43c9df74e32be8f8"
dependencies = [ dependencies = [
"bitflags", "bitflags",
"bstr", "bstr",
@ -996,9 +996,9 @@ dependencies = [
[[package]] [[package]]
name = "git-date" name = "git-date"
version = "0.0.2" version = "0.0.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "de28bca8c01f1ed4e776bed75802c7f7e671da112496445dfcf885bc1a357250" checksum = "0ebf74e9db8846a62865c16999d737b803ad9672e5ba46cd81901e0196f63344"
dependencies = [ dependencies = [
"bstr", "bstr",
"itoa", "itoa",
@ -1007,9 +1007,9 @@ dependencies = [
[[package]] [[package]]
name = "git-diff" name = "git-diff"
version = "0.17.0" version = "0.17.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ca9907f146e0ea61fabca745e45296a4da11cf4d6fd4d7aaa544ccc00f211419" checksum = "c7a3d2379658de2bf9b25e730ca8e486d66f1f9515e7f82b1d165f5e0afec742"
dependencies = [ dependencies = [
"git-hash", "git-hash",
"git-object", "git-object",
@ -1018,9 +1018,9 @@ dependencies = [
[[package]] [[package]]
name = "git-discover" name = "git-discover"
version = "0.3.0" version = "0.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9db794b6e98c7fb9667c371d64a35534a4bfe088868a80efe4cfe38a71379bab" checksum = "5cf1909f287bd3365dabdbb657f78f02c2ef496001db782f6137588c9668623a"
dependencies = [ dependencies = [
"bstr", "bstr",
"git-hash", "git-hash",
@ -1048,6 +1048,7 @@ dependencies = [
"parking_lot 0.12.1", "parking_lot 0.12.1",
"prodash", "prodash",
"quick-error", "quick-error",
"sha-1",
"sha1_smol", "sha1_smol",
"walkdir", "walkdir",
] ]
@ -1074,9 +1075,9 @@ dependencies = [
[[package]] [[package]]
name = "git-index" name = "git-index"
version = "0.4.0" version = "0.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6b6795e3808f9ddc823c9864bec0ddb5c1e44479ac5aea0d6ff25ae0f0d657c1" checksum = "80691537dd8702a4dc317a1aebc969fae51b0dc995e44e07203cfcb60d49efef"
dependencies = [ dependencies = [
"atoi", "atoi",
"bitflags", "bitflags",
@ -1086,9 +1087,10 @@ dependencies = [
"git-features", "git-features",
"git-hash", "git-hash",
"git-object", "git-object",
"itoa",
"memmap2", "memmap2",
"quick-error",
"smallvec", "smallvec",
"thiserror",
] ]
[[package]] [[package]]
@ -1104,9 +1106,9 @@ dependencies = [
[[package]] [[package]]
name = "git-object" name = "git-object"
version = "0.20.0" version = "0.20.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "78bbda5da28d4bb564100373816dd21ba94709c39df12c114764967356430a8e" checksum = "2873d25c73b490aad3897d12f5d1bb9e91404590f37dcf9b72d229972192c07c"
dependencies = [ dependencies = [
"bstr", "bstr",
"btoi", "btoi",
@ -1123,9 +1125,9 @@ dependencies = [
[[package]] [[package]]
name = "git-odb" name = "git-odb"
version = "0.31.0" version = "0.31.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "3ff0f045f8ef21a99fcd9ca540b5a3a7d9f50805316fc183da1e580978c9c561" checksum = "e69359d85f7dbbe05984024e63e581092ef38bdf0f12c461077d190fe47b061d"
dependencies = [ dependencies = [
"arc-swap", "arc-swap",
"git-features", "git-features",
@ -1141,9 +1143,9 @@ dependencies = [
[[package]] [[package]]
name = "git-pack" name = "git-pack"
version = "0.21.0" version = "0.21.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "02268bfe5fe46a6b8dfa5d14357cc1086eba134e254ca7703261ed00f142eb62" checksum = "89910dcf8ea9befe504e6373832b38c9da49e8dd830206c7f9deae29f1e1d58c"
dependencies = [ dependencies = [
"bytesize", "bytesize",
"clru", "clru",
@ -1187,9 +1189,9 @@ dependencies = [
[[package]] [[package]]
name = "git-ref" name = "git-ref"
version = "0.15.0" version = "0.15.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e365e9a3ee19ca10c9cd8f6f7ea4d464b6dfc73b5ef0f0cbc5747e29dfc14e93" checksum = "95c37be789a743f28b1430c9d6096fa637eb696746ae88b76c4b96112e802c8f"
dependencies = [ dependencies = [
"git-actor", "git-actor",
"git-features", "git-features",
@ -1206,19 +1208,22 @@ dependencies = [
[[package]] [[package]]
name = "git-repository" name = "git-repository"
version = "0.20.0" version = "0.21.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9636655207e546b2885248ead6252b54c319cca182914fd7a6cb1d499ab84dc3" checksum = "1cd55007ded60d55237cd899475feca98047b141a6805f63e3c2131e581546f6"
dependencies = [ dependencies = [
"byte-unit", "byte-unit",
"clru", "clru",
"git-actor", "git-actor",
"git-attributes",
"git-config", "git-config",
"git-date", "git-date",
"git-diff", "git-diff",
"git-discover", "git-discover",
"git-features", "git-features",
"git-glob",
"git-hash", "git-hash",
"git-index",
"git-lock", "git-lock",
"git-object", "git-object",
"git-odb", "git-odb",
@ -1234,15 +1239,16 @@ dependencies = [
"git-worktree", "git-worktree",
"log", "log",
"signal-hook 0.3.14", "signal-hook 0.3.14",
"smallvec",
"thiserror", "thiserror",
"unicode-normalization", "unicode-normalization",
] ]
[[package]] [[package]]
name = "git-revision" name = "git-revision"
version = "0.3.0" version = "0.4.0"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "681181c8e87d96d6a47bafe1e4d8c9c7b0091c69573e69bd01422fc1a828f43d" checksum = "3228b58f157e44051791992d38fb0c502ebf3bc1a10b119b3c9089ef6d84b10e"
dependencies = [ dependencies = [
"bstr", "bstr",
"git-date", "git-date",
@ -1282,9 +1288,9 @@ dependencies = [
[[package]] [[package]]
name = "git-traverse" name = "git-traverse"
version = "0.16.0" version = "0.16.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "fff51d777e90a9a46b6d556ff4715eace4a42d7fde546ef21a315a80d4121827" checksum = "c89b9468cd57d145b8bc06f1a8e867b8ed5044c3f856cc7b98a9aac97f9163aa"
dependencies = [ dependencies = [
"git-hash", "git-hash",
"git-object", "git-object",
@ -1294,9 +1300,9 @@ dependencies = [
[[package]] [[package]]
name = "git-url" name = "git-url"
version = "0.7.0" version = "0.7.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "650aa16382e135904f7303cd4156778df3979fc4f3589ea07d870444272486a3" checksum = "7efc31fd6bb3a52a18006dfaf686e3ba4d0d7ad0ca325bfc7d719affd28dc624"
dependencies = [ dependencies = [
"bstr", "bstr",
"git-features", "git-features",
@ -1318,9 +1324,9 @@ dependencies = [
[[package]] [[package]]
name = "git-worktree" name = "git-worktree"
version = "0.4.0" version = "0.4.1"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "6a7e0c10fb0543096aa759e4f082866399e375ffb5e95a4f9e3dcdb3cd6ec488" checksum = "779a6a2a0d51b690fdf1e0024138a2f320be89db7fc2e7f5becd20e65aa42344"
dependencies = [ dependencies = [
"bstr", "bstr",
"git-attributes", "git-attributes",
@ -1483,9 +1489,9 @@ dependencies = [
[[package]] [[package]]
name = "itoa" name = "itoa"
version = "1.0.2" version = "1.0.3"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "112c678d4050afce233f4f2852bb2eb519230b3cf12f33585275537d7e41578d" checksum = "6c8af84674fe1f223a982c933a0ee1086ac4d4052aa0fb8060c12c6ad838e754"
[[package]] [[package]]
name = "js-sys" name = "js-sys"
@ -2551,6 +2557,7 @@ dependencies = [
"cfg-if 1.0.0", "cfg-if 1.0.0",
"cpufeatures", "cpufeatures",
"digest 0.10.3", "digest 0.10.3",
"sha1-asm",
] ]
[[package]] [[package]]
@ -2562,6 +2569,15 @@ dependencies = [
"sha1_smol", "sha1_smol",
] ]
[[package]]
name = "sha1-asm"
version = "0.5.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "563d4f7100bc3fce234e5f37bbf63dc2752558964505ba6ac3f7204bdc59eaac"
dependencies = [
"cc",
]
[[package]] [[package]]
name = "sha1_smol" name = "sha1_smol"
version = "1.0.0" version = "1.0.0"
@ -2903,18 +2919,18 @@ dependencies = [
[[package]] [[package]]
name = "thiserror" name = "thiserror"
version = "1.0.31" version = "1.0.32"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "bd829fe32373d27f76265620b5309d0340cb8550f523c1dda251d6298069069a" checksum = "f5f6586b7f764adc0231f4c79be7b920e766bb2f3e51b3661cdb263828f19994"
dependencies = [ dependencies = [
"thiserror-impl", "thiserror-impl",
] ]
[[package]] [[package]]
name = "thiserror-impl" name = "thiserror-impl"
version = "1.0.31" version = "1.0.32"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "0396bc89e626244658bef819e22d0cc459e795a5ebe878e6ec336d1674a8d79a" checksum = "12bafc5b54507e0149cdf1b145a5d80ab80a90bcd9275df43d4fff68460f6c21"
dependencies = [ dependencies = [
"proc-macro2", "proc-macro2",
"quote", "quote",
@ -2941,8 +2957,15 @@ dependencies = [
"itoa", "itoa",
"libc", "libc",
"num_threads", "num_threads",
"time-macros",
] ]
[[package]]
name = "time-macros"
version = "0.2.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "42657b1a6f4d817cda8e7a0ace261fe0cc946cf3a80314390b22cc61ae080792"
[[package]] [[package]]
name = "tinyvec" name = "tinyvec"
version = "1.6.0" version = "1.6.0"

View File

@ -44,7 +44,7 @@ dunce = "1.0.2"
gethostname = "0.2.3" gethostname = "0.2.3"
# Addresses https://github.com/starship/starship/issues/4251 # Addresses https://github.com/starship/starship/issues/4251
git-features = { version = "0.22.1", features = ["fs-walkdir-single-threaded"] } git-features = { version = "0.22.1", features = ["fs-walkdir-single-threaded"] }
git-repository = "0.20.0" git-repository = "0.21.0"
indexmap = { version = "1.9.1", features = ["serde"] } indexmap = { version = "1.9.1", features = ["serde"] }
local_ipaddress = "0.1.3" local_ipaddress = "0.1.3"
log = { version = "0.4.16", features = ["std"] } log = { version = "0.4.16", features = ["std"] }

View File

@ -51,7 +51,9 @@ pub fn module<'a>(context: &'a Context) -> Option<Module<'a>> {
} }
fn git_tag(repo: &Repo) -> Option<String> { fn git_tag(repo: &Repo) -> Option<String> {
let git_repo = repo.open(); // allow environment variables like GITOXIDE_OBJECT_CACHE_MEMORY and GITOXIDE_DISABLE_PACK_CACHE to speed up operation for some repos
let mut git_repo = repo.open().apply_environment();
git_repo.object_cache_size_if_unset(4 * 1024 * 1024);
let head_commit = git_repo.head_commit().ok()?; let head_commit = git_repo.head_commit().ok()?;
let describe_platform = head_commit.describe().names(AnnotatedTags); let describe_platform = head_commit.describe().names(AnnotatedTags);