diff options
-rw-r--r-- | alacritty.yml | 3 | ||||
-rw-r--r-- | alacritty_macos.yml | 3 | ||||
-rw-r--r-- | src/cli.rs | 15 | ||||
-rw-r--r-- | src/config.rs | 11 | ||||
-rw-r--r-- | src/main.rs | 11 |
5 files changed, 41 insertions, 2 deletions
diff --git a/alacritty.yml b/alacritty.yml index c5e8ba0d..20529a78 100644 --- a/alacritty.yml +++ b/alacritty.yml @@ -278,6 +278,9 @@ selection: hide_cursor_when_typing: false +# Live config reload (changes require restart) +live_config_reload: true + # Shell # # You can set shell.program to the path of your favorite shell, e.g. /bin/fish. diff --git a/alacritty_macos.yml b/alacritty_macos.yml index 6659ea92..cbea7bec 100644 --- a/alacritty_macos.yml +++ b/alacritty_macos.yml @@ -273,6 +273,9 @@ selection: hide_cursor_when_typing: false +# Live config reload (changes require restart) +live_config_reload: true + # Shell # # You can set shell.program to the path of your favorite shell, e.g. /bin/fish. @@ -22,6 +22,7 @@ const DEFAULT_TITLE: &'static str = "Alacritty"; /// Options specified on the command line pub struct Options { + pub live_config_reload: Option<bool>, pub print_events: bool, pub ref_test: bool, pub dimensions: Option<Dimensions>, @@ -35,6 +36,7 @@ pub struct Options { impl Default for Options { fn default() -> Options { Options { + live_config_reload: None, print_events: false, ref_test: false, dimensions: None, @@ -59,6 +61,11 @@ impl Options { .arg(Arg::with_name("ref-test") .long("ref-test") .help("Generates ref test")) + .arg(Arg::with_name("live-config-reload") + .long("live-config-reload") + .help("Live configuration reload") + .takes_value(true) + .use_delimiter(false)) .arg(Arg::with_name("print-events") .long("print-events")) .arg(Arg::with_name("dimensions") @@ -107,6 +114,14 @@ impl Options { options.print_events = true; } + if let Some(val) = matches.value_of("live-config-reload") { + match val { + "y" | "yes" => options.live_config_reload = Some(true), + "n" | "no" => options.live_config_reload = Some(false), + _ => options.live_config_reload = None, + } + } + if let Some(mut dimensions) = matches.values_of("dimensions") { let width = dimensions.next().map(|w| w.parse().map(|w| Column(w))); let height = dimensions.next().map(|h| h.parse().map(|h| Line(h))); diff --git a/src/config.rs b/src/config.rs index 450ab09e..b88723f5 100644 --- a/src/config.rs +++ b/src/config.rs @@ -277,6 +277,10 @@ pub struct Config { /// Hide cursor when typing #[serde(default)] hide_cursor_when_typing: bool, + + /// Live config reload + #[serde(default)] + live_config_reload: bool, } fn default_padding() -> Delta { @@ -329,6 +333,7 @@ impl Default for Config { visual_bell: Default::default(), env: Default::default(), hide_cursor_when_typing: Default::default(), + live_config_reload: Default::default(), padding: default_padding(), } } @@ -1177,6 +1182,12 @@ impl Config { self.hide_cursor_when_typing } + /// Live config reload + #[inline] + pub fn live_config_reload(&self) -> bool { + self.live_config_reload + } + pub fn load_from<P: Into<PathBuf>>(path: P) -> Result<Config> { let path = path.into(); let raw = Config::read_file(path.as_path())?; diff --git a/src/main.rs b/src/main.rs index 472e4144..b8b82914 100644 --- a/src/main.rs +++ b/src/main.rs @@ -148,8 +148,15 @@ fn run(mut config: Config, options: cli::Options) -> Result<(), Box<Error>> { // // The monitor watches the config file for changes and reloads it. Pending // config changes are processed in the main loop. - let config_monitor = config.path() - .map(|path| config::Monitor::new(path, display.notifier())); + let config_monitor = match (options.live_config_reload, config.live_config_reload()) { + // Start monitor if CLI flag says yes + (Some(true), _) | + // Or if no CLI flag was passed and the config says yes + (None, true) => config.path() + .map(|path| config::Monitor::new(path, display.notifier())), + // Otherwise, don't start the monitor + _ => None, + }; // Kick off the I/O thread let io_thread = event_loop.spawn(None); |