summaryrefslogtreecommitdiff
path: root/alacritty_terminal/src/event.rs
diff options
context:
space:
mode:
authorJohn Sullivan <jsullivan@csumb.edu>2019-08-24 16:18:51 -0700
committerChristian Duerr <contact@christianduerr.com>2019-08-24 23:18:50 +0000
commitad0365219f7f264ef0fdf0b3e4401bad7ac40e55 (patch)
treef766474d96708579c1a256e32cb69940184bd29b /alacritty_terminal/src/event.rs
parent629ea247cdccc33c6df0037f357ba9be48c7178d (diff)
downloadalacritty-ad0365219f7f264ef0fdf0b3e4401bad7ac40e55.tar.gz
alacritty-ad0365219f7f264ef0fdf0b3e4401bad7ac40e55.zip
Show text cursor when pressing shift in mouse mode
Fixes #2550.
Diffstat (limited to 'alacritty_terminal/src/event.rs')
-rw-r--r--alacritty_terminal/src/event.rs21
1 files changed, 10 insertions, 11 deletions
diff --git a/alacritty_terminal/src/event.rs b/alacritty_terminal/src/event.rs
index d3daf820..9d2aa78c 100644
--- a/alacritty_terminal/src/event.rs
+++ b/alacritty_terminal/src/event.rs
@@ -7,7 +7,7 @@ use std::sync::mpsc;
use std::time::Instant;
use glutin::dpi::PhysicalSize;
-use glutin::{self, ElementState, Event, ModifiersState, MouseButton};
+use glutin::{self, ElementState, Event, MouseButton};
use parking_lot::MutexGuard;
use crate::clipboard::ClipboardType;
@@ -15,7 +15,7 @@ use crate::config::{self, Config, StartupMode};
use crate::display::OnResize;
use crate::grid::Scroll;
use crate::index::{Column, Line, Point, Side};
-use crate::input::{self, KeyBinding, MouseBinding};
+use crate::input::{self, KeyBinding, Modifiers, MouseBinding};
use crate::selection::Selection;
use crate::sync::FairMutex;
use crate::term::{SizeInfo, Term};
@@ -39,7 +39,7 @@ pub struct ActionContext<'a, N> {
pub mouse: &'a mut Mouse,
pub received_count: &'a mut usize,
pub suppress_chars: &'a mut bool,
- pub last_modifiers: &'a mut ModifiersState,
+ pub modifiers: &'a mut Modifiers,
pub window_changes: &'a mut WindowChanges,
}
@@ -141,8 +141,8 @@ impl<'a, N: Notify + 'a> input::ActionContext for ActionContext<'a, N> {
}
#[inline]
- fn last_modifiers(&mut self) -> &mut ModifiersState {
- &mut self.last_modifiers
+ fn modifiers(&mut self) -> &mut Modifiers {
+ &mut self.modifiers
}
#[inline]
@@ -287,7 +287,7 @@ pub struct Processor<N> {
hide_mouse: bool,
received_count: usize,
suppress_chars: bool,
- last_modifiers: ModifiersState,
+ modifiers: Modifiers,
pending_events: Vec<Event>,
window_changes: WindowChanges,
save_to_clipboard: bool,
@@ -331,7 +331,7 @@ impl<N: Notify> Processor<N> {
hide_mouse: false,
received_count: 0,
suppress_chars: false,
- last_modifiers: Default::default(),
+ modifiers: Default::default(),
pending_events: Vec::with_capacity(4),
window_changes: Default::default(),
save_to_clipboard: config.selection.save_to_clipboard,
@@ -406,11 +406,9 @@ impl<N: Notify> Processor<N> {
*window_is_focused = is_focused;
if is_focused {
- processor.ctx.terminal.dirty = true;
processor.ctx.terminal.next_is_urgent = Some(false);
+ processor.ctx.terminal.dirty = true;
} else {
- processor.ctx.terminal.reset_url_highlight();
- processor.ctx.terminal.reset_mouse_cursor();
processor.ctx.terminal.dirty = true;
*hide_mouse = false;
}
@@ -426,6 +424,7 @@ impl<N: Notify> Processor<N> {
processor.ctx.size_info.dpr = new_dpr;
processor.ctx.terminal.dirty = true;
},
+ CursorLeft { .. } => processor.ctx.terminal.reset_url_highlight(),
_ => (),
}
},
@@ -478,7 +477,7 @@ impl<N: Notify> Processor<N> {
size_info: &mut self.size_info,
received_count: &mut self.received_count,
suppress_chars: &mut self.suppress_chars,
- last_modifiers: &mut self.last_modifiers,
+ modifiers: &mut self.modifiers,
window_changes: &mut self.window_changes,
};