mirror of
https://github.com/gitui-org/gitui
synced 2026-05-24 09:28:21 +00:00
168 lines
3.5 KiB
Rust
168 lines
3.5 KiB
Rust
use crate::bug_report;
|
|
use anyhow::{anyhow, Result};
|
|
use asyncgit::sync::RepoPath;
|
|
use clap::{
|
|
crate_authors, crate_description, crate_name, crate_version, Arg,
|
|
Command as ClapApp,
|
|
};
|
|
use simplelog::{Config, LevelFilter, WriteLogger};
|
|
use std::{
|
|
env,
|
|
fs::{self, File},
|
|
path::PathBuf,
|
|
};
|
|
|
|
pub struct CliArgs {
|
|
pub theme: PathBuf,
|
|
pub repo_path: RepoPath,
|
|
pub notify_watcher: bool,
|
|
}
|
|
|
|
pub fn process_cmdline() -> Result<CliArgs> {
|
|
let app = app();
|
|
|
|
let arg_matches = app.get_matches();
|
|
|
|
if arg_matches.get_flag("bugreport") {
|
|
bug_report::generate_bugreport();
|
|
std::process::exit(0);
|
|
}
|
|
if arg_matches.get_flag("logging") {
|
|
setup_logging()?;
|
|
}
|
|
|
|
let workdir =
|
|
arg_matches.get_one::<String>("workdir").map(PathBuf::from);
|
|
let gitdir = arg_matches
|
|
.get_one::<String>("directory")
|
|
.map_or_else(|| PathBuf::from("."), PathBuf::from);
|
|
|
|
#[allow(clippy::option_if_let_else)]
|
|
let repo_path = if let Some(w) = workdir {
|
|
RepoPath::Workdir { gitdir, workdir: w }
|
|
} else {
|
|
RepoPath::Path(gitdir)
|
|
};
|
|
|
|
let arg_theme = arg_matches
|
|
.get_one::<String>("theme")
|
|
.map_or_else(|| PathBuf::from("theme.ron"), PathBuf::from);
|
|
|
|
let theme = if get_app_config_path()?.join(&arg_theme).is_file() {
|
|
get_app_config_path()?.join(arg_theme)
|
|
} else {
|
|
get_app_config_path()?.join("theme.ron")
|
|
};
|
|
|
|
let notify_watcher: bool =
|
|
*arg_matches.get_one("watcher").unwrap_or(&false);
|
|
|
|
Ok(CliArgs {
|
|
theme,
|
|
repo_path,
|
|
notify_watcher,
|
|
})
|
|
}
|
|
|
|
fn app() -> ClapApp {
|
|
ClapApp::new(crate_name!())
|
|
.author(crate_authors!())
|
|
.version(crate_version!())
|
|
.about(crate_description!())
|
|
.help_template(
|
|
"\
|
|
{before-help}gitui {version}
|
|
{author}
|
|
{about}
|
|
|
|
{usage-heading} {usage}
|
|
|
|
{all-args}{after-help}
|
|
",
|
|
)
|
|
.arg(
|
|
Arg::new("theme")
|
|
.help("Set the color theme (defaults to theme.ron)")
|
|
.short('t')
|
|
.long("theme")
|
|
.value_name("THEME")
|
|
.num_args(1),
|
|
)
|
|
.arg(
|
|
Arg::new("logging")
|
|
.help("Stores logging output into a cache directory")
|
|
.short('l')
|
|
.long("logging")
|
|
.num_args(0),
|
|
)
|
|
.arg(
|
|
Arg::new("watcher")
|
|
.help("Use notify-based file system watcher instead of tick-based update. This is more performant, but can cause issues on some platforms. See https://github.com/extrawurst/gitui/blob/master/FAQ.md#watcher for details.")
|
|
.long("watcher")
|
|
.action(clap::ArgAction::SetTrue),
|
|
)
|
|
.arg(
|
|
Arg::new("bugreport")
|
|
.help("Generate a bug report")
|
|
.long("bugreport")
|
|
.action(clap::ArgAction::SetTrue),
|
|
)
|
|
.arg(
|
|
Arg::new("directory")
|
|
.help("Set the git directory")
|
|
.short('d')
|
|
.long("directory")
|
|
.env("GIT_DIR")
|
|
.num_args(1),
|
|
)
|
|
.arg(
|
|
Arg::new("workdir")
|
|
.help("Set the working directory")
|
|
.short('w')
|
|
.long("workdir")
|
|
.env("GIT_WORK_TREE")
|
|
.num_args(1),
|
|
)
|
|
}
|
|
|
|
fn setup_logging() -> Result<()> {
|
|
let mut path = get_app_cache_path()?;
|
|
path.push("gitui.log");
|
|
|
|
println!("Logging enabled. log written to: {path:?}");
|
|
|
|
WriteLogger::init(
|
|
LevelFilter::Trace,
|
|
Config::default(),
|
|
File::create(path)?,
|
|
)?;
|
|
|
|
Ok(())
|
|
}
|
|
|
|
fn get_app_cache_path() -> Result<PathBuf> {
|
|
let mut path = dirs::cache_dir()
|
|
.ok_or_else(|| anyhow!("failed to find os cache dir."))?;
|
|
|
|
path.push("gitui");
|
|
fs::create_dir_all(&path)?;
|
|
Ok(path)
|
|
}
|
|
|
|
pub fn get_app_config_path() -> Result<PathBuf> {
|
|
let mut path = if cfg!(target_os = "macos") {
|
|
dirs::home_dir().map(|h| h.join(".config"))
|
|
} else {
|
|
dirs::config_dir()
|
|
}
|
|
.ok_or_else(|| anyhow!("failed to find os config dir."))?;
|
|
|
|
path.push("gitui");
|
|
fs::create_dir_all(&path)?;
|
|
Ok(path)
|
|
}
|
|
|
|
#[test]
|
|
fn verify_app() {
|
|
app().debug_assert();
|
|
}
|