1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2025-01-11 16:42:21 -05:00

refactor: Remove duplicated colors.rs file (#11990)

This commit is contained in:
Ryan Dahl 2021-09-12 12:04:17 -04:00 committed by GitHub
parent 00d62e64bf
commit 13991e5995
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
9 changed files with 35 additions and 178 deletions

1
Cargo.lock generated
View file

@ -613,7 +613,6 @@ dependencies = [
"shell-escape", "shell-escape",
"sourcemap", "sourcemap",
"tempfile", "tempfile",
"termcolor",
"test_util", "test_util",
"text-size", "text-size",
"tokio", "tokio",

View file

@ -88,7 +88,6 @@ serde = { version = "1.0.129", features = ["derive"] }
shell-escape = "0.1.5" shell-escape = "0.1.5"
sourcemap = "6.0.1" sourcemap = "6.0.1"
tempfile = "3.2.0" tempfile = "3.2.0"
termcolor = "1.1.2"
text-size = "1.1.0" text-size = "1.1.0"
tokio = { version = "1.10.1", features = ["full"] } tokio = { version = "1.10.1", features = ["full"] }
tokio-rustls = "0.22.0" tokio-rustls = "0.22.0"

View file

@ -1,132 +0,0 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use regex::Regex;
use std::fmt;
use std::io::Write;
use termcolor::Color::{Ansi256, Black, Blue, Cyan, Green, Red, White, Yellow};
use termcolor::{Ansi, ColorSpec, WriteColor};
#[cfg(windows)]
use termcolor::{BufferWriter, ColorChoice};
lazy_static::lazy_static! {
// STRIP_ANSI_RE and strip_ansi_codes are lifted from the "console" crate.
// Copyright 2017 Armin Ronacher <armin.ronacher@active-4.com>. MIT License.
static ref STRIP_ANSI_RE: Regex = Regex::new(
r"[\x1b\x9b][\[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-PRZcf-nqry=><]"
).unwrap();
static ref NO_COLOR: bool = {
std::env::var_os("NO_COLOR").is_some()
};
}
/// Helper function to strip ansi codes.
#[cfg(test)]
pub fn strip_ansi_codes(s: &str) -> std::borrow::Cow<str> {
STRIP_ANSI_RE.replace_all(s, "")
}
pub fn use_color() -> bool {
!(*NO_COLOR)
}
#[cfg(windows)]
pub fn enable_ansi() {
BufferWriter::stdout(ColorChoice::AlwaysAnsi);
}
fn style<S: AsRef<str>>(s: S, colorspec: ColorSpec) -> impl fmt::Display {
if !use_color() {
return String::from(s.as_ref());
}
let mut v = Vec::new();
let mut ansi_writer = Ansi::new(&mut v);
ansi_writer.set_color(&colorspec).unwrap();
ansi_writer.write_all(s.as_ref().as_bytes()).unwrap();
ansi_writer.reset().unwrap();
String::from_utf8_lossy(&v).into_owned()
}
pub fn red_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Red)).set_bold(true);
style(s, style_spec)
}
pub fn green_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Green)).set_bold(true);
style(s, style_spec)
}
pub fn italic<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_italic(true);
style(s, style_spec)
}
pub fn italic_gray<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Ansi256(8))).set_italic(true);
style(s, style_spec)
}
pub fn italic_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_bold(true).set_italic(true);
style(s, style_spec)
}
pub fn white_on_red<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_bg(Some(Red)).set_fg(Some(White));
style(s, style_spec)
}
pub fn black_on_green<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_bg(Some(Green)).set_fg(Some(Black));
style(s, style_spec)
}
pub fn yellow<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Yellow));
style(s, style_spec)
}
pub fn cyan<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Cyan));
style(s, style_spec)
}
pub fn red<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Red));
style(s, style_spec)
}
pub fn green<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Green));
style(s, style_spec)
}
pub fn bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_bold(true);
style(s, style_spec)
}
pub fn gray<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Ansi256(8)));
style(s, style_spec)
}
pub fn intense_blue<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Blue)).set_intense(true);
style(s, style_spec)
}

View file

