From cfe2a0bdb6220aa9215836e9923f3659ed2f0410 Mon Sep 17 00:00:00 2001 From: Sander Date: Mon, 23 Dec 2024 14:14:15 +0400 Subject: [PATCH] devenv: reduce cache misses from non-deterministic cache key order --- devenv/src/cnix.rs | 23 +++++++++++++---------- 1 file changed, 13 insertions(+), 10 deletions(-) diff --git a/devenv/src/cnix.rs b/devenv/src/cnix.rs index 2817e4cc8..7f881f735 100644 --- a/devenv/src/cnix.rs +++ b/devenv/src/cnix.rs @@ -447,8 +447,8 @@ impl<'a> Nix<'a> { options: &Options<'a>, ) -> Result { let mut final_args = Vec::new(); - let known_keys; - let pull_caches; + let known_keys_str; + let pull_caches_str; let mut push_cache = None; if !self.global_options.offline { @@ -463,28 +463,31 @@ impl<'a> Nix<'a> { push_cache = cachix_caches.caches.push.clone(); // handle cachix.pull if !cachix_caches.caches.pull.is_empty() { - pull_caches = cachix_caches + let mut pull_caches = cachix_caches .caches .pull .iter() .map(|cache| format!("https://{}.cachix.org", cache)) - .collect::>() - .join(" "); + .collect::>(); + pull_caches.sort(); + pull_caches_str = pull_caches.join(" "); final_args.extend_from_slice(&[ "--option", "extra-substituters", - &pull_caches, + &pull_caches_str, ]); - known_keys = cachix_caches + + let mut known_keys = cachix_caches .known_keys .values() .cloned() - .collect::>() - .join(" "); + .collect::>(); + known_keys.sort(); + known_keys_str = known_keys.join(" "); final_args.extend_from_slice(&[ "--option", "extra-trusted-public-keys", - &known_keys, + &known_keys_str, ]); } }