API Cleanup - part 3 (#240)

This commit is contained in:
Zrzka 2019-09-20 23:50:53 +02:00 committed by Timon
parent 60cd12710a
commit 5216ecbdec
28 changed files with 152 additions and 163 deletions

1
.github/CODEOWNERS vendored Normal file
View File

@ -0,0 +1 @@
* @TimonPost

View File

@ -183,7 +183,7 @@ cursor.goto(5,20);
// Print at X: 5 Y: 20.
print!("Yea!");
// Reset back to X: 5 Y: 5.
cursor.reset_position();
cursor.restore_position();
// Print 'Back' at X: 5 Y: 5.
print!("Back");

View File

@ -106,7 +106,7 @@ cursor.goto(5,20);
// Print at X: 5 Y: 20.
print!("Yea!");
// Reset back to X: 5 Y: 5.
cursor.reset_position();
cursor.restore_position();
// Print 'Back' at X: 5 Y: 5.
print!("Back");

View File

@ -42,7 +42,7 @@ trait ITerminalCursor: Sync + Send {
/// is stored program based not per instance of the cursor struct.
fn save_position(&self) -> Result<()>;
/// Return to saved cursor position
fn reset_position(&self) -> Result<()>;
fn restore_position(&self) -> Result<()>;
/// Hide the terminal cursor.
fn hide(&self) -> Result<()>;
/// Show the terminal cursor

View File

@ -28,8 +28,8 @@ pub fn get_move_left_ansi(count: u16) -> String {
format!(csi!("{}D"), count)
}
pub static SAFE_POS_ANSI: &'static str = csi!("s");
pub static RESET_POS_ANSI: &'static str = csi!("u");
pub static SAVE_POS_ANSI: &'static str = csi!("s");
pub static RESTORE_POS_ANSI: &'static str = csi!("u");
pub static HIDE_ANSI: &'static str = csi!("?25l");
pub static SHOW_ANSI: &'static str = csi!("?25h");
pub static BLINK_ON_ANSI: &'static str = csi!("?12h");
@ -75,12 +75,12 @@ impl ITerminalCursor for AnsiCursor {
}
fn save_position(&self) -> Result<()> {
write_cout!(SAFE_POS_ANSI)?;
write_cout!(SAVE_POS_ANSI)?;
Ok(())
}
fn reset_position(&self) -> Result<()> {
write_cout!(RESET_POS_ANSI)?;
fn restore_position(&self) -> Result<()> {
write_cout!(RESTORE_POS_ANSI)?;
Ok(())
}
@ -111,45 +111,37 @@ mod tests {
// TODO - Test is ingored, because it's stalled on Travis CI
#[test]
#[ignore]
fn reset_safe_ansi() {
fn test_ansi_save_restore_position() {
if try_enable_ansi() {
let cursor = AnsiCursor::new();
let pos = cursor.pos();
assert!(pos.is_ok());
let (x, y) = pos.unwrap();
assert!(cursor.save_position().is_ok());
assert!(cursor.goto(5, 5).is_ok());
assert!(cursor.reset_position().is_ok());
let (saved_x, saved_y) = cursor.pos().unwrap();
let pos = cursor.pos();
assert!(pos.is_ok());
let (x_saved, y_saved) = pos.unwrap();
cursor.save_position().unwrap();
cursor.goto(saved_x + 1, saved_y + 1).unwrap();
cursor.restore_position().unwrap();
assert_eq!(x, x_saved);
assert_eq!(y, y_saved);
let (x, y) = cursor.pos().unwrap();
assert_eq!(x, saved_x);
assert_eq!(y, saved_y);
}
}
// TODO - Test is ingored, because it's stalled on Travis CI
#[test]
#[ignore]
fn goto_ansi() {
fn test_ansi_goto() {
if try_enable_ansi() {
let cursor = AnsiCursor::new();
let pos = cursor.pos();
assert!(pos.is_ok());
let (x_saved, y_saved) = pos.unwrap();
assert!(cursor.goto(5, 5).is_ok());
let pos = cursor.pos();
assert!(pos.is_ok());
let (x, y) = pos.unwrap();
let (saved_x, saved_y) = cursor.pos().unwrap();
assert!(cursor.goto(x_saved, y_saved).is_ok());
cursor.goto(saved_x + 1, saved_y + 1).unwrap();
assert_eq!(cursor.pos().unwrap(), (saved_x + 1, saved_y + 1));
assert_eq!(x, 5);
assert_eq!(y, 5);
cursor.goto(saved_x, saved_y).unwrap();
assert_eq!(cursor.pos().unwrap(), (saved_x, saved_y));
}
}

View File

@ -95,8 +95,8 @@ impl TerminalCursor {
}
/// Return to saved cursor position
pub fn reset_position(&self) -> Result<()> {
self.cursor.reset_position()
pub fn restore_position(&self) -> Result<()> {
self.cursor.restore_position()
}
/// Hide de cursor in the console.
@ -131,7 +131,7 @@ pub struct Goto(pub u16, pub u16);
impl Command for Goto {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::get_goto_ansi(self.0, self.1)
}
@ -149,7 +149,7 @@ pub struct Up(pub u16);
impl Command for Up {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::get_move_up_ansi(self.0)
}
@ -167,7 +167,7 @@ pub struct Down(pub u16);
impl Command for Down {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::get_move_down_ansi(self.0)
}
@ -185,7 +185,7 @@ pub struct Left(pub u16);
impl Command for Left {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::get_move_left_ansi(self.0)
}
@ -203,7 +203,7 @@ pub struct Right(pub u16);
impl Command for Right {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::get_move_right_ansi(self.0)
}
@ -223,8 +223,8 @@ pub struct SavePos;
impl Command for SavePos {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
ansi_cursor::SAFE_POS_ANSI
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::SAVE_POS_ANSI
}
#[cfg(windows)]
@ -241,13 +241,13 @@ pub struct ResetPos;
impl Command for ResetPos {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
ansi_cursor::RESET_POS_ANSI
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::RESTORE_POS_ANSI
}
#[cfg(windows)]
fn execute_winapi(&self) -> Result<()> {
WinApiCursor::new().reset_position()
WinApiCursor::new().restore_position()
}
}
@ -259,7 +259,7 @@ pub struct Hide;
impl Command for Hide {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::HIDE_ANSI
}
@ -277,7 +277,7 @@ pub struct Show;
impl Command for Show {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::SHOW_ANSI
}
@ -298,7 +298,7 @@ pub struct BlinkOn;
impl Command for BlinkOn {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::BLINK_ON_ANSI
}
@ -319,7 +319,7 @@ pub struct BlinkOff;
impl Command for BlinkOff {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_cursor::BLINK_OFF_ANSI
}

View File

@ -58,8 +58,8 @@ impl ITerminalCursor for WinApiCursor {
Ok(())
}
fn reset_position(&self) -> Result<()> {
Cursor::reset_to_saved_position()?;
fn restore_position(&self) -> Result<()> {
Cursor::restore_cursor_pos()?;
Ok(())
}
@ -83,35 +83,31 @@ mod tests {
use super::{ITerminalCursor, WinApiCursor};
#[test]
fn goto_winapi() {
fn test_winapi_goto() {
let cursor = WinApiCursor::new();
assert!(cursor.goto(5, 5).is_ok());
let pos = cursor.pos();
assert!(pos.is_ok());
let (x, y) = pos.unwrap();
let (saved_x, saved_y) = cursor.pos().unwrap();
assert_eq!(x, 5);
assert_eq!(y, 5);
cursor.goto(saved_x + 1, saved_y + 1).unwrap();
assert_eq!(cursor.pos().unwrap(), (saved_x + 1, saved_y + 1));
cursor.goto(saved_x, saved_y).unwrap();
assert_eq!(cursor.pos().unwrap(), (saved_x, saved_y));
}
#[test]
fn reset_safe_winapi() {
fn test_winapi_save_and_restore() {
let cursor = WinApiCursor::new();
let pos = cursor.pos();
assert!(pos.is_ok());
let (x, y) = pos.unwrap();
let (saved_x, saved_y) = cursor.pos().unwrap();
assert!(cursor.save_position().is_ok());
assert!(cursor.goto(5, 5).is_ok());
assert!(cursor.reset_position().is_ok());
cursor.save_position().unwrap();
cursor.goto(saved_x + 1, saved_y + 1).unwrap();
cursor.restore_position().unwrap();
let pos = cursor.pos();
assert!(pos.is_ok());
let (x_saved, y_saved) = pos.unwrap();
let (x, y) = cursor.pos().unwrap();
assert_eq!(x, x_saved);
assert_eq!(y, y_saved);
assert_eq!(x, saved_x);
assert_eq!(y, saved_y);
}
}

View File

@ -26,7 +26,7 @@ pub fn show_cursor(show_cursor: bool) -> Result<()> {
}
pub fn pos() -> Result<(u16, u16)> {
unix::into_raw_mode()?;
unix::enable_raw_mode()?;
let pos = pos_raw();
unix::disable_raw_mode()?;
pos

View File

@ -67,7 +67,7 @@ impl Cursor {
unsafe {
if !is_true(SetConsoleCursorPosition(
**self.screen_buffer.get_handle(),
**self.screen_buffer.handle(),
position,
)) {
Err(io::Error::last_os_error())?;
@ -85,7 +85,7 @@ impl Cursor {
unsafe {
if !is_true(SetConsoleCursorInfo(
**self.screen_buffer.get_handle(),
**self.screen_buffer.handle(),
&cursor_info,
)) {
Err(io::Error::last_os_error())?;
@ -95,7 +95,7 @@ impl Cursor {
}
/// Reset to saved cursor position
pub fn reset_to_saved_position() -> Result<()> {
pub fn restore_cursor_pos() -> Result<()> {
let cursor = Cursor::new()?;
unsafe {

View File

@ -10,7 +10,7 @@ impl RawModeCommand {
/// Enables raw mode.
pub fn enable(&mut self) -> Result<()> {
crossterm_utils::sys::unix::into_raw_mode()?;
crossterm_utils::sys::unix::enable_raw_mode()?;
Ok(())
}

View File

@ -70,7 +70,7 @@ impl TerminalColor {
/// # Remarks
///
/// This does not always provide a good result.
pub fn get_available_color_count(&self) -> u16 {
pub fn available_color_count(&self) -> u16 {
env::var("TERM")
.map(|x| if x.contains("256color") { 256 } else { 8 })
.unwrap_or(8)
@ -90,7 +90,7 @@ pub struct SetFg(pub Color);
impl Command for SetFg {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_color::get_set_fg_ansi(self.0)
}
@ -108,7 +108,7 @@ pub struct SetBg(pub Color);
impl Command for SetBg {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_color::get_set_bg_ansi(self.0)
}
@ -126,7 +126,7 @@ pub struct SetAttr(pub Attribute);
impl Command for SetAttr {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
ansi_color::get_set_attr_ansi(self.0)
}
@ -148,7 +148,7 @@ where
{
type AnsiType = StyledObject<D>;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
self.0.clone()
}

View File

@ -52,7 +52,7 @@ impl ITerminalColor for WinApiColor {
color = color | wincon::BACKGROUND_INTENSITY as u16;
}
Console::from(**screen_buffer.get_handle()).set_text_attribute(color)?;
Console::from(**screen_buffer.handle()).set_text_attribute(color)?;
Ok(())
}
@ -79,7 +79,7 @@ impl ITerminalColor for WinApiColor {
color = color | wincon::FOREGROUND_INTENSITY as u16;
}
Console::from(**screen_buffer.get_handle()).set_text_attribute(color)?;
Console::from(**screen_buffer.handle()).set_text_attribute(color)?;
Ok(())
}

View File

@ -88,21 +88,21 @@ mod tests {
// TODO - Test is disabled, because it's failing on Travis CI
#[test]
#[ignore]
fn resize_ansi() {
fn test_resize_ansi() {
if try_enable_ansi() {
let terminal = AnsiTerminal::new();
assert!(terminal.set_size(50, 50).is_ok());
let (width, height) = terminal.size().unwrap();
terminal.set_size(30, 30).unwrap();
// see issue: https://github.com/eminence/terminal-size/issues/11
thread::sleep(time::Duration::from_millis(30));
assert_eq!((30, 30), terminal.size().unwrap());
let size = terminal.size();
assert!(size.is_ok());
let (x, y) = size.unwrap();
assert_eq!(x, 50);
assert_eq!(y, 50);
terminal.set_size(width, height).unwrap();
// see issue: https://github.com/eminence/terminal-size/issues/11
thread::sleep(time::Duration::from_millis(30));
assert_eq!((width, height), terminal.size().unwrap());
}
}

View File

@ -145,7 +145,7 @@ pub struct ScrollUp(pub u16);
impl Command for ScrollUp {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
super::ansi_terminal::get_scroll_up_ansi(self.0)
}
@ -163,7 +163,7 @@ pub struct ScrollDown(pub u16);
impl Command for ScrollDown {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
super::ansi_terminal::get_scroll_down_ansi(self.0)
}
@ -181,7 +181,7 @@ pub struct Clear(pub ClearType);
impl Command for Clear {
type AnsiType = &'static str;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
match self.0 {
ClearType::All => {
return super::ansi_terminal::CLEAR_ALL;
@ -211,7 +211,7 @@ pub struct SetSize(pub u16, pub u16);
impl Command for SetSize {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
super::ansi_terminal::get_set_size_ansi(self.0, self.1)
}

View File

@ -93,7 +93,7 @@ impl ITerminal for WinApiTerminal {
// Get the position of the current console window
let screen_buffer = ScreenBuffer::current()?;
let console = Console::from(**screen_buffer.get_handle());
let console = Console::from(**screen_buffer.handle());
let csbi = screen_buffer.info()?;
let current_size = csbi.buffer_size();
@ -283,16 +283,15 @@ mod tests {
// TODO - Test is ignored, because it returns wrong result (31 != 30)
#[test]
#[ignore]
fn resize_winapi() {
fn test_resize_winapi() {
let terminal = WinApiTerminal::new();
assert!(terminal.set_size(30, 30).is_ok());
let (width, height) = terminal.size().unwrap();
let size = terminal.size();
assert!(size.is_ok());
let (x, y) = size.unwrap();
terminal.set_size(30, 30).unwrap();
assert_eq!((30, 30), terminal.size().unwrap());
assert_eq!(x, 30);
assert_eq!(y, 30);
terminal.set_size(width, height).unwrap();
assert_eq!((width, height), terminal.size().unwrap());
}
}

View File

@ -17,7 +17,7 @@ pub trait Command {
/// You are able to use ANSI escape codes only for windows 10 and UNIX systems.
///
/// **This method is mainly used internally by crossterm!**
fn get_ansi_code(&self) -> Self::AnsiType;
fn ansi_code(&self) -> Self::AnsiType;
/// Execute this command.
///
@ -104,7 +104,7 @@ pub struct Output(pub String);
impl Command for Output {
type AnsiType = String;
fn get_ansi_code(&self) -> Self::AnsiType {
fn ansi_code(&self) -> Self::AnsiType {
return self.0.clone();
}

View File

@ -5,24 +5,15 @@ use crate::sys::winapi::ansi::set_virtual_terminal_processing;
pub fn supports_ansi() -> bool {
// Some terminals on windows like GitBash can't use WinaApi calls directly so when we try to enable the ANSI-flag for windows this won't work.
// Because of that we should check first if the TERM-variable is set and see if the current terminal is a terminal who does support ANSI.
let supports_ansi = is_specific_term();
match supports_ansi {
true => {
return true;
}
false => {
// if it is not listed we should try with WinApi to check if we do support ANSI-codes.
match set_virtual_terminal_processing(true) {
Ok(_) => {
return true;
}
Err(_) => {
return false;
}
}
}
if is_specific_term() {
return true;
}
// if it is not listed we should try with WinApi to check if we do support ANSI-codes.
set_virtual_terminal_processing(true)
.map(|_| true)
.unwrap_or(false)
}
// checks if the 'TERM' environment variable is set to check if the terminal supports ANSI-codes.

View File

@ -80,7 +80,7 @@ macro_rules! queue {
#[cfg(windows)]
{
if $crate::supports_ansi() {
match write!($write, "{}", $command.get_ansi_code()) {
match write!($write, "{}", $command.ansi_code()) {
Err(e) => {
error = Some(Err($crate::ErrorKind::from(e)));
}
@ -96,7 +96,7 @@ macro_rules! queue {
};
}
#[cfg(unix)]
match write!($write, "{}", $command.get_ansi_code()) {
match write!($write, "{}", $command.ansi_code()) {
Err(e) => {
error = Some(Err($crate::ErrorKind::from(e)));
}
@ -154,7 +154,7 @@ macro_rules! execute {
#[cfg(windows)]
{
if $crate::supports_ansi() {
if let Err(e) = write_cout!($write, $command.get_ansi_code()) {
if let Err(e) = write_cout!($write, $command.ansi_code()) {
error = Some($crate::ErrorKind::from(e));
};
} else {
@ -165,7 +165,7 @@ macro_rules! execute {
}
#[cfg(unix)]
{
if let Err(e) = write_cout!($write, $command.get_ansi_code()) {
if let Err(e) = write_cout!($write, $command.ansi_code()) {
error = Some($crate::ErrorKind::from(e));
}
}
@ -185,7 +185,7 @@ macro_rules! impl_display {
$(impl ::std::fmt::Display for $t {
fn fmt(&self, f: &mut ::std::fmt::Formatter) -> ::std::result::Result<(), ::std::fmt::Error> {
use $crate::Command;
write!(f, "{}", self.get_ansi_code())
write!(f, "{}", self.ansi_code())
}
})*
}

View File

@ -43,7 +43,7 @@ pub fn set_terminal_attr(termios: &Termios) -> Result<()> {
wrap_with_result(unsafe { tcsetattr(0, 0, termios) })
}
pub fn into_raw_mode() -> Result<()> {
pub fn enable_raw_mode() -> Result<()> {
let mut ios = get_terminal_attr()?;
let prev_ios = ios;

View File

@ -1,6 +1,8 @@
use std::io::Result;
use crossterm_winapi::{Console, ScreenBuffer};
fn set_background_color() -> std::io::Result<()> {
fn set_background_color() -> Result<()> {
// background value
const BLUE_BACKGROUND: u16 = 0x0010;
@ -16,12 +18,12 @@ fn set_background_color() -> std::io::Result<()> {
let new_color = fg_color | BLUE_BACKGROUND;
// set the console text attribute to the new color value.
Console::from(**screen_buffer.get_handle()).set_text_attribute(new_color)?;
Console::from(**screen_buffer.handle()).set_text_attribute(new_color)?;
Ok(())
}
fn set_foreground_color() -> std::io::Result<()> {
fn set_foreground_color() -> Result<()> {
// background value
const BLUE_FOREGROUND: u16 = 0x0001;
@ -41,12 +43,12 @@ fn set_foreground_color() -> std::io::Result<()> {
}
// set the console text attribute to the new color value.
Console::from(**screen_buffer.get_handle()).set_text_attribute(color)?;
Console::from(**screen_buffer.handle()).set_text_attribute(color)?;
Ok(())
}
fn main() {
set_background_color().unwrap();
set_foreground_color().unwrap();
fn main() -> Result<()> {
set_background_color()?;
set_foreground_color()
}

View File

@ -1,17 +1,17 @@
use std::io::Result;
use crossterm_winapi::ConsoleMode;
fn change_console_mode() {
let console_mode = ConsoleMode::new().unwrap();
fn change_console_mode() -> Result<()> {
let console_mode = ConsoleMode::new()?;
// get the current console mode:
let _mode: u32 = console_mode.mode().unwrap();
let _mode: u32 = console_mode.mode()?;
// set the console mode (not sure if this is an actual value xp)
console_mode
.set_mode(10)
.expect("Unable to set console mode");
console_mode.set_mode(10)
}
fn main() {
change_console_mode();
fn main() -> Result<()> {
change_console_mode()
}

View File

@ -1,12 +1,14 @@
use std::io::Result;
use crossterm_winapi::{Handle, HandleType};
#[allow(unused_variables)]
fn main() {
fn main() -> Result<()> {
// see the description of the types to see what they do.
let out_put_handle = Handle::new(HandleType::OutputHandle).unwrap();
let out_put_handle = Handle::new(HandleType::InputHandle).unwrap();
let curr_out_put_handle = Handle::new(HandleType::CurrentOutputHandle).unwrap();
let curr_out_put_handle = Handle::new(HandleType::CurrentInputHandle).unwrap();
let out_put_handle = Handle::new(HandleType::OutputHandle)?;
let out_put_handle = Handle::new(HandleType::InputHandle)?;
let curr_out_put_handle = Handle::new(HandleType::CurrentOutputHandle)?;
let curr_out_put_handle = Handle::new(HandleType::CurrentInputHandle)?;
// now you have this handle you might want to get the WinApi `HANDLE` it is wrapping.
// you can do this by defencing.
@ -15,4 +17,6 @@ fn main() {
// you can also pass you own `HANDLE` to create an instance of `Handle`
let handle = Handle::from(handle); /* winapi::um::winnt::HANDLE */
Ok(())
}

View File

@ -1,26 +1,31 @@
#![allow(dead_code)]
use std::io::Result;
use crossterm_winapi::ScreenBuffer;
fn print_screen_buffer_information() {
let screen_buffer = ScreenBuffer::current().unwrap();
fn print_screen_buffer_information() -> Result<()> {
let screen_buffer = ScreenBuffer::current()?;
// get console screen buffer information
let csbi = screen_buffer.info().unwrap();
let csbi = screen_buffer.info()?;
println!("cursor post: {:?}", csbi.cursor_pos());
println!("attributes: {:?}", csbi.attributes());
println!("terminal window dimentions {:?}", csbi.terminal_window());
println!("terminal size {:?}", csbi.terminal_size());
Ok(())
}
#[allow(dead_code)]
fn multiple_screen_buffers() {
fn multiple_screen_buffers() -> Result<()> {
// create new screen buffer
let screen_buffer = ScreenBuffer::create();
// which to this screen buffer
screen_buffer.show().expect("Unable to show screen buffer");
screen_buffer.show()
}
fn main() {
print_screen_buffer_information();
fn main() -> Result<()> {
print_screen_buffer_information()
}

View File

@ -82,16 +82,15 @@ mod tests {
// TODO - Test is ignored, because it's failing on Travis CI
#[test]
#[ignore]
fn set_get_mode() {
fn test_set_get_mode() {
let mode = ConsoleMode::new().unwrap();
let original_mode = mode.mode().unwrap();
assert!(mode.set_mode(0x0004).is_ok());
mode.set_mode(0x0004).unwrap();
let console_mode = mode.mode().unwrap();
assert_eq!(console_mode & 0x0004, mode.mode().unwrap());
assert_ne!(console_mode & 0x0004, 0);
assert!(mode.set_mode(original_mode).is_ok());
mode.set_mode(original_mode).unwrap();
}
}

View File

@ -179,7 +179,7 @@ mod tests {
use super::{Handle, HandleType};
#[test]
fn get_handle() {
fn test_get_handle() {
assert!(Handle::new(HandleType::OutputHandle).is_ok());
assert!(Handle::new(HandleType::InputHandle).is_ok());
assert!(Handle::new(HandleType::CurrentOutputHandle).is_ok());

View File

@ -102,7 +102,7 @@ impl ScreenBuffer {
}
/// Get the underlining raw `HANDLE` used by this type to execute whit.
pub fn get_handle(&self) -> &Handle {
pub fn handle(&self) -> &Handle {
return &self.handle;
}
}
@ -126,7 +126,7 @@ mod tests {
use super::ScreenBuffer;
#[test]
fn screen_buffer_info() {
fn test_screen_buffer_info() {
let buffer = ScreenBuffer::current().unwrap();
let info = buffer.info().unwrap();
info.terminal_size();

View File

@ -62,7 +62,7 @@ fn move_left() -> Result<()> {
}
/// Save and reset cursor position | demonstration..
fn save_and_reset_position() -> Result<()> {
fn save_and_restore_position() -> Result<()> {
let cursor = cursor();
// Goto X: 5 Y: 5
@ -74,7 +74,7 @@ fn save_and_reset_position() -> Result<()> {
// Print at X: 5 Y: 20.
println!("Yea!");
// Reset back to X: 5 Y: 5.
cursor.reset_position()?;
cursor.restore_position()?;
// Print Back at X: 5 Y: 5.
println!("Back");

View File

@ -399,7 +399,7 @@ fn print_text_with_attributes() {
/// Print all supported RGB colors, not supported for Windows systems < 10 | demonstration.
fn print_supported_colors() {
let count = color().get_available_color_count();
let count = color().available_color_count();
for i in 0..count {
println!("Test {}", Colored::Bg(Color::AnsiValue(i as u8)));