|
|
@ -1,6 +1,6 @@
|
|
|
|
use crate::{dimensions::Dimensions, frame::Frame, settings::*};
|
|
|
|
use crate::{dimensions::Dimensions, frame::Frame, settings::*};
|
|
|
|
|
|
|
|
|
|
|
|
use clap::{App, Arg};
|
|
|
|
use clap::{Arg, Command};
|
|
|
|
|
|
|
|
|
|
|
|
#[derive(Clone, Debug)]
|
|
|
|
#[derive(Clone, Debug)]
|
|
|
|
pub struct CmdLineSettings {
|
|
|
|
pub struct CmdLineSettings {
|
|
|
@ -54,99 +54,99 @@ impl Default for CmdLineSettings {
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
pub fn handle_command_line_arguments(args: Vec<String>) -> Result<(), String> {
|
|
|
|
pub fn handle_command_line_arguments(args: Vec<String>) -> Result<(), String> {
|
|
|
|
let clapp = App::new("Neovide")
|
|
|
|
let clapp = Command::new("Neovide")
|
|
|
|
.version(crate_version!())
|
|
|
|
.version(crate_version!())
|
|
|
|
.author(crate_authors!())
|
|
|
|
.author(crate_authors!())
|
|
|
|
.about(crate_description!())
|
|
|
|
.about(crate_description!())
|
|
|
|
// Pass through arguments
|
|
|
|
// Pass through arguments
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("files_to_open")
|
|
|
|
Arg::new("files_to_open")
|
|
|
|
.multiple(true)
|
|
|
|
.multiple_values(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Files to open"),
|
|
|
|
.help("Files to open"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("neovim_args")
|
|
|
|
Arg::new("neovim_args")
|
|
|
|
.multiple(true)
|
|
|
|
.multiple_values(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.last(true)
|
|
|
|
.last(true)
|
|
|
|
.help("Specify Arguments to pass down to neovim"),
|
|
|
|
.help("Specify Arguments to pass down to neovim"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
// Command-line arguments only
|
|
|
|
// Command-line arguments only
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("geometry")
|
|
|
|
Arg::new("geometry")
|
|
|
|
.long("geometry")
|
|
|
|
.long("geometry")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Specify the Geometry of the window"),
|
|
|
|
.help("Specify the Geometry of the window"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("log_to_file")
|
|
|
|
Arg::new("log_to_file")
|
|
|
|
.long("log")
|
|
|
|
.long("log")
|
|
|
|
.help("Log to a file"),
|
|
|
|
.help("Log to a file"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("nofork")
|
|
|
|
Arg::new("nofork")
|
|
|
|
.long("nofork")
|
|
|
|
.long("nofork")
|
|
|
|
.help("Do not detach process from terminal"),
|
|
|
|
.help("Do not detach process from terminal"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("no_tabs")
|
|
|
|
Arg::new("no_tabs")
|
|
|
|
.long("notabs")
|
|
|
|
.long("notabs")
|
|
|
|
.help("Disable open multiple files as tabs"),
|
|
|
|
.help("Disable open multiple files as tabs"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("remote_tcp")
|
|
|
|
Arg::new("remote_tcp")
|
|
|
|
.long("remote-tcp")
|
|
|
|
.long("remote-tcp")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Connect to Remote TCP"),
|
|
|
|
.help("Connect to Remote TCP"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("wsl")
|
|
|
|
Arg::new("wsl")
|
|
|
|
.long("wsl")
|
|
|
|
.long("wsl")
|
|
|
|
.help("Run in WSL")
|
|
|
|
.help("Run in WSL")
|
|
|
|
)
|
|
|
|
)
|
|
|
|
// Command-line flags with environment variable fallback
|
|
|
|
// Command-line flags with environment variable fallback
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("frame")
|
|
|
|
Arg::new("frame")
|
|
|
|
.long("frame")
|
|
|
|
.long("frame")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Configure the window frame. NOTE: Window might not be resizable if setting is None.")
|
|
|
|
.help("Configure the window frame. NOTE: Window might not be resizable if setting is None.")
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("maximized")
|
|
|
|
Arg::new("maximized")
|
|
|
|
.long("maximized")
|
|
|
|
.long("maximized")
|
|
|
|
.help("Maximize the window"),
|
|
|
|
.help("Maximize the window"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("multi_grid")
|
|
|
|
Arg::new("multi_grid")
|
|
|
|
.long("multigrid")
|
|
|
|
.long("multigrid")
|
|
|
|
.help("Enable Multigrid"),
|
|
|
|
.help("Enable Multigrid"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("noidle")
|
|
|
|
Arg::new("noidle")
|
|
|
|
.long("noidle")
|
|
|
|
.long("noidle")
|
|
|
|
.help("Render every frame. Takes more power and cpu time but possibly fixes animation issues"),
|
|
|
|
.help("Render every frame. Takes more power and cpu time but possibly fixes animation issues"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("nosrgb")
|
|
|
|
Arg::new("nosrgb")
|
|
|
|
.long("nosrgb")
|
|
|
|
.long("nosrgb")
|
|
|
|
.help("Do not use standard color space to initialize the window. Swapping this variable sometimes fixes issues on startup"),
|
|
|
|
.help("Do not use standard color space to initialize the window. Swapping this variable sometimes fixes issues on startup"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
// Command-line arguments with environment variable fallback
|
|
|
|
// Command-line arguments with environment variable fallback
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("neovim_bin")
|
|
|
|
Arg::new("neovim_bin")
|
|
|
|
.long("neovim-bin")
|
|
|
|
.long("neovim-bin")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Specify path to neovim"),
|
|
|
|
.help("Specify path to neovim"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("wayland_app_id")
|
|
|
|
Arg::new("wayland_app_id")
|
|
|
|
.long("wayland-app-id")
|
|
|
|
.long("wayland-app-id")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Specify an App ID for Wayland"),
|
|
|
|
.help("Specify an App ID for Wayland"),
|
|
|
|
)
|
|
|
|
)
|
|
|
|
.arg(
|
|
|
|
.arg(
|
|
|
|
Arg::with_name("x11_wm_class")
|
|
|
|
Arg::new("x11_wm_class")
|
|
|
|
.long("x11-wm-class")
|
|
|
|
.long("x11-wm-class")
|
|
|
|
.takes_value(true)
|
|
|
|
.takes_value(true)
|
|
|
|
.help("Specify an X11 WM class"),
|
|
|
|
.help("Specify an X11 WM class"),
|
|
|
@ -329,7 +329,7 @@ mod tests {
|
|
|
|
|
|
|
|
|
|
|
|
let _accessing_settings = ACCESSING_SETTINGS.lock().unwrap();
|
|
|
|
let _accessing_settings = ACCESSING_SETTINGS.lock().unwrap();
|
|
|
|
handle_command_line_arguments(args).expect("Could not parse arguments");
|
|
|
|
handle_command_line_arguments(args).expect("Could not parse arguments");
|
|
|
|
assert_eq!(SETTINGS.get::<CmdLineSettings>().log_to_file, true);
|
|
|
|
assert!(SETTINGS.get::<CmdLineSettings>().log_to_file);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
#[test]
|
|
|
|