# concolor > **bin/lib API for managing terminal styling** [![Documentation](https://img.shields.io/badge/docs-master-blue.svg)][Documentation] ![License](https://img.shields.io/crates/l/concolor.svg) [![Crates Status](https://img.shields.io/crates/v/concolor.svg)](https://crates.io/crates/concolor) Features - Detects interactive `stdout` / `stderr` - Detects terminal capabilities via `TERM` - Detects and enables ANSI support on Windows - Supports [CLICOLOR] and [NO_COLOR] ## [Contribute](../../CONTRIBUTING.md) Special note: to be successful, this crate **cannot** break compatibility or else different crates in the hierarchy will be reading different globals. While end users can work around this, it isn't ideal. Once we hit 1.0, we should strive to keep the API compatible. If we need a new API, we can make the old API an adapter to the new logic. Similarly, we should strive to reduce **risk** of breaking compatibility by exposing as little as possible. Anything more should be broken out into a separate crate that this crate can call into. ## Special Thanks Prior art for global colors control: - [yansi](https://crates.io/crates/yansi) - [clicolors-control](https://crates.io/crates/clicolors-control) [termcolor](https://crates.io/crates/termcolor) for identifying various corner cases with environment detection. [firestorm](https://crates.io/crates/firestorm) for zero-cost abstraction via bin/lib-specific `Cargo.toml` features. ## License Dual-licensed under [MIT](../../LICENSE-MIT) or [Apache 2.0](../../LICENSE-APACHE) [Documentation]: https://docs.rs/concolor [CLICOLOR]: https://bixense.com/clicolors/ [NO_COLOR]: https://no-color.org/