Deprecated configuration variables
This commit is contained in:
@@ -1,12 +1,3 @@
|
||||
# Additional git repositories to pull
|
||||
#git_repos = [
|
||||
# "~/src/*/",
|
||||
# "~/.config/something"
|
||||
#]
|
||||
|
||||
# Don't pull the predefined git repos
|
||||
# predefined_git_repos = false
|
||||
|
||||
# Disable specific steps - same options as the command line flag
|
||||
#disable = ["system", "emacs"]
|
||||
|
||||
@@ -25,21 +16,29 @@
|
||||
# Arguments to pass SSH when upgrading remote systems
|
||||
#ssh_arguments = "-o ConnectTimeout=2"
|
||||
|
||||
# Arguments to pass Git when pulling Repositories
|
||||
#git_arguments = "--rebase --autostash"
|
||||
|
||||
# Arguments to pass tmux when pulling Repositories
|
||||
#tmux_arguments = "-S /var/tmux.sock"
|
||||
|
||||
# Manually select Windows updates
|
||||
# accept_all_windows_updates = false
|
||||
|
||||
# Do not set the terminal title
|
||||
#set_title = false
|
||||
|
||||
# Cleanup temporary or old files
|
||||
#cleanup = true
|
||||
|
||||
#[git]
|
||||
#max_concurrency = 5
|
||||
# Additional git repositories to pull
|
||||
#repos = [
|
||||
# "~/src/*/",
|
||||
# "~/.config/something"
|
||||
#]
|
||||
|
||||
# Don't pull the predefined git repos
|
||||
# predefined_repos = false
|
||||
|
||||
# Arguments to pass Git when pulling Repositories
|
||||
#arguments = "--rebase --autostash"
|
||||
|
||||
#[composer]
|
||||
#self_update = true
|
||||
|
||||
@@ -60,5 +59,7 @@
|
||||
#trizen_arguments = "--devel"
|
||||
#enable_tlmgr = true
|
||||
|
||||
#[git]
|
||||
#max_concurrency = 5
|
||||
#[windows]
|
||||
# Manually select Windows updates
|
||||
# accept_all_updates = false
|
||||
|
||||
|
||||
@@ -1,5 +1,4 @@
|
||||
use super::utils::editor;
|
||||
use crate::terminal::print_warning;
|
||||
use anyhow::Result;
|
||||
use directories::BaseDirs;
|
||||
use log::{debug, LevelFilter};
|
||||
@@ -13,6 +12,35 @@ use std::{env, fs};
|
||||
use structopt::StructOpt;
|
||||
use strum::{EnumIter, EnumString, EnumVariantNames, IntoEnumIterator, VariantNames};
|
||||
|
||||
macro_rules! check_deprecated {
|
||||
($config:expr, $old:ident, $section:ident, $new:ident) => {
|
||||
if $config.$old.is_some() {
|
||||
println!(concat!(
|
||||
"'",
|
||||
stringify!($old),
|
||||
"' configuration option is deprecated. Rename it to '",
|
||||
stringify!($new),
|
||||
"' and put it under the section [",
|
||||
stringify!($section),
|
||||
"]",
|
||||
));
|
||||
}
|
||||
};
|
||||
}
|
||||
macro_rules! get_deprecated {
|
||||
($config:expr, $old:ident, $section:ident, $new:ident) => {
|
||||
if $config.$old.is_some() {
|
||||
&$config.$old
|
||||
} else {
|
||||
if let Some(section) = &$config.$section {
|
||||
§ion.$new
|
||||
} else {
|
||||
&None
|
||||
}
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
type Commands = BTreeMap<String, String>;
|
||||
|
||||
#[derive(EnumString, EnumVariantNames, Debug, Clone, PartialEq, Deserialize, EnumIter)]
|
||||
@@ -53,6 +81,14 @@ pub enum Step {
|
||||
#[derive(Deserialize, Default, Debug)]
|
||||
pub struct Git {
|
||||
max_concurrency: Option<usize>,
|
||||
arguments: Option<String>,
|
||||
repos: Option<Vec<String>>,
|
||||
pull_predefined: Option<bool>,
|
||||
}
|
||||
|
||||
#[derive(Deserialize, Default, Debug)]
|
||||
pub struct Windows {
|
||||
accept_all_updates: Option<bool>,
|
||||
}
|
||||
|
||||
#[derive(Deserialize, Default, Debug)]
|
||||
@@ -99,6 +135,7 @@ pub struct ConfigFile {
|
||||
brew: Option<Brew>,
|
||||
linux: Option<Linux>,
|
||||
git: Option<Git>,
|
||||
windows: Option<Windows>,
|
||||
}
|
||||
|
||||
impl ConfigFile {
|
||||
@@ -270,6 +307,12 @@ impl Config {
|
||||
ConfigFile::default()
|
||||
});
|
||||
|
||||
check_deprecated!(config_file, git_arguments, git, arguments);
|
||||
check_deprecated!(config_file, git_repos, git, repos);
|
||||
check_deprecated!(config_file, predefined_git_repos, git, pull_predefined);
|
||||
check_deprecated!(config_file, yay_arguments, linux, yay_arguments);
|
||||
check_deprecated!(config_file, accept_all_windows_updates, windows, accept_all_updates);
|
||||
|
||||
let allowed_steps = Self::allowed_steps(&opt, &config_file);
|
||||
|
||||
Ok(Self {
|
||||
@@ -296,7 +339,7 @@ impl Config {
|
||||
|
||||
/// The list of additional git repositories to pull.
|
||||
pub fn git_repos(&self) -> &Option<Vec<String>> {
|
||||
&self.config_file.git_repos
|
||||
get_deprecated!(&self.config_file, git_repos, git, repos)
|
||||
}
|
||||
|
||||
/// Tell whether the specified step should run.
|
||||
@@ -359,7 +402,7 @@ impl Config {
|
||||
|
||||
/// Extra Git arguments
|
||||
pub fn git_arguments(&self) -> &Option<String> {
|
||||
&self.config_file.git_arguments
|
||||
get_deprecated!(&self.config_file, git_arguments, git, arguments)
|
||||
}
|
||||
|
||||
/// Extra Tmux arguments
|
||||
@@ -387,7 +430,13 @@ impl Config {
|
||||
/// Whether to accept all Windows updates
|
||||
#[allow(dead_code)]
|
||||
pub fn accept_all_windows_updates(&self) -> bool {
|
||||
self.config_file.accept_all_windows_updates.unwrap_or(true)
|
||||
get_deprecated!(
|
||||
self.config_file,
|
||||
accept_all_windows_updates,
|
||||
windows,
|
||||
accept_all_updates
|
||||
)
|
||||
.unwrap_or(true)
|
||||
}
|
||||
|
||||
/// Whether Brew cask should be greedy
|
||||
@@ -429,11 +478,8 @@ impl Config {
|
||||
/// Extra yay arguments
|
||||
#[allow(dead_code)]
|
||||
pub fn yay_arguments(&self) -> &str {
|
||||
&self.config_file.yay_arguments.as_deref().map(|p| {
|
||||
print_warning("Putting --yay-arguments in the top section is deprecated and will be removed in the future. Please move it to the [linux] section");
|
||||
p
|
||||
})
|
||||
.or_else(|| self.config_file.linux.as_ref().and_then(|s| s.yay_arguments.as_deref()))
|
||||
get_deprecated!(self.config_file, yay_arguments, linux, yay_arguments)
|
||||
.as_deref()
|
||||
.unwrap_or("--devel")
|
||||
}
|
||||
|
||||
@@ -462,6 +508,7 @@ impl Config {
|
||||
}
|
||||
|
||||
pub fn use_predefined_git_repos(&self) -> bool {
|
||||
!self.opt.disable_predefined_git_repos && self.config_file.predefined_git_repos.unwrap_or(true)
|
||||
!self.opt.disable_predefined_git_repos
|
||||
&& get_deprecated!(&self.config_file, predefined_git_repos, git, pull_predefined).unwrap_or(true)
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user