You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

163 lines
4.6 KiB

use crate::arch::Arch;
use crate::log_level::LogLevel;
use crate::path_ext::PathExt;
use crate::version_file_strategy::VersionFileStrategy;
use dirs::{data_dir, home_dir};
use url::Url;
#[derive(clap::Parser, Debug)]
pub struct FnmConfig {
/// https://nodejs.org/dist/ mirror
#[clap(
long,
env = "FNM_NODE_DIST_MIRROR",
default_value = "https://nodejs.org/dist",
global = true,
hide_env_values = true
)]
pub node_dist_mirror: Url,
/// The root directory of fnm installations.
#[clap(
long = "fnm-dir",
env = "FNM_DIR",
global = true,
hide_env_values = true
)]
pub base_dir: Option<std::path::PathBuf>,
/// Where the current node version link is stored.
/// This value will be populated automatically by evaluating
/// `fnm env` in your shell profile. Read more about it using `fnm help env`
#[clap(long, env = "FNM_MULTISHELL_PATH", hide_env_values = true, hide = true)]
multishell_path: Option<std::path::PathBuf>,
/// The log level of fnm commands
#[clap(
long,
env = "FNM_LOGLEVEL",
default_value = "info",
global = true,
hide_env_values = true,
possible_values = LogLevel::possible_values()
)]
log_level: LogLevel,
/// Override the architecture of the installed Node binary.
/// Defaults to arch of fnm binary.
#[clap(
long,
env = "FNM_ARCH",
default_value_t,
global = true,
hide_env_values = true,
hide_default_value = true
)]
pub arch: Arch,
/// A strategy for how to resolve the Node version. Used whenever `fnm use` or `fnm install` is
/// called without a version, or when `--use-on-cd` is configured on evaluation.
///
/// * `local`: Use the local version of Node defined within the current directory
///
/// * `recursive`: Use the version of Node defined within the current directory and all parent directories
#[clap(
long,
env = "FNM_VERSION_FILE_STRATEGY",
possible_values = VersionFileStrategy::possible_values(),
default_value = "local",
global = true,
hide_env_values = true,
)]
version_file_strategy: VersionFileStrategy,
/// Enable corepack support for each new installation.
/// This will make fnm call `corepack enable` on every Node.js installation.
/// For more information about corepack see https://nodejs.org/api/corepack.html
#[clap(
long,
env = "FNM_COREPACK_ENABLED",
global = true,
hide_env_values = true
)]
corepack_enabled: bool,
}
impl Default for FnmConfig {
fn default() -> Self {
Self {
node_dist_mirror: Url::parse("https://nodejs.org/dist/").unwrap(),
base_dir: None,
multishell_path: None,
log_level: LogLevel::Info,
arch: Arch::default(),
version_file_strategy: VersionFileStrategy::default(),
corepack_enabled: false,
}
}
}
impl FnmConfig {
pub fn version_file_strategy(&self) -> &VersionFileStrategy {
&self.version_file_strategy
}
pub fn corepack_enabled(&self) -> bool {
self.corepack_enabled
}
pub fn multishell_path(&self) -> Option<&std::path::Path> {
match &self.multishell_path {
None => None,
Some(v) => Some(v.as_path()),
}
}
pub fn log_level(&self) -> &LogLevel {
&self.log_level
}
pub fn base_dir_with_default(&self) -> std::path::PathBuf {
let user_pref = self.base_dir.clone();
if let Some(dir) = user_pref {
return dir;
}
let legacy = home_dir()
.map(|dir| dir.join(".fnm"))
.filter(|dir| dir.exists());
let modern = data_dir().map(|dir| dir.join("fnm"));
if let Some(dir) = legacy {
return dir;
}
modern
.expect("Can't get data directory")
.ensure_exists_silently()
}
pub fn installations_dir(&self) -> std::path::PathBuf {
self.base_dir_with_default()
.join("node-versions")
.ensure_exists_silently()
}
pub fn default_version_dir(&self) -> std::path::PathBuf {
self.aliases_dir().join("default")
}
pub fn aliases_dir(&self) -> std::path::PathBuf {
self.base_dir_with_default()
.join("aliases")
.ensure_exists_silently()
}
#[cfg(test)]
pub fn with_base_dir(mut self, base_dir: Option<std::path::PathBuf>) -> Self {
self.base_dir = base_dir;
self
}
}