Examples Clean-Up (#119)
This commit is contained in:
parent
41f68bda25
commit
f468cf6a9a
@ -1,25 +1,25 @@
|
|||||||
extern crate crossterm;
|
extern crate crossterm;
|
||||||
|
|
||||||
use crossterm::{style, AlternateScreen, ClearType, Color, Crossterm};
|
use crossterm::{style, AlternateScreen, ClearType, Color, Crossterm};
|
||||||
use std::{thread, time};
|
use std::{thread, time, io};
|
||||||
|
|
||||||
fn print_wait_screen() {
|
fn print_wait_screen() -> io::Result<()> {
|
||||||
let crossterm = Crossterm::new();
|
let crossterm = Crossterm::new();
|
||||||
let terminal = crossterm.terminal();
|
let terminal = crossterm.terminal();
|
||||||
let cursor = crossterm.cursor();
|
let cursor = crossterm.cursor();
|
||||||
|
|
||||||
terminal.clear(ClearType::All);
|
terminal.clear(ClearType::All)?;
|
||||||
cursor.goto(0, 0);
|
cursor.goto(0, 0)?;
|
||||||
cursor.hide();
|
cursor.hide()?;
|
||||||
terminal.write(
|
terminal.write(
|
||||||
"Welcome to the wait screen.\n\
|
"Welcome to the wait screen.\n\
|
||||||
Please wait a few seconds until we arrive back at the main screen.\n\
|
Please wait a few seconds until we arrive back at the main screen.\n\
|
||||||
Progress: ",
|
Progress: ",
|
||||||
);
|
)?;
|
||||||
// print some progress example.
|
// print some progress example.
|
||||||
for i in 1..5 {
|
for i in 1..5 {
|
||||||
// print the current counter at the line of `Seconds to Go: {counter}`
|
// print the current counter at the line of `Seconds to Go: {counter}`
|
||||||
cursor.goto(10, 2);
|
cursor.goto(10, 2)?;
|
||||||
println!(
|
println!(
|
||||||
"{}",
|
"{}",
|
||||||
style(format!("{} of the 5 items processed", i))
|
style(format!("{} of the 5 items processed", i))
|
||||||
@ -30,15 +30,19 @@ fn print_wait_screen() {
|
|||||||
// 1 second delay
|
// 1 second delay
|
||||||
thread::sleep(time::Duration::from_secs(1));
|
thread::sleep(time::Duration::from_secs(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// print wait screen on alternate screen, then switch back.
|
/// print wait screen on alternate screen, then switch back.
|
||||||
pub fn print_wait_screen_on_alternate_window() {
|
pub fn print_wait_screen_on_alternate_window() -> io::Result<()> {
|
||||||
if let Ok(alternate) = AlternateScreen::to_alternate(false) {
|
if let Ok(_alternate) = AlternateScreen::to_alternate(false) {
|
||||||
print_wait_screen();
|
print_wait_screen()?;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
print_wait_screen_on_alternate_window();
|
print_wait_screen_on_alternate_window().unwrap();
|
||||||
}
|
}
|
||||||
|
@ -5,13 +5,16 @@
|
|||||||
extern crate crossterm_cursor;
|
extern crate crossterm_cursor;
|
||||||
|
|
||||||
use crossterm_cursor::cursor;
|
use crossterm_cursor::cursor;
|
||||||
|
use std::io;
|
||||||
|
|
||||||
/// Set the cursor to position X: 10, Y: 5 in the terminal.
|
/// Set the cursor to position X: 10, Y: 5 in the terminal.
|
||||||
pub fn goto() {
|
pub fn goto() -> io::Result<()> {
|
||||||
// Get the cursor
|
// Get the cursor
|
||||||
let cursor = cursor();
|
let cursor = cursor();
|
||||||
// Set the cursor to position X: 10, Y: 5 in the terminal
|
// Set the cursor to position X: 10, Y: 5 in the terminal
|
||||||
cursor.goto(10, 5);
|
cursor.goto(10, 5)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// get the cursor position
|
/// get the cursor position
|
||||||
@ -48,44 +51,46 @@ pub fn move_down() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Save and reset cursor position | demonstration..
|
/// Save and reset cursor position | demonstration..
|
||||||
pub fn save_and_reset_position() {
|
pub fn save_and_reset_position() -> io::Result<()> {
|
||||||
let cursor = cursor();
|
let cursor = cursor();
|
||||||
|
|
||||||
// Goto X: 5 Y: 5
|
// Goto X: 5 Y: 5
|
||||||
cursor.goto(5, 5);
|
cursor.goto(5, 5)?;
|
||||||
// Safe cursor position: X: 5 Y: 5
|
// Safe cursor position: X: 5 Y: 5
|
||||||
cursor.save_position();
|
cursor.save_position()?;
|
||||||
// Goto X: 5 Y: 20
|
// Goto X: 5 Y: 20
|
||||||
cursor.goto(5, 20);
|
cursor.goto(5, 20)?;
|
||||||
// Print at X: 5 Y: 20.
|
// Print at X: 5 Y: 20.
|
||||||
println!("Yea!");
|
println!("Yea!");
|
||||||
// Reset back to X: 5 Y: 5.
|
// Reset back to X: 5 Y: 5.
|
||||||
cursor.reset_position();
|
cursor.reset_position()?;
|
||||||
// Print Back at X: 5 Y: 5.
|
// Print Back at X: 5 Y: 5.
|
||||||
println!("Back");
|
println!("Back");
|
||||||
|
|
||||||
println!()
|
println!();
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Hide cursor display | demonstration.
|
/// Hide cursor display | demonstration.
|
||||||
pub fn hide_cursor() {
|
pub fn hide_cursor() {
|
||||||
let cursor = cursor();
|
let cursor = cursor();
|
||||||
cursor.hide();
|
cursor.hide().unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Show cursor display | demonstration.
|
/// Show cursor display | demonstration.
|
||||||
pub fn show_cursor() {
|
pub fn show_cursor() {
|
||||||
let cursor = cursor();
|
let cursor = cursor();
|
||||||
cursor.show();
|
cursor.show().unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Show cursor display, only works on certain terminals.| demonstration
|
/// Show cursor display, only works on certain terminals.| demonstration
|
||||||
pub fn blink_cursor() {
|
pub fn blink_cursor() {
|
||||||
let cursor = cursor();
|
let cursor = cursor();
|
||||||
cursor.blink(false);
|
cursor.blink(false).unwrap();
|
||||||
cursor.blink(false);
|
cursor.blink(false).unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
save_and_reset_position();
|
save_and_reset_position().unwrap();
|
||||||
}
|
}
|
||||||
|
@ -1,30 +1,30 @@
|
|||||||
extern crate crossterm;
|
extern crate crossterm;
|
||||||
|
|
||||||
use crossterm::{style, terminal, AlternateScreen, ClearType, Color, Crossterm, RawScreen};
|
use crossterm::{style, AlternateScreen, ClearType, Color, Crossterm};
|
||||||
|
|
||||||
use std::io::{stdout, Write};
|
use std::io::{self, stdout, Write};
|
||||||
use std::{thread, time};
|
use std::{thread, time};
|
||||||
|
|
||||||
fn print_wait_screen() {
|
fn print_wait_screen() -> io::Result<()> {
|
||||||
let crossterm = Crossterm::new();
|
let crossterm = Crossterm::new();
|
||||||
let terminal = crossterm.terminal();
|
let terminal = crossterm.terminal();
|
||||||
let cursor = crossterm.cursor();
|
let cursor = crossterm.cursor();
|
||||||
|
|
||||||
terminal.clear(ClearType::All);
|
terminal.clear(ClearType::All)?;
|
||||||
|
|
||||||
cursor.hide();
|
cursor.hide()?;
|
||||||
cursor.goto(0, 0);
|
cursor.goto(0, 0)?;
|
||||||
println!("Welcome to the wait screen.");
|
println!("Welcome to the wait screen.");
|
||||||
cursor.goto(0, 1);
|
cursor.goto(0, 1)?;
|
||||||
println!("Please wait a few seconds until we arrive back at the main screen.");
|
println!("Please wait a few seconds until we arrive back at the main screen.");
|
||||||
cursor.goto(0, 2);
|
cursor.goto(0, 2)?;
|
||||||
println!("Progress:");
|
println!("Progress:");
|
||||||
cursor.goto(0, 3);
|
cursor.goto(0, 3)?;
|
||||||
|
|
||||||
// print some progress example.
|
// print some progress example.
|
||||||
for i in 1..5 {
|
for i in 1..5 {
|
||||||
// print the current counter at the line of `Seconds to Go: {counter}`
|
// print the current counter at the line of `Seconds to Go: {counter}`
|
||||||
cursor.goto(10, 2);
|
cursor.goto(10, 2)?;
|
||||||
print!(
|
print!(
|
||||||
"{}",
|
"{}",
|
||||||
style(format!("{} of the 5 items processed", i))
|
style(format!("{} of the 5 items processed", i))
|
||||||
@ -32,20 +32,24 @@ fn print_wait_screen() {
|
|||||||
.on(Color::Blue)
|
.on(Color::Blue)
|
||||||
);
|
);
|
||||||
|
|
||||||
stdout().flush();
|
stdout().flush()?;
|
||||||
|
|
||||||
// 1 second delay
|
// 1 second delay
|
||||||
thread::sleep(time::Duration::from_secs(1));
|
thread::sleep(time::Duration::from_secs(1));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn print_wait_screen_on_alternate_window() {
|
pub fn print_wait_screen_on_alternate_window() -> io::Result<()> {
|
||||||
// by passing in 'true' the alternate screen will be in raw modes.
|
// by passing in 'true' the alternate screen will be in raw modes.
|
||||||
if let Ok(alternate) = AlternateScreen::to_alternate(true) {
|
if let Ok(_alternate) = AlternateScreen::to_alternate(true) {
|
||||||
print_wait_screen();
|
print_wait_screen()?;
|
||||||
} // <- drop alternate screen; this will cause the alternate screen to drop.
|
} // <- drop alternate screen; this will cause the alternate screen to drop.
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
print_wait_screen_on_alternate_window();
|
print_wait_screen_on_alternate_window().unwrap();
|
||||||
}
|
}
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
//!
|
//!
|
||||||
extern crate crossterm;
|
extern crate crossterm;
|
||||||
|
|
||||||
use self::crossterm::{color, style, Attribute, Color, Colored, Colorize, Styler};
|
use self::crossterm::{color, Attribute, Color, Colored, Colorize, Styler};
|
||||||
|
|
||||||
/// print some red font | demonstration.
|
/// print some red font | demonstration.
|
||||||
pub fn paint_foreground() {
|
pub fn paint_foreground() {
|
||||||
|
@ -5,6 +5,7 @@
|
|||||||
extern crate crossterm;
|
extern crate crossterm;
|
||||||
|
|
||||||
use crossterm::{cursor, terminal, ClearType};
|
use crossterm::{cursor, terminal, ClearType};
|
||||||
|
use std::io;
|
||||||
|
|
||||||
fn print_test_data() {
|
fn print_test_data() {
|
||||||
for i in 0..100 {
|
for i in 0..100 {
|
||||||
@ -13,65 +14,75 @@ fn print_test_data() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Clear all lines in terminal | demonstration
|
/// Clear all lines in terminal | demonstration
|
||||||
pub fn clear_all_lines() {
|
pub fn clear_all_lines() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Clear all lines in terminal;
|
// Clear all lines in terminal;
|
||||||
terminal.clear(ClearType::All);
|
terminal.clear(ClearType::All)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Clear all lines from cursor position X:4, Y:4 down | demonstration
|
/// Clear all lines from cursor position X:4, Y:4 down | demonstration
|
||||||
pub fn clear_from_cursor_down() {
|
pub fn clear_from_cursor_down() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Set terminal cursor position (see example for more info).
|
// Set terminal cursor position (see example for more info).
|
||||||
cursor().goto(4, 8);
|
cursor().goto(4, 8)?;
|
||||||
|
|
||||||
// Clear all cells from current cursor position down.
|
// Clear all cells from current cursor position down.
|
||||||
terminal.clear(ClearType::FromCursorDown);
|
terminal.clear(ClearType::FromCursorDown)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Clear all lines from cursor position X:4, Y:4 up | demonstration
|
/// Clear all lines from cursor position X:4, Y:4 up | demonstration
|
||||||
pub fn clear_from_cursor_up() {
|
pub fn clear_from_cursor_up() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Set terminal cursor position (see example for more info).
|
// Set terminal cursor position (see example for more info).
|
||||||
cursor().goto(4, 4);
|
cursor().goto(4, 4)?;
|
||||||
|
|
||||||
// Clear all cells from current cursor position down.
|
// Clear all cells from current cursor position down.
|
||||||
terminal.clear(ClearType::FromCursorUp);
|
terminal.clear(ClearType::FromCursorUp)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Clear all lines from cursor position X:4, Y:4 up | demonstration
|
/// Clear all lines from cursor position X:4, Y:4 up | demonstration
|
||||||
pub fn clear_current_line() {
|
pub fn clear_current_line() -> io::Result<()>{
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Set terminal cursor position (see example for more info).
|
// Set terminal cursor position (see example for more info).
|
||||||
cursor().goto(4, 3);
|
cursor().goto(4, 3)?;
|
||||||
|
|
||||||
// Clear current line cells.
|
// Clear current line cells.
|
||||||
terminal.clear(ClearType::CurrentLine);
|
terminal.clear(ClearType::CurrentLine)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Clear all lines from cursor position X:4, Y:7 up | demonstration
|
/// Clear all lines from cursor position X:4, Y:7 up | demonstration
|
||||||
pub fn clear_until_new_line() {
|
pub fn clear_until_new_line() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Set terminal cursor position (see example for more info).
|
// Set terminal cursor position (see example for more info).
|
||||||
cursor().goto(4, 20);
|
cursor().goto(4, 20)?;
|
||||||
|
|
||||||
// Clear all the cells until next line.
|
// Clear all the cells until next line.
|
||||||
terminal.clear(ClearType::UntilNewLine);
|
terminal.clear(ClearType::UntilNewLine)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Print the the current terminal size | demonstration.
|
/// Print the the current terminal size | demonstration.
|
||||||
@ -86,38 +97,46 @@ pub fn print_terminal_size() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// Set the terminal size to width 10, height: 10 | demonstration.
|
/// Set the terminal size to width 10, height: 10 | demonstration.
|
||||||
pub fn set_terminal_size() {
|
pub fn set_terminal_size() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
terminal.set_size(10, 10);
|
terminal.set_size(10, 10)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Scroll down 10 lines | demonstration.
|
/// Scroll down 10 lines | demonstration.
|
||||||
pub fn scroll_down() {
|
pub fn scroll_down() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Scroll down 10 lines.
|
// Scroll down 10 lines.
|
||||||
terminal.scroll_down(10);
|
terminal.scroll_down(10)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Scroll down 10 lines | demonstration.
|
/// Scroll down 10 lines | demonstration.
|
||||||
pub fn scroll_up() {
|
pub fn scroll_up() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
print_test_data();
|
print_test_data();
|
||||||
|
|
||||||
// Scroll up 10 lines.
|
// Scroll up 10 lines.
|
||||||
terminal.scroll_up(5);
|
terminal.scroll_up(5)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Resize the terminal to X: 10, Y: 10 | demonstration.
|
/// Resize the terminal to X: 10, Y: 10 | demonstration.
|
||||||
pub fn resize_terminal() {
|
pub fn resize_terminal() -> io::Result<()> {
|
||||||
let terminal = terminal();
|
let terminal = terminal();
|
||||||
|
|
||||||
// Get terminal size
|
// Get terminal size
|
||||||
terminal.set_size(10, 10);
|
terminal.set_size(10, 10)?;
|
||||||
|
|
||||||
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
/// exit the current proccess.
|
/// exit the current proccess.
|
||||||
|
@ -21,7 +21,7 @@ use std::fmt::Display;
|
|||||||
/// - checkout the crossterm book for more information about feature flags or alternate screen.
|
/// - checkout the crossterm book for more information about feature flags or alternate screen.
|
||||||
pub struct Crossterm;
|
pub struct Crossterm;
|
||||||
|
|
||||||
impl<'crossterm> Crossterm {
|
impl Crossterm {
|
||||||
/// Create a new instance of `Crossterm`
|
/// Create a new instance of `Crossterm`
|
||||||
pub fn new() -> Crossterm {
|
pub fn new() -> Crossterm {
|
||||||
Crossterm
|
Crossterm
|
||||||
|
Loading…
Reference in New Issue
Block a user