add --show-config-path argument

This commit is contained in:
alice pellerin
2026-04-13 11:29:09 -05:00
parent 3e24d00af4
commit 00bf25b5bd
3 changed files with 28 additions and 5 deletions
+4
View File
@@ -11,4 +11,8 @@ pub struct Arguments {
/// the input files to edit
#[arg(value_name = "files")]
pub files: Vec<PathBuf>,
/// print the path to the config file
#[arg(short, long)]
pub show_config_path: bool,
}
+7 -4
View File
@@ -34,7 +34,7 @@ pub struct Keypress {
impl Config {
#[cfg(unix)]
fn path() -> Option<PathBuf> {
fn default_path() -> Option<PathBuf> {
env::var_os("XDG_CONFIG_HOME")
.map(PathBuf::from)
.take_if(|xdg_config_home| xdg_config_home.is_absolute())
@@ -43,14 +43,17 @@ impl Config {
}
#[cfg(windows)]
fn path() -> Option<PathBuf> {
fn default_path() -> Option<PathBuf> {
// this isn't technically the right way but it should be good enough
home_dir().map(|home| home.join("AppData").join("Roaming"))
}
pub fn path(override_path: Option<PathBuf>) -> Option<PathBuf> {
override_path.or_else(Self::default_path)
}
pub fn init(override_path: Option<PathBuf>) -> Result<Self, ConfigInitError> {
let path = override_path
.or_else(Self::path)
let path = Self::path(override_path)
.ok_or(ConfigInitError::NoConfigPath)?;
let raw_config = read_to_string(path)?;
+17 -1
View File
@@ -11,6 +11,8 @@ use clap::Parser;
use app::App;
use crossterm::{QueueableCommand, event::{DisableMouseCapture, EnableMouseCapture}};
use crate::config::Config;
mod app;
mod buffer;
mod popup;
@@ -33,12 +35,12 @@ const LINES_OF_PADDING: usize = 5;
const BYTES_OF_PADDING: usize = LINES_OF_PADDING * BYTES_PER_LINE;
// TODO:
// - update showcase
// - write docs
// - simonomi.dev/hexapoda?
// - config
// - schema!!
// - uhhhhh?
// - update showcase
// - fix scroll clamping
// - inspector translations for varint
// - search
@@ -71,6 +73,20 @@ const BYTES_OF_PADDING: usize = LINES_OF_PADDING * BYTES_PER_LINE;
fn main() {
let arguments = Arguments::parse();
if arguments.show_config_path {
if let Some(path) = Config::path(arguments.config) {
println!("{}", path.display());
} else {
#[cfg(unix)] {
println!("currently, no config file will be used. define the environment variable XDG_CONFIG_HOME or use the -c/--config option to provide one");
}
#[cfg(windows)] {
println!("currently, no config file will be used. use the -c/--config option to provide one");
}
}
return;
}
let mut app = App::new(
arguments.config,
&arguments.files