aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorJoe Wilm <joe@jwilm.com>2018-02-16 17:33:32 -0800
committerJoe Wilm <joe@jwilm.com>2018-06-02 09:32:29 -0700
commit7fe67743ebffd047532f6271bf28474f9d947f64 (patch)
treea9d54cb4a6d40bc7499a23968108cbcd16a0e67d /src
parentf67b17ca7b2e0e47ad5eee24d8b86800c61139b4 (diff)
downloadalacritty-7fe67743ebffd047532f6271bf28474f9d947f64.tar.gz
alacritty-7fe67743ebffd047532f6271bf28474f9d947f64.zip
Scroll to bottom on character received
Diffstat (limited to 'src')
-rw-r--r--src/event.rs4
-rw-r--r--src/grid/mod.rs4
-rw-r--r--src/input.rs2
-rw-r--r--src/term/mod.rs4
4 files changed, 14 insertions, 0 deletions
diff --git a/src/event.rs b/src/event.rs
index 9c3e8edc..3b1df006 100644
--- a/src/event.rs
+++ b/src/event.rs
@@ -59,6 +59,10 @@ impl<'a, N: Notify + 'a> input::ActionContext for ActionContext<'a, N> {
self.terminal.scroll_display(count);
}
+ fn reset_scroll(&mut self) {
+ self.terminal.reset_scroll();
+ }
+
fn copy_selection(&self, buffer: ::copypasta::Buffer) {
if let Some(ref selection) = *self.selection {
if let Some(ref span) = selection.to_span(self.terminal) {
diff --git a/src/grid/mod.rs b/src/grid/mod.rs
index 23ee9cf4..c6543270 100644
--- a/src/grid/mod.rs
+++ b/src/grid/mod.rs
@@ -108,6 +108,10 @@ impl<T: Copy + Clone> Grid<T> {
);
}
+ pub fn reset_scroll(&mut self) {
+ self.display_offset = 0;
+ }
+
pub fn new(lines: index::Line, cols: index::Column, template: T) -> Grid<T> {
let mut raw = Storage::with_capacity(*lines + SCROLLBACK_LINES, lines);
let template_row = Row::new(cols, &template);
diff --git a/src/input.rs b/src/input.rs
index 2e345c2a..68787979 100644
--- a/src/input.rs
+++ b/src/input.rs
@@ -65,6 +65,7 @@ pub trait ActionContext {
fn change_font_size(&mut self, delta: i8);
fn reset_font_size(&mut self);
fn scroll(&mut self, count: isize) {}
+ fn reset_scroll(&mut self) {}
}
/// Describes a state and action to take in that state
@@ -560,6 +561,7 @@ impl<'a, A: ActionContext + 'a> Processor<'a, A> {
/// Process a received character
pub fn received_char(&mut self, c: char) {
if !*self.ctx.suppress_chars() {
+ self.ctx.reset_scroll();
self.ctx.clear_selection();
let utf8_len = c.len_utf8();
diff --git a/src/term/mod.rs b/src/term/mod.rs
index 824577f7..3bce60cd 100644
--- a/src/term/mod.rs
+++ b/src/term/mod.rs
@@ -784,6 +784,10 @@ impl Term {
self.dirty = true;
}
+ pub fn reset_scroll(&mut self) {
+ self.grid.reset_scroll();
+ }
+
#[inline]
pub fn get_next_mouse_cursor(&mut self) -> Option<MouseCursor> {
self.next_mouse_cursor.take()