Created better documentation and formatted code
This commit is contained in:
parent
37670c7fbb
commit
8b5d34c866
@ -25,7 +25,25 @@ fn main() {
|
|||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
terminal::get().clear(ClearType::UntilNewLine);
|
let mut terminal = terminal::get();
|
||||||
|
|
||||||
|
// clear all cells in terminal.
|
||||||
|
terminal.clear(ClearType::All);
|
||||||
|
// clear all cells after the cursor position in terminal.
|
||||||
|
terminal.clear(ClearType::AfterCursor);
|
||||||
|
// clear all cells before cursor in terminal.
|
||||||
|
terminal.clear(ClearType::BeforeCursor);
|
||||||
|
// clear current line cells in terminal.
|
||||||
|
terminal.clear(ClearType::CurrentLine);
|
||||||
|
// clear all cells until new line in terminal.
|
||||||
|
terminal.clear(ClearType::UntilNewLine);
|
||||||
|
|
||||||
|
let size = terminal.terminal_size();
|
||||||
|
println!("{:?}", size);
|
||||||
|
|
||||||
|
// scrolling in terminal
|
||||||
|
terminal.scroll_up(1);
|
||||||
|
terminal.scroll_down();
|
||||||
|
|
||||||
cursor::get().goto(0,30);
|
cursor::get().goto(0,30);
|
||||||
}
|
}
|
||||||
|
0
examples/color/examples.rs
Normal file
0
examples/color/examples.rs
Normal file
24
examples/terminal/examples.rs
Normal file
24
examples/terminal/examples.rs
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
fn main()
|
||||||
|
{
|
||||||
|
let mut terminal = terminal::get();
|
||||||
|
|
||||||
|
// clear all cells in terminal.
|
||||||
|
terminal.clear(ClearType::All);
|
||||||
|
// clear all cells after the cursor position in terminal.
|
||||||
|
terminal.clear(ClearType::AfterCursor);
|
||||||
|
// clear all cells before cursor in terminal.
|
||||||
|
terminal.clear(ClearType::BeforeCursor);
|
||||||
|
// clear current line cells in terminal.
|
||||||
|
terminal.clear(ClearType::CurrentLine);
|
||||||
|
// clear all cells until new line in terminal.
|
||||||
|
terminal.clear(ClearType::UntilNewLine);
|
||||||
|
|
||||||
|
// get terminal size (x,y)
|
||||||
|
let size = terminal.terminal_size();
|
||||||
|
println!("{:?}", size);
|
||||||
|
|
||||||
|
// scrolling in terminal
|
||||||
|
terminal.scroll_up();
|
||||||
|
terminal.scroll_down();
|
||||||
|
|
||||||
|
}
|
@ -20,7 +20,7 @@ pub fn terminal_size() -> Option<(u16, u16)> {
|
|||||||
let mut winsize: libc::winsize = mem::zeroed();
|
let mut winsize: libc::winsize = mem::zeroed();
|
||||||
libc::ioctl(libc::STDOUT_FILENO, libc::TIOCGWINSZ, &mut winsize);
|
libc::ioctl(libc::STDOUT_FILENO, libc::TIOCGWINSZ, &mut winsize);
|
||||||
if winsize.ws_row > 0 && winsize.ws_col > 0 {
|
if winsize.ws_row > 0 && winsize.ws_col > 0 {
|
||||||
Some((winsize.ws_row as u16, winsize.ws_col as u16))
|
Some((winsize.ws_col as u16, winsize.ws_row as u16))
|
||||||
} else {
|
} else {
|
||||||
None
|
None
|
||||||
}
|
}
|
||||||
|
@ -7,8 +7,8 @@ pub fn terminal_size() -> Option<(u16, u16)> {
|
|||||||
let csbi = kernel::get_console_screen_buffer_info();
|
let csbi = kernel::get_console_screen_buffer_info();
|
||||||
|
|
||||||
Some((
|
Some((
|
||||||
(csbi.srWindow.Bottom - csbi.srWindow.Top) as u16,
|
|
||||||
(csbi.srWindow.Right - csbi.srWindow.Left) as u16,
|
(csbi.srWindow.Right - csbi.srWindow.Left) as u16,
|
||||||
|
(csbi.srWindow.Bottom - csbi.srWindow.Top) as u16,
|
||||||
))
|
))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -15,6 +15,26 @@ impl Terminal {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Clear the current cursor by specifying the clear type
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// let mut terminal = terminal::get();
|
||||||
|
///
|
||||||
|
/// // clear all cells in terminal.
|
||||||
|
/// terminal.clear(ClearType::All);
|
||||||
|
/// //clear all cells after the cursor position in terminal.
|
||||||
|
/// terminal.clear(ClearType::AfterCursor);
|
||||||
|
/// // clear all cells before cursor in terminal.
|
||||||
|
/// terminal.clear(ClearType::BeforeCursor);
|
||||||
|
/// // clear current line cells in terminal.
|
||||||
|
/// terminal.clear(ClearType::CurrentLine);
|
||||||
|
/// // clear all cells from cursor position until new line in terminal.
|
||||||
|
/// terminal.clear(ClearType::UntilNewLine);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn clear(&mut self, clear_type: ClearType) {
|
pub fn clear(&mut self, clear_type: ClearType) {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal) = self.terminal {
|
if let Some(ref terminal) = self.terminal {
|
||||||
@ -22,6 +42,18 @@ impl Terminal {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Get the terminal size (x,y).
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// let mut terminal = terminal::get();
|
||||||
|
///
|
||||||
|
/// let size = terminal.terminal_size();
|
||||||
|
/// println!("{:?}", size);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn terminal_size(&mut self) -> Option<(u16, u16)> {
|
pub fn terminal_size(&mut self) -> Option<(u16, u16)> {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal) = self.terminal {
|
if let Some(ref terminal) = self.terminal {
|
||||||
@ -32,6 +64,7 @@ impl Terminal {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Scroll `n` lines up in the current terminal.
|
||||||
pub fn scroll_up(&mut self, count: i16) {
|
pub fn scroll_up(&mut self, count: i16) {
|
||||||
for i in 0..100 {
|
for i in 0..100 {
|
||||||
println!("Ik ben timon en dit is een test {}", i)
|
println!("Ik ben timon en dit is een test {}", i)
|
||||||
@ -43,6 +76,7 @@ impl Terminal {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Scroll `n` lines up in the current terminal.
|
||||||
pub fn scroll_down(&self) {}
|
pub fn scroll_down(&self) {}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3,36 +3,27 @@ use Construct;
|
|||||||
use super::base_cursor::ITerminalCursor;
|
use super::base_cursor::ITerminalCursor;
|
||||||
use super::{AnsiCursor, NoCursor, WinApiCursor};
|
use super::{AnsiCursor, NoCursor, WinApiCursor};
|
||||||
|
|
||||||
/// Struct with the cursor on wits cursor realated actions can be performed.
|
/// Struct on wits cursor realated actions can be performed.
|
||||||
pub struct TerminalCursor {
|
pub struct TerminalCursor {
|
||||||
terminal_cursor: Option<Box<ITerminalCursor>>,
|
terminal_cursor: Option<Box<ITerminalCursor>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
// impl Clone for TerminalCursor {
|
|
||||||
// fn clone(&self) -> TerminalCursor { *self }
|
|
||||||
// }
|
|
||||||
|
|
||||||
impl TerminalCursor {
|
impl TerminalCursor {
|
||||||
/// Instantiate an cursor implementation whereon cursor related actions can be performed.
|
/// Instantiates an platform specific cursor implementation whereon cursor related actions can be performed.
|
||||||
pub fn init(&mut self) {
|
pub fn init(&mut self) {
|
||||||
if let None = self.terminal_cursor {
|
if let None = self.terminal_cursor {
|
||||||
self.terminal_cursor = get_cursor_options();
|
self.terminal_cursor = get_cursor_options();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Goto some location (x,y) in the terminal.
|
/// Goto some position (x,y) in the terminal.
|
||||||
///
|
///
|
||||||
/// #Example
|
/// #Example
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate crossterm;
|
|
||||||
///
|
///
|
||||||
/// use self::crossterm::terminal_cursor::{cursor,TerminalCursor};
|
|
||||||
|
|
||||||
/// fn main()
|
|
||||||
/// {
|
|
||||||
/// cursor::get().goto(10,10);
|
/// cursor::get().goto(10,10);
|
||||||
/// }
|
///
|
||||||
/// ```
|
/// ```
|
||||||
pub fn goto(&mut self, x: u16, y: u16) -> &mut TerminalCursor {
|
pub fn goto(&mut self, x: u16, y: u16) -> &mut TerminalCursor {
|
||||||
&self.init();
|
&self.init();
|
||||||
@ -42,7 +33,17 @@ impl TerminalCursor {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn pos(mut self) -> (i16, i16) {
|
/// Get current cursor position (x,y) in the terminal.
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// let pos = cursor::get().pos();
|
||||||
|
/// println!("{:?}", pos);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
|
pub fn pos(&mut self) -> (i16, i16) {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
||||||
terminal_cursor.pos()
|
terminal_cursor.pos()
|
||||||
@ -51,24 +52,17 @@ impl TerminalCursor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Print an value at the current cursor location.
|
/// Move the current cursor position `n` times up.
|
||||||
///
|
///
|
||||||
/// #Example
|
/// #Example
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate crossterm;
|
|
||||||
///
|
///
|
||||||
/// use self::crossterm::terminal_cursor::{cursor,TerminalCursor};
|
/// // move 1 time up
|
||||||
|
/// cursor::get().move_up(1);
|
||||||
/// fn main()
|
///
|
||||||
/// {
|
/// // move 2 time up
|
||||||
/// // of course we can just do this.
|
/// cursor::get().move_up(2); ///
|
||||||
/// print!("@").
|
|
||||||
/// // but now we can chain the methods so it looks cleaner.
|
|
||||||
/// cursor::get()
|
|
||||||
/// .goto(10,10)
|
|
||||||
/// .print("@");
|
|
||||||
/// }
|
|
||||||
/// ```
|
/// ```
|
||||||
pub fn move_up(&mut self, count: u16) -> &mut TerminalCursor {
|
pub fn move_up(&mut self, count: u16) -> &mut TerminalCursor {
|
||||||
&self.init();
|
&self.init();
|
||||||
@ -78,6 +72,19 @@ impl TerminalCursor {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Move the current cursor position `n` times right.
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// // move 1 time right
|
||||||
|
/// cursor::get().move_right(1);
|
||||||
|
///
|
||||||
|
/// // move 2 time right
|
||||||
|
/// cursor::get().move_right(2);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn move_right(&mut self, count: u16) -> &mut TerminalCursor {
|
pub fn move_right(&mut self, count: u16) -> &mut TerminalCursor {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
||||||
@ -86,6 +93,19 @@ impl TerminalCursor {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Move the current cursor position `n` times down.
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// // move 1 time down
|
||||||
|
/// cursor::get().move_down(1);
|
||||||
|
///
|
||||||
|
/// // move 2 time down
|
||||||
|
/// cursor::get().move_down(2);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn move_down(&mut self, count: u16) -> &mut TerminalCursor {
|
pub fn move_down(&mut self, count: u16) -> &mut TerminalCursor {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
||||||
@ -94,6 +114,19 @@ impl TerminalCursor {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Move the current cursor position `n` times left.
|
||||||
|
///
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// // move 1 time left
|
||||||
|
/// cursor::get().move_left(1);
|
||||||
|
///
|
||||||
|
/// // move 2 time left
|
||||||
|
/// cursor::get().move_left(2);
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn move_left(&mut self, count: u16) -> &mut TerminalCursor {
|
pub fn move_left(&mut self, count: u16) -> &mut TerminalCursor {
|
||||||
&self.init();
|
&self.init();
|
||||||
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
if let Some(ref terminal_cursor) = self.terminal_cursor {
|
||||||
@ -102,10 +135,30 @@ impl TerminalCursor {
|
|||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Print an value at the current cursor position.
|
||||||
|
///
|
||||||
|
/// This method prints an value and clears the buffer.
|
||||||
|
/// If you do not clear the buffer the character will not be printed at the wished position.
|
||||||
|
/// #Example
|
||||||
|
///
|
||||||
|
/// ```rust
|
||||||
|
///
|
||||||
|
/// // of course we can just do this.
|
||||||
|
/// cursor::get().goto(10,10);
|
||||||
|
/// print!("@");
|
||||||
|
/// std::io::stdout().flush();
|
||||||
|
///
|
||||||
|
/// // but now we can chain the methods so it looks cleaner and it automatically flushes the buffer.
|
||||||
|
/// cursor::get()
|
||||||
|
/// .goto(10,10)
|
||||||
|
/// .print("@");
|
||||||
|
///
|
||||||
|
/// ```
|
||||||
pub fn print<D: Display>(&mut self, value: D) -> &mut TerminalCursor {
|
pub fn print<D: Display>(&mut self, value: D) -> &mut TerminalCursor {
|
||||||
print!("{}", value);
|
print!("{}", value);
|
||||||
use std;
|
use std;
|
||||||
use std::io::Write;
|
use std::io::Write;
|
||||||
|
// rust is line buffered so we need to flush the buffer in order to print it at the current cursor position.
|
||||||
std::io::stdout().flush();
|
std::io::stdout().flush();
|
||||||
self
|
self
|
||||||
}
|
}
|
||||||
|
@ -41,34 +41,12 @@ pub enum ColorType {
|
|||||||
Foreground,
|
Foreground,
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Enables an user to pass in an color as str.
|
|
||||||
/// *Default color if cannot be parsed will be white.*
|
|
||||||
///
|
|
||||||
/// # Example
|
|
||||||
///
|
|
||||||
/// ``` rust
|
|
||||||
/// let fg_color = Color::from("red");
|
|
||||||
/// let bg_color = Color::from("blue");
|
|
||||||
///
|
|
||||||
/// println!("{}",paint("■").with(fg_color).on(bg_color));
|
|
||||||
/// ```
|
|
||||||
impl<'a> From<&'a str> for Color {
|
impl<'a> From<&'a str> for Color {
|
||||||
fn from(src: &str) -> Self {
|
fn from(src: &str) -> Self {
|
||||||
src.parse().unwrap_or(Color::White)
|
src.parse().unwrap_or(Color::White)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Enables an user to pass in an color as String.
|
|
||||||
/// *Default color if cannot be parsed will be white.*
|
|
||||||
///
|
|
||||||
/// # Example
|
|
||||||
///
|
|
||||||
/// ``` rust
|
|
||||||
/// let fg_color = Color::from(String::from("red"));
|
|
||||||
/// let bg_color = Color::from(String::from("blue"));
|
|
||||||
///
|
|
||||||
/// println!("{}",paint("■").with(fg_color).on(bg_color));
|
|
||||||
/// ```
|
|
||||||
impl From<String> for Color {
|
impl From<String> for Color {
|
||||||
fn from(src: String) -> Self {
|
fn from(src: String) -> Self {
|
||||||
src.parse().unwrap_or(Color::White)
|
src.parse().unwrap_or(Color::White)
|
||||||
@ -102,7 +80,7 @@ impl FromStr for Color {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Struct on wits the color realated actions can be performed.
|
/// Struct on wits color realated actions can be performed.
|
||||||
pub struct TerminalColor {
|
pub struct TerminalColor {
|
||||||
terminal_color: Option<Box<ITerminalColor>>,
|
terminal_color: Option<Box<ITerminalColor>>,
|
||||||
}
|
}
|
||||||
@ -149,7 +127,7 @@ impl TerminalColor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Reset the terminal colors to default.
|
/// Reset the terminal colors and attributes to default.
|
||||||
/// # Example
|
/// # Example
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
@ -166,7 +144,7 @@ impl TerminalColor {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get the concrete ITerminalColor implementation based on the current operating system.
|
/// Get an concrete ITerminalColor implementation based on the current operating system.
|
||||||
fn get_color_options() -> Option<Box<ITerminalColor>> {
|
fn get_color_options() -> Option<Box<ITerminalColor>> {
|
||||||
if cfg!(target_os = "linux") {
|
if cfg!(target_os = "linux") {
|
||||||
Some(ANSIColor::new())
|
Some(ANSIColor::new())
|
||||||
|
@ -18,7 +18,7 @@ impl Default for ObjectStyle {
|
|||||||
}
|
}
|
||||||
|
|
||||||
impl ObjectStyle {
|
impl ObjectStyle {
|
||||||
/// Get an `StyledObject` from the passed displayable object.
|
/// Apply an `StyledObject` to the passed displayable object.
|
||||||
pub fn apply_to<D>(&self, val: D) -> StyledObject<D>
|
pub fn apply_to<D>(&self, val: D) -> StyledObject<D>
|
||||||
where
|
where
|
||||||
D: Display,
|
D: Display,
|
||||||
@ -29,7 +29,7 @@ impl ObjectStyle {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Get an instance of `ObjectStyle`
|
/// Get an new instance of `ObjectStyle`
|
||||||
pub fn new() -> ObjectStyle {
|
pub fn new() -> ObjectStyle {
|
||||||
return ObjectStyle {
|
return ObjectStyle {
|
||||||
fg_color: None,
|
fg_color: None,
|
||||||
|
@ -16,23 +16,17 @@ impl<D> StyledObject<D> {
|
|||||||
/// #Example
|
/// #Example
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate crossterm;
|
|
||||||
///
|
|
||||||
/// use self::crossterm::terminal_style::{paint,Color};
|
|
||||||
///
|
|
||||||
/// fn main()
|
|
||||||
/// {
|
|
||||||
/// // create an styled object with the foreground color red.
|
/// // create an styled object with the foreground color red.
|
||||||
/// let styledobject = paint("I am colored red").with(Color::Red);
|
/// let styledobject = paint("I am colored red").with(Color::Red);
|
||||||
/// // create an styled object with the foreground color blue.
|
/// // create an styled object with the foreground color blue.
|
||||||
/// let styledobject1 = paint("I am colored blue").with(Color::Blue);
|
/// let styledobject1 = paint("I am colored blue").with(Color::Blue);
|
||||||
///
|
///
|
||||||
/// // print the styled objects
|
/// // print the styledobject to see the result
|
||||||
/// println!("{}", styledobject);
|
/// println!("{}", styledobject);
|
||||||
/// println!("{}", styledobject1);
|
/// println!("{}", styledobject1);
|
||||||
/// // or print an styled object directly.
|
/// // print an styled object directly.
|
||||||
/// println!("{}", paint("I am colored green").with(Color::Green))
|
/// println!("{}", paint("I am colored green").with(Color::Green));
|
||||||
/// }
|
///
|
||||||
/// ```
|
/// ```
|
||||||
pub fn with(mut self, foreground_color: Color) -> StyledObject<D> {
|
pub fn with(mut self, foreground_color: Color) -> StyledObject<D> {
|
||||||
self.object_style = self.object_style.fg(foreground_color);
|
self.object_style = self.object_style.fg(foreground_color);
|
||||||
@ -44,23 +38,18 @@ impl<D> StyledObject<D> {
|
|||||||
/// #Example
|
/// #Example
|
||||||
///
|
///
|
||||||
/// ```rust
|
/// ```rust
|
||||||
/// extern crate crossterm;
|
|
||||||
///
|
///
|
||||||
/// use self::crossterm::terminal_style::{paint,Color};
|
|
||||||
///
|
|
||||||
/// fn main()
|
|
||||||
/// {
|
|
||||||
/// // create an styled object with the background color red.
|
/// // create an styled object with the background color red.
|
||||||
/// let styledobject = paint("I am colored red").on(Color::Red);
|
/// let styledobject = paint("I am colored red").on(Color::Red);
|
||||||
/// // create an styled object with the background color blue.
|
/// // create an styled object with the background color blue.
|
||||||
/// let styledobject1 = paint("I am colored blue").on(Color::Blue);
|
/// let styledobject1 = paint("I am colored blue").on(Color::Blue);
|
||||||
///
|
///
|
||||||
/// // print the styled objects
|
/// // print the styledobjects
|
||||||
/// println!("{}", styledobject);
|
/// println!("{}", styledobject);
|
||||||
/// println!("{}", styledobject1);
|
/// println!("{}", styledobject1);
|
||||||
/// // or print an styled object directly.
|
/// // print an styled object directly.
|
||||||
/// println!("{}", paint("I am colored green").on(Color::Green))
|
/// println!("{}", paint("I am colored green").on(Color::Green))
|
||||||
/// }
|
///
|
||||||
/// ```
|
/// ```
|
||||||
pub fn on(mut self, background_color: Color) -> StyledObject<D> {
|
pub fn on(mut self, background_color: Color) -> StyledObject<D> {
|
||||||
self.object_style = self.object_style.bg(background_color);
|
self.object_style = self.object_style.bg(background_color);
|
||||||
@ -69,8 +58,7 @@ impl<D> StyledObject<D> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
/// This is used to make StyledObject able to be displayed.
|
/// This is used to make StyledObject able to be displayed.
|
||||||
/// This macro will set the styled stored in Styled Object
|
/// This macro will set the styles stored in Styled Object
|
||||||
|
|
||||||
macro_rules! impl_fmt
|
macro_rules! impl_fmt
|
||||||
{
|
{
|
||||||
($name:ident) => {
|
($name:ident) => {
|
||||||
@ -104,11 +92,5 @@ macro_rules! impl_fmt
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// This inplements Display for StyledObject
|
|
||||||
/// Notice that more implementations can be maked.
|
|
||||||
/// # Example
|
|
||||||
/// ```rust
|
|
||||||
/// example impl_fmt!(Debug);
|
|
||||||
/// ```
|
|
||||||
impl_fmt!(Debug);
|
impl_fmt!(Debug);
|
||||||
impl_fmt!(Display);
|
impl_fmt!(Display);
|
||||||
|
Loading…
Reference in New Issue
Block a user