From 017259ee3413f60b34ac7e7933aba48af6a21aaa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Denys=20S=C3=A9guret?= Date: Sun, 6 Oct 2024 17:14:12 +0200 Subject: [PATCH] `BACON_PREFS` and `BACON_CONFIG` env vars (#230) Bacon loads its default configuration then, in order: * the global `prefs.toml` * the file whose path is in environment variable `BACON_PREFS` * the workspace level `bacon.toml` file * the package level `bacon.toml` file * the file whose path is in environment variable `BACON_CONFIG` Fix #76 --- CHANGELOG.md | 1 + src/cli.rs | 8 ++++++++ src/config.rs | 23 ++++++++++++++++++++++- website/docs/config.md | 17 ++++++++++++----- 4 files changed, 43 insertions(+), 6 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 9c3f59e..8e7ff3b 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -5,6 +5,7 @@ - recognize panic location in test - Fix #208 - lines to ignore can be specified as a set of regular expressions in a `ignored_lines` field either in the job or at the top of the prefs or bacon.toml - Fix #223 - `toggle-backtrace` accepts an optional level: `toggle-backtrace(1)` or `toggle-backtrace(full)` - Experimental - Fix #210 +- configuration can be passed in `BACON_PREFS` and `BACON_CONFIG` env vars - Fix #76 ### v2.21.0 - 2024/09/14 diff --git a/src/cli.rs b/src/cli.rs index e2b5f4d..483ad9e 100644 --- a/src/cli.rs +++ b/src/cli.rs @@ -73,6 +73,10 @@ pub fn run() -> anyhow::Result<()> { } } + if let Some(config) = Config::from_env("BACON_PREFS")? { + settings.apply_config(&config); + } + let location = MissionLocation::new(&args)?; info!("mission location: {:#?}", &location); @@ -102,6 +106,10 @@ pub fn run() -> anyhow::Result<()> { settings.apply_config(&config); } + if let Some(config) = Config::from_env("BACON_CONFIG")? { + settings.apply_config(&config); + } + // args are applied after prefs, and package config so that they can override them settings.apply_args(&args); diff --git a/src/config.rs b/src/config.rs index b00dfaa..e5f46e3 100644 --- a/src/config.rs +++ b/src/config.rs @@ -10,7 +10,7 @@ use { }, }; -/// A configuration item which may be stored either as `bacon.toml` +/// A configuration item which may be stored in various places, eg as `bacon.toml` /// along a `Cargo.toml` file or as `prefs.toml` in the xdg config directory. /// /// Leaf values are options (and not Default) so that they don't @@ -70,6 +70,27 @@ impl Config { } Ok(conf) } + pub fn from_env(env_var_name: &str) -> Result> { + let Some(path) = std::env::var_os(env_var_name) else { + return Ok(None); + }; + let path = Path::new(&path); + if !path.exists() { + // some users may want to use an env var to point to a file that may not always exist + // so we don't bail here + warn!( + "Env var {:?} points to file {:?} which does not exist", + env_var_name, path + ); + return Ok(None); + } + let config = Self::from_path(path)?; + debug!( + "Loaded config at {:?} as specified in env var {:?}", + path, env_var_name + ); + Ok(Some(config)) + } pub fn default_package_config() -> Self { toml::from_str(DEFAULT_PACKAGE_CONFIG).unwrap() } diff --git a/website/docs/config.md b/website/docs/config.md index 2d5327a..02f008b 100644 --- a/website/docs/config.md +++ b/website/docs/config.md @@ -1,14 +1,21 @@ # Configuration Files -The behavior of bacon is defined by a global `prefs.toml` file and project specific `bacon.toml` files. - -All configuration files are optional but you'll soon need specific jobs for your targets, examples, etc. +All configuration files are optional but you'll probably need specific jobs for your targets, examples, etc. All accept the same properties (preferences, keybindings, jobs, etc.). -The properties of the global `prefs.toml` file are overriden by the workspace level `bacon.toml` file, then by the package level `bacon.toml` file. -When you modified those files and bacon evolved since, you may want to have a look at the current default ones and pick the changes you like: +Bacon loads its default configuration then, in order: + +* the global `prefs.toml` ([global preferences](#global-preferences)) +* the file whose path is in environment variable `BACON_PREFS` +* the workspace level `bacon.toml` file +* the package level `bacon.toml` file ([project settings](#project-settings)) +* the file whose path is in environment variable `BACON_CONFIG` + +Each configuration file overrides the properties of previously loaded ones. + +When you modified those files and bacon evolved since, you may want to have a look at the current default ones: * [Current default prefs.toml](https://raw.githubusercontent.com/Canop/bacon/main/defaults/default-prefs.toml) * [Current default bacon.toml](https://raw.githubusercontent.com/Canop/bacon/main/defaults/default-bacon.toml)