summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--Cargo.lock1
-rw-r--r--cli/Cargo.toml1
-rw-r--r--cli/colors.rs132
-rw-r--r--cli/diagnostics.rs4
-rw-r--r--cli/diff.rs2
-rw-r--r--cli/fmt_errors.rs2
-rw-r--r--cli/info.rs2
-rw-r--r--cli/main.rs2
-rw-r--r--runtime/colors.rs67
9 files changed, 35 insertions, 178 deletions
diff --git a/Cargo.lock b/Cargo.lock
index b289012d3..1927a5803 100644
--- a/Cargo.lock
+++ b/Cargo.lock
@@ -613,7 +613,6 @@ dependencies = [
"shell-escape",
"sourcemap",
"tempfile",
- "termcolor",
"test_util",
"text-size",
"tokio",
diff --git a/cli/Cargo.toml b/cli/Cargo.toml
index 2a1179aa5..b0154f739 100644
--- a/cli/Cargo.toml
+++ b/cli/Cargo.toml
@@ -88,7 +88,6 @@ serde = { version = "1.0.129", features = ["derive"] }
shell-escape = "0.1.5"
sourcemap = "6.0.1"
tempfile = "3.2.0"
-termcolor = "1.1.2"
text-size = "1.1.0"
tokio = { version = "1.10.1", features = ["full"] }
tokio-rustls = "0.22.0"
diff --git a/cli/colors.rs b/cli/colors.rs
deleted file mode 100644
index ce0af172d..000000000
--- a/cli/colors.rs
+++ /dev/null
@@ -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)
-}
diff --git a/cli/diagnostics.rs b/cli/diagnostics.rs
index 44dbacdcc..260f3a53d 100644
--- a/cli/diagnostics.rs
+++ b/cli/diagnostics.rs
@@ -1,6 +1,6 @@
// 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::Deserializer;
@@ -421,9 +421,9 @@ impl Error for Diagnostics {}
#[cfg(test)]
mod tests {
use super::*;
- use colors::strip_ansi_codes;
use deno_core::serde_json;
use deno_core::serde_json::json;
+ use test_util::strip_ansi_codes;
#[test]
fn test_de_diagnostics() {
diff --git a/cli/diff.rs b/cli/diff.rs
index 33af8bf0e..8285139b5 100644
--- a/cli/diff.rs
+++ b/cli/diff.rs
@@ -215,7 +215,7 @@ mod tests {
fn run_test(diff_text1: &str, diff_text2: &str, expected_output: &str) {
assert_eq!(
- colors::strip_ansi_codes(&diff(diff_text1, diff_text2,)),
+ test_util::strip_ansi_codes(&diff(diff_text1, diff_text2,)),
expected_output,
);
}
diff --git a/cli/fmt_errors.rs b/cli/fmt_errors.rs
index 2078c8b32..53a8535f0 100644
--- a/cli/fmt_errors.rs
+++ b/cli/fmt_errors.rs
@@ -246,7 +246,7 @@ impl Error for PrettyJsError {}
#[cfg(test)]
mod tests {
use super::*;
- use crate::colors::strip_ansi_codes;
+ use test_util::strip_ansi_codes;
#[test]
fn test_format_none_source_line() {
diff --git a/cli/info.rs b/cli/info.rs
index 7f30d7909..0f062028e 100644
--- a/cli/info.rs
+++ b/cli/info.rs
@@ -410,7 +410,7 @@ mod test {
fn text_module_graph_info_display() {
let fixture = get_fixture();
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
type: TypeScript
emit: /cache/emit/https/deno.land/x/a.js
diff --git a/cli/main.rs b/cli/main.rs
index f988728c4..896704eec 100644
--- a/cli/main.rs
+++ b/cli/main.rs
@@ -3,7 +3,6 @@
mod ast;
mod auth_tokens;
mod checksum;
-mod colors;
mod config_file;
mod deno_dir;
mod diagnostics;
@@ -74,6 +73,7 @@ use deno_core::serde_json::json;
use deno_core::v8_set_flags;
use deno_core::JsRuntime;
use deno_core::ModuleSpecifier;
+use deno_runtime::colors;
use deno_runtime::ops::worker_host::CreateWebWorkerCb;
use deno_runtime::permissions::Permissions;
use deno_runtime::web_worker::WebWorker;
diff --git a/runtime/colors.rs b/runtime/colors.rs
index 417a6e76e..00241b4e0 100644
--- a/runtime/colors.rs
+++ b/runtime/colors.rs
@@ -1,6 +1,5 @@
// Copyright 2018-2021 the Deno authors. All rights reserved. MIT license.
-use regex::Regex;
-use std::env;
+
use std::fmt;
use std::io::Write;
use termcolor::Color::{Ansi256, Black, Blue, Cyan, Green, Red, White, Yellow};
@@ -10,18 +9,7 @@ use termcolor::{Ansi, ColorSpec, WriteColor};
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 = 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, "")
+ static ref NO_COLOR: bool = std::env::var_os("NO_COLOR").is_some();
}
pub fn use_color() -> bool {
@@ -33,94 +21,97 @@ pub fn enable_ansi() {
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() {
- return String::from(s);
+ 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_bytes()).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: &str) -> impl fmt::Display {
+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: &str) -> impl fmt::Display {
+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_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();
style_spec.set_bold(true).set_italic(true);
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();
style_spec.set_bg(Some(Red)).set_fg(Some(White));
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();
style_spec.set_bg(Some(Green)).set_fg(Some(Black));
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();
style_spec.set_fg(Some(Yellow));
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();
style_spec.set_fg(Some(Cyan));
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();
style_spec.set_fg(Some(Red));
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();
style_spec.set_fg(Some(Green));
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();
style_spec.set_bold(true);
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();
style_spec.set_fg(Some(Ansi256(8)));
style(s, style_spec)
}
-pub fn italic_bold_gray(s: &str) -> 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 {
+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)