diff --git a/.idea/workspace.xml b/.idea/workspace.xml index 325ca54..476a865 100644 --- a/.idea/workspace.xml +++ b/.idea/workspace.xml @@ -2,16 +2,14 @@ - - + - + - - - - - + + + + - - + + - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + - + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + @@ -135,7 +137,6 @@ - terminal_cursor term ScreenManager color @@ -165,6 +166,7 @@ data context WinApiScreenManager + color( crossterm_cursor @@ -188,7 +190,6 @@ @@ -294,13 +296,27 @@ - + + + + + + + + + + + + + + + + - @@ -319,7 +335,8 @@ - + + @@ -327,39 +344,6 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - @@ -557,11 +541,12 @@ + - @@ -573,50 +558,28 @@ - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - + + + + + + + + + + + + + + + + + + + @@ -624,12 +587,12 @@ - + @@ -640,7 +603,7 @@ - + @@ -655,24 +618,10 @@ - - - - - - - - - - - - - - @@ -680,20 +629,6 @@ - - - - - - - - - - - - - - @@ -760,27 +695,6 @@ - - - - - - - - - - - - - - - - - - - - - @@ -795,13 +709,6 @@ - - - - - - - @@ -809,13 +716,6 @@ - - - - - - - @@ -823,27 +723,6 @@ - - - - - - - - - - - - - - - - - - - - - @@ -851,13 +730,6 @@ - - - - - - - @@ -865,20 +737,6 @@ - - - - - - - - - - - - - - @@ -886,20 +744,6 @@ - - - - - - - - - - - - - - @@ -918,31 +762,19 @@ - - - - - - - - - - - - - + - + @@ -956,14 +788,14 @@ - + - + @@ -975,10 +807,149 @@ + + + + + + + + + + + + + + + + + + + + + + + + + - - + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/examples/Crossterm 0.2.2 - New Version (Not finished)/bin.rs b/examples/Crossterm 0.2.2 - New Version (Not finished)/bin.rs index cf3732b..b952917 100644 --- a/examples/Crossterm 0.2.2 - New Version (Not finished)/bin.rs +++ b/examples/Crossterm 0.2.2 - New Version (Not finished)/bin.rs @@ -29,16 +29,15 @@ use crossterm::raw::IntoRawMode; use std::io::Write; use std::{time, thread}; +use std::process::exit; + fn main() { -//// alternate_screen::switch_between_main_and_alternate_screen(); let context = Context::new(); -// let mut scre = screen::AlternateScreen::from(context.clone()); -// write!(scre, "asdf"); -// scre.flush(); -// thread::sleep(time::Duration::from_secs(3)); use crossterm::terminal::terminal; let curs = terminal(context.clone()); - curs.set_title(String::from("Test")); + curs.exit(); + thread::sleep(time::Duration::from_secs(3)); + } \ No newline at end of file diff --git a/examples/Crossterm 0.2.2 - New Version (Not finished)/color/mod.rs b/examples/Crossterm 0.2.2 - New Version (Not finished)/color/mod.rs index 81b65af..603c70f 100644 --- a/examples/Crossterm 0.2.2 - New Version (Not finished)/color/mod.rs +++ b/examples/Crossterm 0.2.2 - New Version (Not finished)/color/mod.rs @@ -146,7 +146,7 @@ pub fn print_supported_colors() let context = Context::new(); let terminal = terminal::terminal(context.clone()); - let count = crossterm::style::color(context.screen_manager.clone()).get_available_color_count().unwrap(); + let count = crossterm::style::color(context.clone()).get_available_color_count().unwrap(); for i in 0..count { diff --git a/src/cursor/ansi_cursor.rs b/src/cursor/ansi_cursor.rs index d880abe..83fe35b 100644 --- a/src/cursor/ansi_cursor.rs +++ b/src/cursor/ansi_cursor.rs @@ -100,7 +100,7 @@ impl ITerminalCursor for AnsiCursor { screen.write_ansi_str(csi!("?12h")); } else { - screen.write_ansi_str(csi!("?12l")); + screen.write_ansi_str(csi!("?12")); } } } diff --git a/src/kernel/unix_kernel/terminal.rs b/src/kernel/unix_kernel/terminal.rs index 2dff600..7f10506 100644 --- a/src/kernel/unix_kernel/terminal.rs +++ b/src/kernel/unix_kernel/terminal.rs @@ -132,6 +132,10 @@ pub fn get_terminal_mode() -> io::Result } } +pub fn exit() +{ + ::std::process::exit(0); + /// Is the return value true? fn is_true(value: i32) -> Result<(), Error> { diff --git a/src/kernel/windows_kernel/terminal.rs b/src/kernel/windows_kernel/terminal.rs index 2771f44..9a31e1a 100644 --- a/src/kernel/windows_kernel/terminal.rs +++ b/src/kernel/windows_kernel/terminal.rs @@ -5,4 +5,9 @@ pub fn terminal_size() -> (u16, u16) { (csbi.srWindow.Right - csbi.srWindow.Left) as u16, (csbi.srWindow.Bottom - csbi.srWindow.Top) as u16, ) +} + +pub fn exit() +{ + ::std::process::exit(256); } \ No newline at end of file diff --git a/src/shared/functions.rs b/src/shared/functions.rs index 58514bd..1408552 100644 --- a/src/shared/functions.rs +++ b/src/shared/functions.rs @@ -4,15 +4,13 @@ use Context; use std::rc::Rc; #[cfg(windows)] -use kernel::windows_kernel::terminal::terminal_size; - -#[cfg(unix)] -use kernel::unix_kernel::terminal::terminal_size; +use kernel::windows_kernel::terminal::{exit, terminal_size}; #[cfg(windows)] use kernel::windows_kernel::cursor::pos; + #[cfg(unix)] -use kernel::unix_kernel::terminal::pos; +use kernel::unix_kernel::terminal::{pos, exit,terminal_size }; /// Get the terminal size based on the current platform. pub fn get_terminal_size() -> (u16, u16) @@ -30,6 +28,16 @@ pub fn get_cursor_position(context: Rc) -> (u16, u16) return pos(); } +/// exit the current terminal. +pub fn exit_terminal() +{ + #[cfg(unix)] + exit(); + + #[cfg(windows)] + exit(); +} + #[cfg(windows)] /// Get an module specific implementation based on the current platform. pub fn get_module(winapi_impl: T, unix_impl: T) -> Option diff --git a/src/style/styles/styledobject.rs b/src/style/styles/styledobject.rs index 8d3cd9a..8fcaa3f 100644 --- a/src/style/styles/styledobject.rs +++ b/src/style/styles/styledobject.rs @@ -124,18 +124,19 @@ macro_rules! impl_fmt colored_terminal.set_bg(bg); reset = true; } + if let Some(fg) = self.object_style.fg_color { colored_terminal.set_fg(fg); reset = true; } - #[cfg(unix)] +// #[cfg(unix)] for attr in self.object_style.attrs.iter() { - let mutex = self.context.screen_manager; + let mutex = &self.context.screen_manager; { let mut screen = mutex.lock().unwrap(); - screen.write_ansi_str(format!(csi!("{}m"), *attr as i16)); + screen.write_ansi(format!(csi!("{}m"), *attr as i16)); } reset = true; } diff --git a/src/terminal/ansi_terminal.rs b/src/terminal/ansi_terminal.rs index 378a4e4..264d121 100644 --- a/src/terminal/ansi_terminal.rs +++ b/src/terminal/ansi_terminal.rs @@ -74,4 +74,9 @@ impl ITerminal for AnsiTerminal { screen.write_ansi_str("\x1b]2;New terminal titleBEL"); } } + + fn exit(&self) + { + functions::exit_terminal(); + } } diff --git a/src/terminal/mod.rs b/src/terminal/mod.rs index 1d0d23e..2003aaa 100644 --- a/src/terminal/mod.rs +++ b/src/terminal/mod.rs @@ -50,4 +50,6 @@ pub trait ITerminal { fn set_size(&self,width: i16, height: i16); /// Set the terminal title. fn set_title(&self, title: String); + /// Close the current terminal + fn exit(&self); } diff --git a/src/terminal/terminal.rs b/src/terminal/terminal.rs index faab9d4..00d9069 100644 --- a/src/terminal/terminal.rs +++ b/src/terminal/terminal.rs @@ -193,6 +193,13 @@ impl Terminal { terminal.set_title(title ); } } + + pub fn exit(&self) + { + if let Some (ref terminal) = self.terminal { + terminal.exit(); + } + } } /// Get an Terminal implementation whereon terminal related actions can be performed. diff --git a/src/terminal/winapi_terminal.rs b/src/terminal/winapi_terminal.rs index 866c6c7..e40fd44 100644 --- a/src/terminal/winapi_terminal.rs +++ b/src/terminal/winapi_terminal.rs @@ -6,6 +6,7 @@ use cursor::cursor; use super::{ClearType, ITerminal, Rc}; use winapi::um::wincon::{SMALL_RECT, COORD, CONSOLE_SCREEN_BUFFER_INFO,}; use kernel::windows_kernel::{kernel, terminal}; +use super::super::shared::functions; /// This struct is an windows implementation for terminal related actions. pub struct WinApiTerminal @@ -142,6 +143,11 @@ impl ITerminal for WinApiTerminal { { } + + fn exit(&self) + { + functions::exit_terminal(); + } } pub fn clear_after_cursor(pos: (u16,u16), csbi: CONSOLE_SCREEN_BUFFER_INFO, context: Rc) {