summaryrefslogtreecommitdiff
path: root/alacritty_terminal
diff options
context:
space:
mode:
Diffstat (limited to 'alacritty_terminal')
-rw-r--r--alacritty_terminal/src/input.rs1
-rw-r--r--alacritty_terminal/src/tty/unix.rs23
-rw-r--r--alacritty_terminal/src/util.rs46
3 files changed, 33 insertions, 37 deletions
diff --git a/alacritty_terminal/src/input.rs b/alacritty_terminal/src/input.rs
index 92e08af5..9443a1a9 100644
--- a/alacritty_terminal/src/input.rs
+++ b/alacritty_terminal/src/input.rs
@@ -1074,6 +1074,7 @@ mod tests {
assert!(!subset_mods.triggers_match(&superset_mods));
}
+ #[test]
fn binding_trigger_input() {
let mut binding = MockBinding::default();
binding.trigger = 13;
diff --git a/alacritty_terminal/src/tty/unix.rs b/alacritty_terminal/src/tty/unix.rs
index cafa7027..f4c5771f 100644
--- a/alacritty_terminal/src/tty/unix.rs
+++ b/alacritty_terminal/src/tty/unix.rs
@@ -194,35 +194,30 @@ pub fn new<T: ToWinsize>(config: &Config, size: &T, window_id: Option<usize>) ->
builder.env("WINDOWID", format!("{}", window_id));
}
- // TODO: Rust 1.34.0
- #[allow(deprecated)]
- builder.before_exec(move || {
- // Create a new process group
- unsafe {
+ unsafe {
+ builder.pre_exec(move || {
+ // Create a new process group
let err = libc::setsid();
if err == -1 {
die!("Failed to set session id: {}", errno());
}
- }
- set_controlling_terminal(slave);
+ set_controlling_terminal(slave);
- // No longer need slave/master fds
- unsafe {
+ // No longer need slave/master fds
libc::close(slave);
libc::close(master);
- }
- unsafe {
libc::signal(libc::SIGCHLD, libc::SIG_DFL);
libc::signal(libc::SIGHUP, libc::SIG_DFL);
libc::signal(libc::SIGINT, libc::SIG_DFL);
libc::signal(libc::SIGQUIT, libc::SIG_DFL);
libc::signal(libc::SIGTERM, libc::SIG_DFL);
libc::signal(libc::SIGALRM, libc::SIG_DFL);
- }
- Ok(())
- });
+
+ Ok(())
+ });
+ }
// Handle set working directory option
if let Some(ref dir) = config.working_directory() {
diff --git a/alacritty_terminal/src/util.rs b/alacritty_terminal/src/util.rs
index 45b17353..7bc7c08b 100644
--- a/alacritty_terminal/src/util.rs
+++ b/alacritty_terminal/src/util.rs
@@ -87,29 +87,29 @@ where
I: IntoIterator<Item = S>,
S: AsRef<OsStr>,
{
- // TODO: Rust 1.34.0
- #[allow(deprecated)]
- Command::new(program)
- .args(args)
- .stdin(Stdio::null())
- .stdout(Stdio::null())
- .stderr(Stdio::null())
- .before_exec(|| unsafe {
- match ::libc::fork() {
- -1 => return Err(io::Error::last_os_error()),
- 0 => (),
- _ => ::libc::_exit(0),
- }
-
- if ::libc::setsid() == -1 {
- return Err(io::Error::last_os_error());
- }
-
- Ok(())
- })
- .spawn()?
- .wait()
- .map(|_| ())
+ unsafe {
+ Command::new(program)
+ .args(args)
+ .stdin(Stdio::null())
+ .stdout(Stdio::null())
+ .stderr(Stdio::null())
+ .pre_exec(|| {
+ match ::libc::fork() {
+ -1 => return Err(io::Error::last_os_error()),
+ 0 => (),
+ _ => ::libc::_exit(0),
+ }
+
+ if ::libc::setsid() == -1 {
+ return Err(io::Error::last_os_error());
+ }
+
+ Ok(())
+ })
+ .spawn()?
+ .wait()
+ .map(|_| ())
+ }
}
#[cfg(windows)]