Fixup multiple --extra-conf usages (#456)
* Fixup multiple --extra-conf usages * Merge experimental-features passed in extra-conf
This commit is contained in:
parent
217c3683bc
commit
7c9dfacf8e
2 changed files with 17 additions and 5 deletions
|
@ -5,6 +5,7 @@ use crate::action::base::{CreateDirectory, CreateOrMergeNixConfig};
|
||||||
use crate::action::{
|
use crate::action::{
|
||||||
Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction,
|
Action, ActionDescription, ActionError, ActionErrorKind, ActionTag, StatefulAction,
|
||||||
};
|
};
|
||||||
|
use std::collections::hash_map::Entry;
|
||||||
|
|
||||||
const NIX_CONF_FOLDER: &str = "/etc/nix";
|
const NIX_CONF_FOLDER: &str = "/etc/nix";
|
||||||
const NIX_CONF: &str = "/etc/nix/nix.conf";
|
const NIX_CONF: &str = "/etc/nix/nix.conf";
|
||||||
|
@ -32,10 +33,21 @@ impl PlaceNixConfiguration {
|
||||||
let settings = nix_config.settings_mut();
|
let settings = nix_config.settings_mut();
|
||||||
|
|
||||||
settings.insert("build-users-group".to_string(), nix_build_group_name);
|
settings.insert("build-users-group".to_string(), nix_build_group_name);
|
||||||
settings.insert(
|
let experimental_features = ["nix-command", "flakes", "auto-allocate-uids"];
|
||||||
"experimental-features".to_string(),
|
match settings.entry("experimental-features".to_string()) {
|
||||||
"nix-command flakes auto-allocate-uids".to_string(),
|
Entry::Occupied(mut slot) => {
|
||||||
);
|
let slot_mut = slot.get_mut();
|
||||||
|
for experimental_feature in experimental_features {
|
||||||
|
if !slot_mut.contains(experimental_feature) {
|
||||||
|
*slot_mut += " ";
|
||||||
|
*slot_mut += experimental_feature;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
Entry::Vacant(slot) => {
|
||||||
|
let _ = slot.insert(experimental_features.join(" ").to_string());
|
||||||
|
},
|
||||||
|
};
|
||||||
settings.insert("auto-optimise-store".to_string(), "true".to_string());
|
settings.insert("auto-optimise-store".to_string(), "true".to_string());
|
||||||
settings.insert(
|
settings.insert(
|
||||||
"bash-prompt-prefix".to_string(),
|
"bash-prompt-prefix".to_string(),
|
||||||
|
|
|
@ -140,7 +140,7 @@ pub struct CommonSettings {
|
||||||
pub ssl_cert_file: Option<PathBuf>,
|
pub ssl_cert_file: Option<PathBuf>,
|
||||||
|
|
||||||
/// Extra configuration lines for `/etc/nix.conf`
|
/// Extra configuration lines for `/etc/nix.conf`
|
||||||
#[cfg_attr(feature = "cli", clap(long, action = ArgAction::Set, num_args = 0.., value_delimiter = ',', env = "NIX_INSTALLER_EXTRA_CONF", global = true))]
|
#[cfg_attr(feature = "cli", clap(long, action = ArgAction::Append, num_args = 0.., env = "NIX_INSTALLER_EXTRA_CONF", global = true))]
|
||||||
pub extra_conf: Vec<String>,
|
pub extra_conf: Vec<String>,
|
||||||
|
|
||||||
/// If `nix-installer` should forcibly recreate files it finds existing
|
/// If `nix-installer` should forcibly recreate files it finds existing
|
||||||
|
|
Loading…
Reference in a new issue