diff options
Diffstat (limited to 'src/ansi.rs')
-rw-r--r-- | src/ansi.rs | 121 |
1 files changed, 52 insertions, 69 deletions
diff --git a/src/ansi.rs b/src/ansi.rs index 8ff7d06b..22e84a21 100644 --- a/src/ansi.rs +++ b/src/ansi.rs @@ -360,6 +360,9 @@ pub enum CursorStyle { /// Cursor is a vertical bar `⎸` Beam, + + /// Cursor is a box like `☐` + HollowBlock, } impl Default for CursorStyle { @@ -731,18 +734,16 @@ impl<'a, H, W> vte::Perform for Performer<'a, H, W> // TODO replace OSC parsing with parser combinators #[inline] fn osc_dispatch(&mut self, params: &[&[u8]]) { - macro_rules! unhandled { - () => {{ - let mut buf = String::new(); - for items in params { - buf.push_str("["); - for item in *items { - buf.push_str(&format!("{:?},", *item as char)); - } - buf.push_str("],"); + fn unhandled(params: &[&[u8]]) { + let mut buf = String::new(); + for items in params { + buf.push_str("["); + for item in *items { + buf.push_str(&format!("{:?},", *item as char)); } - warn!("[unhandled osc_dispatch]: [{}] at line {}", &buf, line!()); - }} + buf.push_str("],"); + } + warn!("[unhandled osc_dispatch]: [{}] at line {}", &buf, line!()); } if params.is_empty() || params[0].is_empty() { @@ -752,13 +753,13 @@ impl<'a, H, W> vte::Perform for Performer<'a, H, W> match params[0] { // Set window title b"0" | b"2" => { - if params.len() < 2 { - return unhandled!(); - } - - if let Ok(utf8_title) = str::from_utf8(params[1]) { - self.handler.set_title(utf8_title); + if params.len() >= 2 { + if let Ok(utf8_title) = str::from_utf8(params[1]) { + self.handler.set_title(utf8_title); + return; + } } + unhandled(params); }, // Set icon name @@ -767,70 +768,60 @@ impl<'a, H, W> vte::Perform for Performer<'a, H, W> // Set color index b"4" => { - if params.len() == 1 || params.len() % 2 == 0 { - return unhandled!(); - } - - for chunk in params[1..].chunks(2) { - if let Some(index) = parse_number(chunk[0]) { - if let Some(color) = parse_rgb_color(chunk[1]) { - self.handler.set_color(index as usize, color); - } else { - unhandled!(); + if params.len() > 1 && params.len() % 2 != 0 { + for chunk in params[1..].chunks(2) { + let index = parse_number(chunk[0]); + let color = parse_rgb_color(chunk[0]); + if let (Some(i), Some(c)) = (index, color) { + self.handler.set_color(i as usize, c); + return; } - } else { - unhandled!(); } } + unhandled(params); } // Set foreground color b"10" => { - if params.len() < 2 { - return unhandled!(); - } - - if let Some(color) = parse_rgb_color(params[1]) { - self.handler.set_color(NamedColor::Foreground as usize, color); - } else { - unhandled!() + if params.len() >= 2 { + if let Some(color) = parse_rgb_color(params[1]) { + self.handler.set_color(NamedColor::Foreground as usize, color); + return; + } } + unhandled(params); } // Set background color b"11" => { - if params.len() < 2 { - return unhandled!(); - } - - if let Some(color) = parse_rgb_color(params[1]) { - self.handler.set_color(NamedColor::Background as usize, color); - } else { - unhandled!() + if params.len() >= 2 { + if let Some(color) = parse_rgb_color(params[1]) { + self.handler.set_color(NamedColor::Background as usize, color); + return; + } } + unhandled(params); } // Set text cursor color b"12" => { - if params.len() < 2 { - return unhandled!(); - } - - if let Some(color) = parse_rgb_color(params[1]) { - self.handler.set_color(NamedColor::Cursor as usize, color); - } else { - unhandled!() + if params.len() >= 2 { + if let Some(color) = parse_rgb_color(params[1]) { + self.handler.set_color(NamedColor::Cursor as usize, color); + return; + } } + unhandled(params); } // Set clipboard b"52" => { if params.len() < 3 { - return unhandled!(); + return unhandled(params); } match params[2] { - b"?" => unhandled!(), + b"?" => unhandled(params), selection => { if let Ok(string) = base64::decode(selection) { if let Ok(utf8_string) = str::from_utf8(&string) { @@ -855,29 +846,21 @@ impl<'a, H, W> vte::Perform for Performer<'a, H, W> for param in ¶ms[1..] { match parse_number(param) { Some(index) => self.handler.reset_color(index as usize), - None => unhandled!(), + None => unhandled(params), } } } // Reset foreground color - b"110" => { - self.handler.reset_color(NamedColor::Foreground as usize); - } + b"110" => self.handler.reset_color(NamedColor::Foreground as usize), // Reset background color - b"111" => { - self.handler.reset_color(NamedColor::Background as usize); - } + b"111" => self.handler.reset_color(NamedColor::Background as usize), // Reset text cursor color - b"112" => { - self.handler.reset_color(NamedColor::Cursor as usize); - } + b"112" => self.handler.reset_color(NamedColor::Cursor as usize), - _ => { - unhandled!(); - } + _ => unhandled(params), } } @@ -1389,7 +1372,7 @@ mod tests { use super::{Processor, Handler, Attr, TermInfo, Color, StandardCharset, CharsetIndex, parse_rgb_color, parse_number}; use ::Rgb; - /// The /dev/null of io::Write + /// The /dev/null of `io::Write` struct Void; impl io::Write for Void { |