From 165246f50aead3a4311df6304830a6e24ef522c8 Mon Sep 17 00:00:00 2001 From: Christian Duerr Date: Sun, 7 Jul 2019 14:51:11 +0000 Subject: Fix saving of ref tests Since ref tests were only stored whenever winit requested the window close, they would not get stored properly when the terminal was closed through Alacritty using `exit`, Ctrl+D or similar. This moves the ref test code to the and of the main entry point, which will always be executed regardless of how the terminal was shutdown. --- alacritty_terminal/src/event.rs | 41 +---------------------------------------- 1 file changed, 1 insertion(+), 40 deletions(-) (limited to 'alacritty_terminal/src/event.rs') diff --git a/alacritty_terminal/src/event.rs b/alacritty_terminal/src/event.rs index 3c85cee7..bb34d2f2 100644 --- a/alacritty_terminal/src/event.rs +++ b/alacritty_terminal/src/event.rs @@ -3,15 +3,12 @@ use std::borrow::Cow; use std::env; #[cfg(unix)] use std::fs; -use std::fs::File; -use std::io::Write; use std::sync::mpsc; use std::time::Instant; use glutin::dpi::PhysicalSize; use glutin::{self, ElementState, Event, ModifiersState, MouseButton}; use parking_lot::MutexGuard; -use serde_json as json; use crate::clipboard::ClipboardType; use crate::config::{self, Config, StartupMode}; @@ -21,7 +18,6 @@ use crate::index::{Column, Line, Point, Side}; use crate::input::{self, KeyBinding, MouseBinding}; use crate::selection::Selection; use crate::sync::FairMutex; -use crate::term::cell::Cell; use crate::term::{SizeInfo, Term}; #[cfg(unix)] use crate::tty; @@ -286,7 +282,6 @@ pub struct Processor { notifier: N, mouse: Mouse, resize_tx: mpsc::Sender, - ref_test: bool, size_info: SizeInfo, hide_mouse_when_typing: bool, hide_mouse: bool, @@ -330,7 +325,6 @@ impl Processor { wait_for_event: true, notifier, resize_tx, - ref_test: config.debug.ref_test, mouse: Default::default(), size_info, hide_mouse_when_typing: config.mouse.hide_when_typing, @@ -356,7 +350,6 @@ impl Processor { fn handle_event<'a>( processor: &mut input::Processor<'a, ActionContext<'a, N>>, event: Event, - ref_test: bool, resize_tx: &mpsc::Sender, hide_mouse: &mut bool, window_is_focused: &mut bool, @@ -367,37 +360,7 @@ impl Processor { Event::WindowEvent { event, .. } => { use glutin::WindowEvent::*; match event { - CloseRequested => { - if ref_test { - // dump grid state - let mut grid = processor.ctx.terminal.grid().clone(); - grid.initialize_all(&Cell::default()); - grid.truncate(); - - let serialized_grid = json::to_string(&grid).expect("serialize grid"); - - let serialized_size = - json::to_string(processor.ctx.terminal.size_info()) - .expect("serialize size"); - - let serialized_config = - format!("{{\"history_size\":{}}}", grid.history_size()); - - File::create("./grid.json") - .and_then(|mut f| f.write_all(serialized_grid.as_bytes())) - .expect("write grid.json"); - - File::create("./size.json") - .and_then(|mut f| f.write_all(serialized_size.as_bytes())) - .expect("write size.json"); - - File::create("./config.json") - .and_then(|mut f| f.write_all(serialized_config.as_bytes())) - .expect("write config.json"); - } - - processor.ctx.terminal.exit(); - }, + CloseRequested => processor.ctx.terminal.exit(), Resized(lsize) => { // Resize events are emitted via glutin/winit with logical sizes // However the terminal, window and renderer use physical sizes @@ -492,7 +455,6 @@ impl Processor { let print_events = self.print_events; - let ref_test = self.ref_test; let resize_tx = &self.resize_tx; if self.wait_for_event { @@ -542,7 +504,6 @@ impl Processor { Processor::handle_event( &mut processor, event, - ref_test, resize_tx, hide_mouse, &mut window_is_focused, -- cgit v1.2.3-54-g00ecf