From 0a4ce466dda6024cd6bad74d8fc2f6c71d38f7b7 Mon Sep 17 00:00:00 2001 From: Weihang Lo Date: Wed, 20 Dec 2023 17:17:51 -0500 Subject: [PATCH] refactor: centralize git checkouts and db paths --- src/cargo/core/global_cache_tracker.rs | 5 ++--- src/cargo/sources/git/source.rs | 9 ++++++--- src/cargo/util/config/mod.rs | 12 ++++++++++++ 3 files changed, 20 insertions(+), 6 deletions(-) diff --git a/src/cargo/core/global_cache_tracker.rs b/src/cargo/core/global_cache_tracker.rs index 79ae252d9b3..21f9b31c3ca 100644 --- a/src/cargo/core/global_cache_tracker.rs +++ b/src/cargo/core/global_cache_tracker.rs @@ -560,11 +560,10 @@ impl GlobalCacheTracker { ) -> CargoResult<()> { let _p = crate::util::profile::start("cleaning global cache files"); let config = clean_ctx.config; - let base_git_path = config.git_path().into_path_unlocked(); let base = BasePaths { index: config.registry_index_path().into_path_unlocked(), - git_db: base_git_path.join("db"), - git_co: base_git_path.join("checkouts"), + git_db: config.git_db_path().into_path_unlocked(), + git_co: config.git_checkouts_path().into_path_unlocked(), crate_dir: config.registry_cache_path().into_path_unlocked(), src: config.registry_source_path().into_path_unlocked(), }; diff --git a/src/cargo/sources/git/source.rs b/src/cargo/sources/git/source.rs index 664c64bfe12..7d303f0c25f 100644 --- a/src/cargo/sources/git/source.rs +++ b/src/cargo/sources/git/source.rs @@ -248,7 +248,8 @@ impl<'cfg> Source for GitSource<'cfg> { // exists. exclude_from_backups_and_indexing(&git_path); - let db_path = git_path.join("db").join(&self.ident); + let db_path = self.config.git_db_path().join(&self.ident); + let db_path = db_path.into_path_unlocked(); let db = self.remote.db_at(&db_path).ok(); let (db, actual_rev) = match (self.locked_rev, db) { @@ -305,10 +306,12 @@ impl<'cfg> Source for GitSource<'cfg> { // Check out `actual_rev` from the database to a scoped location on the // filesystem. This will use hard links and such to ideally make the // checkout operation here pretty fast. - let checkout_path = git_path - .join("checkouts") + let checkout_path = self + .config + .git_checkouts_path() .join(&self.ident) .join(short_id.as_str()); + let checkout_path = checkout_path.into_path_unlocked(); db.copy_to(actual_rev, &checkout_path, self.config)?; let source_id = self diff --git a/src/cargo/util/config/mod.rs b/src/cargo/util/config/mod.rs index 2362aa7e73b..0e161ba8af4 100644 --- a/src/cargo/util/config/mod.rs +++ b/src/cargo/util/config/mod.rs @@ -368,6 +368,18 @@ impl Config { self.home_path.join("git") } + /// Gets the directory of code sources Cargo checkouts from Git bare repos + /// (`/git/checkouts`). + pub fn git_checkouts_path(&self) -> Filesystem { + self.git_path().join("checkouts") + } + + /// Gets the directory for all Git bare repos Cargo clones + /// (`/git/db`). + pub fn git_db_path(&self) -> Filesystem { + self.git_path().join("db") + } + /// Gets the Cargo base directory for all registry information (`/registry`). pub fn registry_base_path(&self) -> Filesystem { self.home_path.join("registry")