From 196d68c7c9f315c1ec3934d2f1c66823f57c7aec Mon Sep 17 00:00:00 2001 From: Dillard Robertson Date: Sun, 13 Aug 2023 13:48:35 -0400 Subject: [PATCH] Stop Terminal::drop from overriding work of Terminal::restore. When Application::run is exiting, either Terminal::restore or Terminal::force_restore will be called depending on if a panic occured or not. Both of these functions will reset the cursor to terminal's default. After this is done, Terminal::drop will be called. If terminal.cursor_kind == Hidden, then the cursor will be reset to a CursorKind::Block, undoing the work of restore or force_restore. This commit just removes the drop implementation, as its job is already better handled in restore and force_restore. --- helix-tui/src/terminal.rs | 14 -------------- 1 file changed, 14 deletions(-) diff --git a/helix-tui/src/terminal.rs b/helix-tui/src/terminal.rs index 8b7342751168..d2a911cf5d70 100644 --- a/helix-tui/src/terminal.rs +++ b/helix-tui/src/terminal.rs @@ -65,20 +65,6 @@ where viewport: Viewport, } -impl Drop for Terminal -where - B: Backend, -{ - fn drop(&mut self) { - // Attempt to restore the cursor state - if self.cursor_kind == CursorKind::Hidden { - if let Err(err) = self.show_cursor(CursorKind::Block) { - eprintln!("Failed to show the cursor: {}", err); - } - } - } -} - impl Terminal where B: Backend,