2018-01-18 09:06:45 +11:00
# Crossterm | crossplatform terminal library written in rust.
2018-01-28 05:53:39 +11:00
Ever got disappointed when a terminal library for rust was only written for unix systems? Crossterm provides the same core functionalities for both windows and unix systems.
2018-01-18 09:06:45 +11:00
2018-01-28 05:53:39 +11:00
Crossterm aims to be simple and easy to call in code. True the simplicity of crossterm you do not have to worry about the platform your working with. You can just call the action you want to preform and unther water it will check what to do based on the current platform.
2018-01-18 09:06:45 +11:00
2018-03-13 21:05:13 +11:00
Currently working on the alternatescreen and raw terminal features.
2018-03-03 00:07:29 +11:00
2018-01-18 09:06:45 +11:00
## Getting Started
2018-05-20 22:39:05 +10:00
This documentation is only for the newest version of crossterm. See the [Upgrade manual for more info ](https://github.com/TimonPost/crossterm/blob/development/UPGRADE%20Manual )
2018-01-18 09:06:45 +11:00
Add the crossterm package to your `Cargo.toml` file.
```
[dependencies]
crossterm = "*"
```
Add the crate to your solution.
And use the crossterm modules withs you want to use.
2018-01-19 08:47:09 +11:00
```rust
2018-01-18 09:06:45 +11:00
extern crate crossterm;
// this module is used for styling the terminal
2018-05-20 22:39:05 +10:00
use self::crossterm::style::*;
2018-01-18 09:06:45 +11:00
// this module is used for cursor related actions
2018-05-20 22:39:05 +10:00
use self::crossterm::cursor::*;
2018-01-18 09:06:45 +11:00
// this mudule is used for terminal related actions
2018-05-20 22:39:05 +10:00
use self::crossterm::terminal::*;
2018-01-18 09:06:45 +11:00
```
2018-01-26 08:38:28 +11:00
## Links
2018-01-18 09:06:45 +11:00
2018-05-20 22:39:05 +10:00
Documentation for the code version 0.1 can be found [here ](https://docs.rs/crossterm/0.1.0/crossterm/ )
2018-02-16 03:04:05 +11:00
2018-05-20 22:39:05 +10:00
Documentation for the code version 0.2 can be found [here ](https://docs.rs/crossterm/0.2.0/crossterm/ )
2018-01-26 08:39:08 +11:00
2018-01-26 08:38:28 +11:00
The Cargo Page can be found [here ](https://crates.io/search?q=crossterm )
2018-01-18 09:06:45 +11:00
## Examples
2018-01-19 08:47:09 +11:00
For detailed examples of all crossterm functionalities check the [examples ](https://github.com/TimonPost/crossterm/tree/master/examples ) direcory.
2018-01-18 09:06:45 +11:00
### Styled font
2018-01-18 18:31:13 +11:00
```rust
2018-05-20 22:39:05 +10:00
use crossterm::style::{paint, Color};
2018-01-18 18:31:13 +11:00
2018-01-18 21:52:24 +11:00
// Crossterm provides method chaining so that you can style the font nicely.
2018-01-28 05:53:39 +11:00
// the `with()` methods sets the foreground color and the `on()` methods sets the background color
2018-01-18 21:52:24 +11:00
// You can either store the styled font.
let mut styledobject = paint("Stored styled font").with(Color::Red).on(Color::Blue);
println!("{}",styledobject);
// Or you can print it directly.
println!("{}", paint("Red font on blue background color").with(Color::Red).on(Color::Blue));
2018-01-18 18:31:13 +11:00
println!("{}", paint("Red font on default background color").with(Color::Red));
2018-01-18 22:39:52 +11:00
println!("{}", paint("Default font color on Blue background color").on(Color::Blue));
2018-01-28 05:53:39 +11:00
/// The following code can only be used for unix systems:
// Set background Color from RGB
println!("RGB (10,10,10): \t {}", paint(" ").on(Color::Rgb {r: 10, g: 10, b: 10}));
// Set background Color from RGB
2018-01-28 05:59:33 +11:00
println!("ANSI value (50): \t {}", paint(" ").on(Color::AnsiValue(50)));
2018-01-28 05:53:39 +11:00
// Use attributes to syle the font.
println!("{}", paint("Normal text"));
println!("{}", paint("Bold text").bold());
println!("{}", paint("Italic text").italic());
println!("{}", paint("Slow blinking text").slow_blink());
println!("{}", paint("Rapid blinking text").rapid_blink());
println!("{}", paint("Hidden text").hidden());
println!("{}", paint("Underlined text").underlined());
println!("{}", paint("Reversed color").reverse());
println!("{}", paint("Dim text color").dim());
println!("{}", paint("Crossed out font").crossed_out());
2018-01-18 09:06:45 +11:00
```
### Cursor
2018-01-18 21:52:24 +11:00
```rust
2018-01-19 08:47:09 +11:00
2018-05-20 22:39:05 +10:00
use crossterm::cursor::cursor();
2018-01-18 21:52:24 +11:00
2018-05-20 22:39:05 +10:00
let mut cursor = cursor();
2018-01-18 21:52:24 +11:00
2018-01-28 05:53:39 +11:00
/// Moving the cursor
2018-01-19 08:47:09 +11:00
// Set the cursor to position X: 10, Y: 5 in the terminal
cursor.goto(10,5);
2018-01-18 21:52:24 +11:00
2018-01-19 08:47:09 +11:00
// Move the cursor to position 3 times to the up in the terminal
cursor.move_up(3);
2018-01-18 21:52:24 +11:00
// Move the cursor to position 3 times to the right in the terminal
2018-01-19 08:47:09 +11:00
cursor.move_right(3);
2018-01-18 21:52:24 +11:00
2018-01-19 08:47:09 +11:00
// Move the cursor to position 3 times to the down in the terminal
cursor.move_down(3);
2018-01-18 21:52:24 +11:00
// Move the cursor to position 3 times to the left in the terminal
2018-01-19 08:47:09 +11:00
cursor.move_left(3);
2018-01-18 21:52:24 +11:00
2018-01-19 08:47:09 +11:00
// Print an character at X: 10, Y: 5 (see examples for more explanation why to use this method).
2018-01-28 05:53:39 +11:00
// cursor.goto(10,5).print("@");
/// Safe the current cursor position to recall later
// Goto X: 5 Y: 5
cursor.goto(5,5);
// Safe cursor position: X: 5 Y: 5
cursor.safe_position();
// Goto X: 5 Y: 20
cursor.goto(5,20);
// Print at X: 5 Y: 20.
print!("Yea!");
// Reset back to X: 5 Y: 5.
cursor.reset_position();
// Print 'Back' at X: 5 Y: 5.
print!("Back");
2018-01-18 21:52:24 +11:00
```
2018-01-18 09:06:45 +11:00
### Terminal
2018-01-18 21:52:24 +11:00
```rust
2018-05-20 22:39:05 +10:00
use crossterm::terminal::{terminal,ClearType};
2018-01-19 08:47:09 +11:00
2018-05-20 22:39:05 +10:00
let mut terminal = terminal();
2018-01-19 08:47:09 +11:00
// Clear all lines in terminal;
terminal.clear(ClearType::All);
// Clear all cells from current cursor position down.
terminal.clear(ClearType::FromCursorDown);
// Clear all cells from current cursor position down.
terminal.clear(ClearType::FromCursorUp);
// Clear current line cells.
terminal.clear(ClearType::CurrentLine);
// Clear all the cells until next line.
terminal.clear(ClearType::UntilNewLine);
// Get terminal size
let terminal_size = terminal.terminal_size().unwrap();
// Print results
print!("X: {}, y: {}", terminal_size.0, terminal_size.1);
// Scroll down 10 lines.
terminal.scroll_down(10);
// Scroll up 10 lines.
terminal.scroll_up(10);
2018-01-28 05:53:39 +11:00
// Set terminal size
terminal.set_size(10,10);
2018-01-18 21:52:24 +11:00
```
2018-01-18 09:06:45 +11:00
## Features crossterm 0.1
- Cursor movement.
- Up, Down, Left, Right.
- Goto an certain position.
- Styled output
- Foreground color (16 base colors)
- Background color (16 base colors)
- Terminal
- Clearing
- Scrolling
- Size
- Detailed documentation on every item.
2018-01-18 22:39:52 +11:00
- Examples for every client callable code.
2018-01-18 09:06:45 +11:00
2018-01-28 05:53:39 +11:00
## Features crossterm 0.2
2018-01-28 05:58:06 +11:00
- 256 color support.
- Text Attributes like: bold, italic, underscore and crossed word ect.
- Custom ANSI color code input to set fore- and background color for unix.
- Storing the current cursor position and resetting to that stored cursor position later.
2018-01-28 05:53:39 +11:00
- Resizing the terminal.
2018-05-20 22:39:05 +10:00
### fixes in crossterm 0.2.1
2018-02-11 04:46:12 +11:00
- Default ANSI escape codes for windows machines, if windows does not support ANSI switsh back to WINAPI.
2018-05-20 22:52:20 +10:00
- method grammer mistake fixed [Issue 3 ](https://github.com/TimonPost/crossterm/issues/3 )
2018-02-11 04:46:12 +11:00
- Some Refactorings in method names see [issue 4 ](https://github.com/TimonPost/crossterm/issues/4 )
2018-05-20 22:52:20 +10:00
- Removed bin refrence from crate [Issue 6 ](https://github.com/TimonPost/crossterm/issues/6 )
- The terminal state will be set to its original state when process ends [issue7 ](https://github.com/TimonPost/crossterm/issues/7 ).
- Get position unix fixed [issue 8 ](https://github.com/TimonPost/crossterm/issues/8 )
2018-05-20 22:39:05 +10:00
2018-05-20 22:52:20 +10:00
## TODO Features crossterm 0.3
- Raw state implementation [Issue 5 ](https://github.com/TimonPost/crossterm/issues/5 ).
- Alternate screen implementation.
- Tests
2018-02-11 04:44:35 +11:00
2018-01-18 09:06:45 +11:00
## Tested terminals
- Windows Powershell
- Windows 10 (pro)
- Windows CMD
- Windows 10 (pro)
- Ubuntu Desktop Terminal
- Ubuntu 17.10
2018-01-18 22:39:52 +11:00
The above terminals have been tested. Crossterm should works also for windows 7, 8 consoles and all ansi supportable consoles.
But these are yet to be tested.
2018-01-18 09:06:45 +11:00
If you have used this library for an terminal other than the above list without issues feel free to add it to the above list.
2018-01-28 05:53:39 +11:00
## How it works
Crossterm is using `WINAPI` for windows systems and `ANSI escape codes` for unix systems. Crossterm provides one base trait with can be implemented for a platform specific instance. For example, there is an implementation for windows (`WINAPI`) and unix(`ANSI`) for the `cursor module` . To call the platform specific implementation there is one module that rules them all. Thrue this module the client calls some action and the module will deside what to do based on the current platform. And it will execute that action.
2018-01-18 09:06:45 +11:00
## Notice
2018-01-28 05:53:39 +11:00
This library is library is stable. There will not be changed mutch in the code design so do not worry to mutch. If there are any changes that affect previous versions I will describe what to change when upgrading crossterm to an newer version.
2018-01-18 09:06:45 +11:00
2018-01-28 05:53:39 +11:00
## Todo
2018-01-18 09:06:45 +11:00
2018-01-30 07:52:11 +11:00
- This library does not support any kind of raw terminal. When an terminal changes some core state of the terminal this state should be revered when the process ends from this library. Currently there are not made any changed to the core state of the terminal with this library. But when some fearures in the furure will be inplemented this will be the case. So there should come an kind of raw state for the terminal and reversable options to redo all the changes made to the core state when the process ends. More information can be found at this [thread ](https://www.reddit.com/r/rust/comments/7tg6n2/looking_for_feedback_onmy_cross_platform_terminal/dtf4ilo/ )
2018-01-18 09:06:45 +11:00
- Handling mouse events
- Handling key events
- Tests
## Contributing
2018-01-18 22:39:52 +11:00
If you would like to contribute to crossterm, than please design the code as it is now. Each module contains the same structures so we can easely extend to multible platforms. As you study the code you will quiqly see what the architecture is. Maybe later there will be an documentation for how crossterm is design.
2018-01-18 09:06:45 +11:00
## Versioning
2018-01-18 22:39:52 +11:00
The current version is crossterm 0.1, every commit I merge the version go's up like 0.1.0 -> 0.1.1 -> 0.1.2.
2018-01-18 09:06:45 +11:00
2018-01-18 22:39:52 +11:00
When new features arrives the packages will go up like 0.1 -> 0.2 -> 0.3
2018-01-18 09:06:45 +11:00
## Authors
2018-01-18 22:39:52 +11:00
* **Timon Post** - *Project Owner & creator*
2018-01-18 09:06:45 +11:00
## License
This project is licensed under the MIT License - see the [LICENSE.md ](LICENSE.md ) file for details
2018-01-08 01:32:30 +11:00