@ -1,6 +1,6 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use crate::colors; use deno_runtime::colors;
use deno_core::serde::Deserialize; use deno_core::serde::Deserialize;
use deno_core::serde::Deserializer; use deno_core::serde::Deserializer;
@ -421,9 +421,9 @@ impl Error for Diagnostics {}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::*; use super::*;
use colors::strip_ansi_codes;
use deno_core::serde_json; use deno_core::serde_json;
use deno_core::serde_json::json; use deno_core::serde_json::json;
use test_util::strip_ansi_codes;
#[test] #[test]
fn test_de_diagnostics() { fn test_de_diagnostics() {

View file

@ -215,7 +215,7 @@ mod tests {
fn run_test(diff_text1: &str, diff_text2: &str, expected_output: &str) { fn run_test(diff_text1: &str, diff_text2: &str, expected_output: &str) {
assert_eq!( assert_eq!(
colors::strip_ansi_codes(&diff(diff_text1, diff_text2,)), test_util::strip_ansi_codes(&diff(diff_text1, diff_text2,)),
expected_output, expected_output,
); );
} }

View file

@ -246,7 +246,7 @@ impl Error for PrettyJsError {}
#[cfg(test)] #[cfg(test)]
mod tests { mod tests {
use super::*; use super::*;
use crate::colors::strip_ansi_codes; use test_util::strip_ansi_codes;
#[test] #[test]
fn test_format_none_source_line() { fn test_format_none_source_line() {

View file

@ -410,7 +410,7 @@ mod test {
fn text_module_graph_info_display() { fn text_module_graph_info_display() {
let fixture = get_fixture(); let fixture = get_fixture();
let text = fixture.to_string(); let text = fixture.to_string();
let actual = colors::strip_ansi_codes(&text); let actual = test_util::strip_ansi_codes(&text);
let expected = r#"local: /cache/deps/https/deno.land/x/a.ts let expected = r#"local: /cache/deps/https/deno.land/x/a.ts
type: TypeScript type: TypeScript
emit: /cache/emit/https/deno.land/x/a.js emit: /cache/emit/https/deno.land/x/a.js

View file

@ -3,7 +3,6 @@
mod ast; mod ast;
mod auth_tokens; mod auth_tokens;
mod checksum; mod checksum;
mod colors;
mod config_file; mod config_file;
mod deno_dir; mod deno_dir;
mod diagnostics; mod diagnostics;
@ -74,6 +73,7 @@ use deno_core::serde_json::json;
use deno_core::v8_set_flags; use deno_core::v8_set_flags;
use deno_core::JsRuntime; use deno_core::JsRuntime;
use deno_core::ModuleSpecifier; use deno_core::ModuleSpecifier;
use deno_runtime::colors;
use deno_runtime::ops::worker_host::CreateWebWorkerCb; use deno_runtime::ops::worker_host::CreateWebWorkerCb;
use deno_runtime::permissions::Permissions; use deno_runtime::permissions::Permissions;
use deno_runtime::web_worker::WebWorker; use deno_runtime::web_worker::WebWorker;

View file

@ -1,6 +1,5 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license. // Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
use regex::Regex;
use std::env;
use std::fmt; use std::fmt;
use std::io::Write; use std::io::Write;
use termcolor::Color::{Ansi256, Black, Blue, Cyan, Green, Red, White, Yellow}; use termcolor::Color::{Ansi256, Black, Blue, Cyan, Green, Red, White, Yellow};
@ -10,18 +9,7 @@ use termcolor::{Ansi, ColorSpec, WriteColor};
use termcolor::{BufferWriter, ColorChoice}; use termcolor::{BufferWriter, ColorChoice};
lazy_static::lazy_static! { lazy_static::lazy_static! {
// STRIP_ANSI_RE and strip_ansi_codes are lifted from the "console" crate. static ref NO_COLOR: bool = std::env::var_os("NO_COLOR").is_some();
// Copyright 2017 Armin Ronacher <armin.ronacher@active-4.com>. MIT License.
static ref STRIP_ANSI_RE: Regex = Regex::new(
r"[\x1b\x9b][\[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-PRZcf-nqry=><]"
).unwrap();
static ref NO_COLOR: bool = env::var_os("NO_COLOR").is_some();
}
/// Helper function to strip ansi codes.
#[cfg(test)]
pub fn strip_ansi_codes(s: &str) -> std::borrow::Cow<str> {
STRIP_ANSI_RE.replace_all(s, "")
} }
pub fn use_color() -> bool { pub fn use_color() -> bool {
@ -33,94 +21,97 @@ pub fn enable_ansi() {
BufferWriter::stdout(ColorChoice::AlwaysAnsi); BufferWriter::stdout(ColorChoice::AlwaysAnsi);
} }
fn style(s: &str, colorspec: ColorSpec) -> impl fmt::Display { fn style<S: AsRef<str>>(s: S, colorspec: ColorSpec) -> impl fmt::Display {
if !use_color() { if !use_color() {
return String::from(s); return String::from(s.as_ref());
} }
let mut v = Vec::new(); let mut v = Vec::new();
let mut ansi_writer = Ansi::new(&mut v); let mut ansi_writer = Ansi::new(&mut v);
ansi_writer.set_color(&colorspec).unwrap(); ansi_writer.set_color(&colorspec).unwrap();
ansi_writer.write_all(s.as_bytes()).unwrap(); ansi_writer.write_all(s.as_ref().as_bytes()).unwrap();
ansi_writer.reset().unwrap(); ansi_writer.reset().unwrap();
String::from_utf8_lossy(&v).into_owned() String::from_utf8_lossy(&v).into_owned()
} }
pub fn red_bold(s: &str) -> impl fmt::Display { pub fn red_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Red)).set_bold(true); style_spec.set_fg(Some(Red)).set_bold(true);
style(s, style_spec) style(s, style_spec)
} }
pub fn green_bold(s: &str) -> impl fmt::Display { pub fn green_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Green)).set_bold(true); style_spec.set_fg(Some(Green)).set_bold(true);
style(s, style_spec) style(s, style_spec)
} }
pub fn italic_bold(s: &str) -> impl fmt::Display { pub fn italic<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_italic(true);
style(s, style_spec)
}
pub fn italic_gray<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Ansi256(8))).set_italic(true);
style(s, style_spec)
}
pub fn italic_bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_bold(true).set_italic(true); style_spec.set_bold(true).set_italic(true);
style(s, style_spec) style(s, style_spec)
} }
pub fn white_on_red(s: &str) -> impl fmt::Display { pub fn white_on_red<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_bg(Some(Red)).set_fg(Some(White)); style_spec.set_bg(Some(Red)).set_fg(Some(White));
style(s, style_spec) style(s, style_spec)
} }
pub fn black_on_green(s: &str) -> impl fmt::Display { pub fn black_on_green<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_bg(Some(Green)).set_fg(Some(Black)); style_spec.set_bg(Some(Green)).set_fg(Some(Black));
style(s, style_spec) style(s, style_spec)
} }
pub fn yellow(s: &str) -> impl fmt::Display { pub fn yellow<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Yellow)); style_spec.set_fg(Some(Yellow));
style(s, style_spec) style(s, style_spec)
} }
pub fn cyan(s: &str) -> impl fmt::Display { pub fn cyan<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Cyan)); style_spec.set_fg(Some(Cyan));
style(s, style_spec) style(s, style_spec)
} }
pub fn red(s: &str) -> impl fmt::Display { pub fn red<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Red)); style_spec.set_fg(Some(Red));
style(s, style_spec) style(s, style_spec)
} }
pub fn green(s: &str) -> impl fmt::Display { pub fn green<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Green)); style_spec.set_fg(Some(Green));
style(s, style_spec) style(s, style_spec)
} }
pub fn bold(s: &str) -> impl fmt::Display { pub fn bold<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_bold(true); style_spec.set_bold(true);
style(s, style_spec) style(s, style_spec)
} }
pub fn gray(s: &str) -> impl fmt::Display { pub fn gray<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Ansi256(8))); style_spec.set_fg(Some(Ansi256(8)));
style(s, style_spec) style(s, style_spec)
} }
pub fn italic_bold_gray(s: &str) -> impl fmt::Display { pub fn intense_blue<S: AsRef<str>>(s: S) -> impl fmt::Display {
let mut style_spec = ColorSpec::new();
style_spec
.set_fg(Some(Ansi256(8)))
.set_bold(true)
.set_italic(true);
style(s, style_spec)
}
pub fn intense_blue(s: &str) -> impl fmt::Display {
let mut style_spec = ColorSpec::new(); let mut style_spec = ColorSpec::new();
style_spec.set_fg(Some(Blue)).set_intense(true); style_spec.set_fg(Some(Blue)).set_intense(true);
style(s, style_spec) style(s, style_spec)