2020-03-29 04:38:07 +11:00
|
|
|
//! Making it a little more convenient and safe to query whether
|
|
|
|
//! something is a terminal teletype or not.
|
|
|
|
//! This module defines the IsTty trait and the is_tty method to
|
|
|
|
//! return true if the item represents a terminal.
|
|
|
|
|
|
|
|
#[cfg(unix)]
|
|
|
|
use std::os::unix::io::AsRawFd;
|
|
|
|
#[cfg(windows)]
|
|
|
|
use std::os::windows::io::AsRawHandle;
|
2020-12-28 19:47:20 +11:00
|
|
|
|
2020-03-29 04:38:07 +11:00
|
|
|
#[cfg(windows)]
|
|
|
|
use winapi::um::consoleapi::GetConsoleMode;
|
|
|
|
|
|
|
|
/// Adds the `is_tty` method to types that might represent a terminal
|
2020-07-12 20:16:18 +10:00
|
|
|
///
|
|
|
|
/// ```rust
|
|
|
|
/// use std::io::stdout;
|
|
|
|
/// use crossterm::tty::IsTty;
|
|
|
|
///
|
|
|
|
/// let is_tty: bool = stdout().is_tty();
|
|
|
|
/// ```
|
2020-03-29 04:38:07 +11:00
|
|
|
pub trait IsTty {
|
|
|
|
/// Returns true when an instance is a terminal teletype, otherwise false.
|
|
|
|
fn is_tty(&self) -> bool;
|
|
|
|
}
|
|
|
|
|
|
|
|
/// On unix, the `isatty()` function returns true if a file
|
|
|
|
/// descriptor is a terminal.
|
|
|
|
#[cfg(unix)]
|
|
|
|
impl<S: AsRawFd> IsTty for S {
|
|
|
|
fn is_tty(&self) -> bool {
|
|
|
|
let fd = self.as_raw_fd();
|
|
|
|
unsafe { libc::isatty(fd) == 1 }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/// On windows, `GetConsoleMode` will return true if we are in a terminal.
|
|
|
|
/// Otherwise false.
|
|
|
|
#[cfg(windows)]
|
|
|
|
impl<S: AsRawHandle> IsTty for S {
|
|
|
|
fn is_tty(&self) -> bool {
|
|
|
|
let mut mode = 0;
|
|
|
|
let ok = unsafe { GetConsoleMode(self.as_raw_handle() as *mut _, &mut mode) };
|
|
|
|
ok == 1
|
|
|
|
}
|
|
|
|
}
|