abrasion/third_party/cargo/vendor/atty-0.2.14
q3k 4a50bbf00d third_party/cargo: re-raze, fix winapi for windows 2021-05-03 23:43:36 +02:00
..
examples vendor all the shit. 2020-01-19 00:27:25 +01:00
src vendor all the shit. 2020-01-19 00:27:25 +01:00
.cargo-checksum.json third_party/cargo: add flatbuffers, bump 2020-05-29 03:43:49 +02:00
BUILD.bazel third_party/cargo: re-raze, fix winapi for windows 2021-05-03 23:43:36 +02:00
CHANGELOG.md vendor all the shit. 2020-01-19 00:27:25 +01:00
Cargo.lock third_party/cargo: add flatbuffers, bump 2020-05-29 03:43:49 +02:00
Cargo.toml vendor all the shit. 2020-01-19 00:27:25 +01:00
LICENSE vendor all the shit. 2020-01-19 00:27:25 +01:00
README.md vendor all the shit. 2020-01-19 00:27:25 +01:00
rustfmt.toml vendor all the shit. 2020-01-19 00:27:25 +01:00

README.md

atty

Build Status Build status Coverage Status crates.io Released API docs Master API docs

are you or are you not a tty?

install

Add the following to your Cargo.toml

[dependencies]
atty = "0.2"

usage

use atty::Stream;

fn main() {
  if atty::is(Stream::Stdout) {
    println!("I'm a terminal");
  } else {
    println!("I'm not");
  }
}

testing

This library has been unit tested on both unix and windows platforms (via appveyor).

A simple example program is provided in this repo to test various tty's. By default.

It prints

$ cargo run --example atty
stdout? true
stderr? true
stdin? true

To test std in, pipe some text to the program

$ echo "test" | cargo run --example atty
stdout? true
stderr? true
stdin? false

To test std out, pipe the program to something

$ cargo run --example atty | grep std
stdout? false
stderr? true
stdin? true

To test std err, pipe the program to something redirecting std err

$ cargo run --example atty 2>&1 | grep std
stdout? false
stderr? false
stdin? true

Doug Tangren (softprops) 2015-2019