diff options
author | Joe Wilm <joe@jwilm.com> | 2016-06-06 15:13:45 -0700 |
---|---|---|
committer | Joe Wilm <joe@jwilm.com> | 2016-06-06 15:13:45 -0700 |
commit | 6636cf6b9fa03a711f8c3aa2d6ca43248fecfc0f (patch) | |
tree | 0c5116d2cb479bad8be1ed42cf91368b25091861 /src/term.rs | |
parent | e5aeae69aabe2586d7bb3fc90c24cefc39af3e63 (diff) | |
download | alacritty-6636cf6b9fa03a711f8c3aa2d6ca43248fecfc0f.tar.gz alacritty-6636cf6b9fa03a711f8c3aa2d6ca43248fecfc0f.zip |
Minor updates to terminal handling
Properly handles goto_col and goto_row. Additionally, input wrapping is
handled.
Truecolor specs are now set appropriately.
Diffstat (limited to 'src/term.rs')
-rw-r--r-- | src/term.rs | 24 |
1 files changed, 22 insertions, 2 deletions
diff --git a/src/term.rs b/src/term.rs index 2838c668..5b00acfd 100644 --- a/src/term.rs +++ b/src/term.rs @@ -149,6 +149,11 @@ impl Term { /// Set character in current cursor position fn set_char(&mut self, c: char) { + if self.cursor.x == self.grid.num_cols() as u16 { + self.cursor.y += 1; + self.cursor.x = 0; + } + let cell = &mut self.grid[self.cursor]; cell.c = c; cell.fg = self.fg; @@ -175,8 +180,17 @@ impl ansi::Handler for Term { println!("goto: x={}, y={}", x, y); self.cursor.goto(x as u16, y as u16); } - fn goto_row(&mut self, y: i64) { println!("goto_row: {}", y); } - fn goto_col(&mut self, x: i64) { println!("goto_col: {}", x); } + fn goto_row(&mut self, y: i64) { + println!("goto_row: {}", y); + let x = self.cursor_x(); + self.cursor.goto(x, y as u16); + } + fn goto_col(&mut self, x: i64) { + println!("goto_col: {}", x); + let y = self.cursor_y(); + self.cursor.goto(x as u16, y); + } + fn insert_blank(&mut self, num: i64) { println!("insert_blank: {}", num); } fn move_up(&mut self, rows: i64) { @@ -325,6 +339,12 @@ impl ansi::Handler for Term { Attr::Background(named_color) => { self.bg = COLORS[named_color as usize]; }, + Attr::ForegroundSpec(rgb) => { + self.fg = rgb; + }, + Attr::BackgroundSpec(rgb) => { + self.bg = rgb; + }, Attr::Reset => { self.fg = DEFAULT_FG; self.bg = DEFAULT_BG; |