aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristian Duerr <contact@christianduerr.com>2023-08-07 23:14:53 +0200
committerGitHub <noreply@github.com>2023-08-08 01:14:53 +0400
commitbbe317438192ee695c86b904ff6e1f3843eb94c2 (patch)
tree052c2b8c61bd442209e751006e15b4f2eb94409b
parent35e1bb128b6c6835649e4e669fca9e26267b2d1d (diff)
downloadalacritty-bbe317438192ee695c86b904ff6e1f3843eb94c2.tar.gz
alacritty-bbe317438192ee695c86b904ff6e1f3843eb94c2.zip
Copy global IPC options for new windows
This patch stores all options set for the Window ID `-1` and automatically applies them to new windows after their creation. This in theory makes it possible to have a fully dynamic "default config" without having to reapply it for every new window. Closes #7128.
-rw-r--r--CHANGELOG.md1
-rw-r--r--alacritty/src/event.rs27
2 files changed, 26 insertions, 2 deletions
diff --git a/CHANGELOG.md b/CHANGELOG.md
index 927ca0d3..5d66beeb 100644
--- a/CHANGELOG.md
+++ b/CHANGELOG.md
@@ -19,6 +19,7 @@ The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/).
- Support for dynamically loading conpty.dll on Windows
- Support for keybindings with dead keys
- `Back`/`Forward` mouse buttons support in bindings
+- Copy global IPC options (`-w -1`) for new windows
### Changed
diff --git a/alacritty/src/event.rs b/alacritty/src/event.rs
index 0ffc46a0..add30722 100644
--- a/alacritty/src/event.rs
+++ b/alacritty/src/event.rs
@@ -1403,6 +1403,8 @@ pub struct Processor {
#[cfg(all(feature = "wayland", not(any(target_os = "macos", windows))))]
wayland_event_queue: Option<EventQueue>,
windows: HashMap<WindowId, WindowContext, RandomState>,
+ #[cfg(unix)]
+ global_ipc_options: Vec<String>,
cli_options: CliOptions,
config: Rc<UiConfig>,
}
@@ -1424,11 +1426,13 @@ impl Processor {
});
Processor {
- windows: Default::default(),
config: Rc::new(config),
cli_options,
#[cfg(all(feature = "wayland", not(any(target_os = "macos", windows))))]
wayland_event_queue,
+ #[cfg(unix)]
+ global_ipc_options: Default::default(),
+ windows: Default::default(),
}
}
@@ -1464,7 +1468,9 @@ impl Processor {
options: WindowOptions,
) -> Result<(), Box<dyn Error>> {
let window = self.windows.iter().next().as_ref().unwrap().1;
- let window_context = window.additional(
+
+ #[allow(unused_mut)]
+ let mut window_context = window.additional(
event_loop,
proxy,
self.config.clone(),
@@ -1473,6 +1479,14 @@ impl Processor {
self.wayland_event_queue.as_ref(),
)?;
+ // Apply global IPC options.
+ #[cfg(unix)]
+ {
+ let options = self.global_ipc_options.clone();
+ let ipc_config = IpcConfig { options, window_id: None, reset: false };
+ window_context.update_ipc_config(self.config.clone(), ipc_config);
+ }
+
self.windows.insert(window_context.id(), window_context);
Ok(())
}
@@ -1609,6 +1623,15 @@ impl Processor {
payload: EventType::IpcConfig(ipc_config),
window_id,
}) => {
+ // Persist global options for future windows.
+ if window_id.is_none() {
+ if ipc_config.reset {
+ self.global_ipc_options.clear();
+ } else {
+ self.global_ipc_options.extend_from_slice(&ipc_config.options);
+ }
+ }
+
for (_, window_context) in self
.windows
.iter_mut()