Support ANSI colors in msys terminals. See #2807

This commit is contained in:
Jan Niklas Hasse 2013-12-20 20:22:41 +01:00
parent b6933f8d8b
commit 5cf2f54bb1
2 changed files with 28 additions and 45 deletions

View File

@ -15,11 +15,11 @@
use std::io::{Decorator, Writer};
#[cfg(not(target_os = "win32"))] use std::os;
#[cfg(not(target_os = "win32"))] use terminfo::*;
#[cfg(not(target_os = "win32"))] use terminfo::searcher::open;
#[cfg(not(target_os = "win32"))] use terminfo::parser::compiled::parse;
#[cfg(not(target_os = "win32"))] use terminfo::parm::{expand, Number, Variables};
use std::os;
use terminfo::*;
use terminfo::searcher::open;
use terminfo::parser::compiled::{parse, msys_terminfo};
use terminfo::parm::{expand, Number, Variables};
// FIXME (#2807): Windows support.
@ -74,7 +74,6 @@ pub mod attr {
}
}
#[cfg(not(target_os = "win32"))]
fn cap_for_attr(attr: attr::Attr) -> &'static str {
match attr {
attr::Bold => "bold",
@ -93,29 +92,24 @@ fn cap_for_attr(attr: attr::Attr) -> &'static str {
}
}
#[cfg(not(target_os = "win32"))]
pub struct Terminal<T> {
priv num_colors: u16,
priv out: T,
priv ti: ~TermInfo
}
#[cfg(target_os = "win32")]
pub struct Terminal<T> {
priv num_colors: u16,
priv out: T,
}
#[cfg(not(target_os = "win32"))]
impl<T: Writer> Terminal<T> {
pub fn new(out: T) -> Result<Terminal<T>, ~str> {
let term = os::getenv("TERM");
if term.is_none() {
return Err(~"TERM environment variable undefined");
}
let term = match os::getenv("TERM") {
Some(t) => t,
None => return Err(~"TERM environment variable undefined")
};
let entry = open(term.unwrap());
let entry = open(term);
if entry.is_err() {
if "cygwin" == term { // msys terminal
return Ok(Terminal {out: out, ti: msys_terminfo(), num_colors: 8});
}
return Err(entry.unwrap_err());
}
@ -241,32 +235,6 @@ impl<T: Writer> Terminal<T> {
}
}
#[cfg(target_os = "win32")]
impl<T: Writer> Terminal<T> {
pub fn new(out: T) -> Result<Terminal<T>, ~str> {
return Ok(Terminal {out: out, num_colors: 0});
}
pub fn fg(&mut self, _color: color::Color) -> bool {
false
}
pub fn bg(&mut self, _color: color::Color) -> bool {
false
}
pub fn attr(&mut self, _attr: attr::Attr) -> bool {
false
}
pub fn supports_attr(&self, _attr: attr::Attr) -> bool {
false
}
pub fn reset(&self) {
}
}
impl<T: Writer> Decorator<T> for Terminal<T> {
fn inner(self) -> T {
self.out

View File

@ -316,6 +316,21 @@ pub fn parse(file: &mut io::Reader,
Ok(~TermInfo {names: term_names, bools: bools_map, numbers: numbers_map, strings: string_map })
}
/// Create a dummy TermInfo struct for msys terminals
pub fn msys_terminfo() -> ~TermInfo {
let mut strings = HashMap::new();
strings.insert(~"sgr0", bytes!("\x1b[0m").to_owned());
strings.insert(~"bold", bytes!("\x1b[1m;").to_owned());
strings.insert(~"setaf", bytes!("\x1b[3%p1%dm").to_owned());
strings.insert(~"setab", bytes!("\x1b[4%p1%dm").to_owned());
~TermInfo {
names: ~[~"cygwin"], // msys is a fork of an older cygwin version
bools: HashMap::new(),
numbers: HashMap::new(),
strings: strings
}
}
#[cfg(test)]
mod test {
use super::*;