mirror of
https://github.com/martinvonz/jj.git
synced 2024-12-23 20:43:56 +00:00
cli: use color only when stdout is a TTY
This adds a `ui.color` config that can be set to "always", "never", or "auto". If set to "auto", we use color iff stdout is a TTY.
This commit is contained in:
parent
0fadac38d6
commit
9ce56f6cb7
3 changed files with 14 additions and 3 deletions
1
Cargo.lock
generated
1
Cargo.lock
generated
|
@ -528,6 +528,7 @@ dependencies = [
|
|||
name = "jujutsu"
|
||||
version = "0.2.0"
|
||||
dependencies = [
|
||||
"atty",
|
||||
"blake2",
|
||||
"bytes",
|
||||
"chrono",
|
||||
|
|
|
@ -20,6 +20,7 @@ path = "src/main.rs"
|
|||
members = ["lib"]
|
||||
|
||||
[dependencies]
|
||||
atty = "0.2.14"
|
||||
blake2 = "0.9.2"
|
||||
bytes = "1.1.0"
|
||||
chrono = "0.4.19"
|
||||
|
|
15
src/ui.rs
15
src/ui.rs
|
@ -17,6 +17,7 @@ use std::path::{Component, Path, PathBuf};
|
|||
use std::sync::{Mutex, MutexGuard};
|
||||
use std::{fmt, io};
|
||||
|
||||
use atty::Stream;
|
||||
use jujutsu_lib::commit::Commit;
|
||||
use jujutsu_lib::repo::RepoRef;
|
||||
use jujutsu_lib::repo_path::{RepoPath, RepoPathComponent, RepoPathJoin};
|
||||
|
@ -48,10 +49,9 @@ impl<'stdout> Ui<'stdout> {
|
|||
pub fn new(
|
||||
cwd: PathBuf,
|
||||
stdout: Box<dyn Write + 'stdout>,
|
||||
is_atty: bool,
|
||||
color: bool,
|
||||
settings: UserSettings,
|
||||
) -> Ui<'stdout> {
|
||||
let color = is_atty;
|
||||
let formatter = Mutex::new(new_formatter(&settings, color, stdout));
|
||||
Ui {
|
||||
cwd,
|
||||
|
@ -64,7 +64,16 @@ impl<'stdout> Ui<'stdout> {
|
|||
pub fn for_terminal(settings: UserSettings) -> Ui<'static> {
|
||||
let cwd = std::env::current_dir().unwrap();
|
||||
let stdout: Box<dyn Write + 'static> = Box::new(io::stdout());
|
||||
Ui::new(cwd, stdout, true, settings)
|
||||
let color_setting = settings
|
||||
.config()
|
||||
.get_str("ui.color")
|
||||
.unwrap_or_else(|_| "auto".to_string());
|
||||
let color = match color_setting.as_str() {
|
||||
"always" => true,
|
||||
"never" => false,
|
||||
_ => atty::is(Stream::Stdout),
|
||||
};
|
||||
Ui::new(cwd, stdout, color, settings)
|
||||
}
|
||||
|
||||
pub fn cwd(&self) -> &Path {
|
||||
|
|
Loading…
Reference in a new issue