mirror of
https://github.com/denoland/deno.git
synced 2025-01-12 09:03:42 -05:00
refactor(cli): move tooling to cli/tools/ (#8424)
This commit moves following tools into a single "tools" module located at "cli/tools/mod.rs": - formatter - linter - test runner - coverage collector - installer - binary upgrader - repl
This commit is contained in:
parent
21e8ff6fc1
commit
9eaa1fb71d
9 changed files with 31 additions and 24 deletions
42
cli/main.rs
42
cli/main.rs
|
@ -10,7 +10,6 @@ extern crate log;
|
|||
mod ast;
|
||||
mod checksum;
|
||||
mod colors;
|
||||
mod coverage;
|
||||
mod deno_dir;
|
||||
mod diagnostics;
|
||||
mod diff;
|
||||
|
@ -20,7 +19,6 @@ mod file_fetcher;
|
|||
mod file_watcher;
|
||||
mod flags;
|
||||
mod flags_allow_net;
|
||||
mod fmt;
|
||||
mod fmt_errors;
|
||||
mod fs_util;
|
||||
mod http_cache;
|
||||
|
@ -28,9 +26,7 @@ mod http_util;
|
|||
mod import_map;
|
||||
mod info;
|
||||
mod inspector;
|
||||
mod installer;
|
||||
mod js;
|
||||
mod lint;
|
||||
mod lockfile;
|
||||
mod media_type;
|
||||
mod metrics;
|
||||
|
@ -39,22 +35,18 @@ mod module_loader;
|
|||
mod ops;
|
||||
mod permissions;
|
||||
mod program_state;
|
||||
mod repl;
|
||||
mod resolve_addr;
|
||||
mod signal;
|
||||
mod source_maps;
|
||||
mod specifier_handler;
|
||||
mod test_runner;
|
||||
mod text_encoding;
|
||||
mod tokio_util;
|
||||
mod tools;
|
||||
mod tsc;
|
||||
mod tsc_config;
|
||||
mod upgrade;
|
||||
mod version;
|
||||
mod worker;
|
||||
|
||||
use crate::coverage::CoverageCollector;
|
||||
use crate::coverage::PrettyCoverageReporter;
|
||||
use crate::file_fetcher::File;
|
||||
use crate::file_fetcher::FileFetcher;
|
||||
use crate::media_type::MediaType;
|
||||
|
@ -88,7 +80,6 @@ use std::path::PathBuf;
|
|||
use std::pin::Pin;
|
||||
use std::rc::Rc;
|
||||
use std::sync::Arc;
|
||||
use upgrade::upgrade_command;
|
||||
|
||||
fn write_to_stdout_ignore_sigpipe(bytes: &[u8]) -> Result<(), std::io::Error> {
|
||||
use std::io::ErrorKind;
|
||||
|
@ -213,7 +204,7 @@ async fn install_command(
|
|||
MainWorker::new(&program_state, main_module.clone(), permissions);
|
||||
// First, fetch and compile the module; this step ensures that the module exists.
|
||||
worker.preload_module(&main_module).await?;
|
||||
installer::install(flags, &module_url, args, name, root, force)
|
||||
tools::installer::install(flags, &module_url, args, name, root, force)
|
||||
}
|
||||
|
||||
async fn lint_command(
|
||||
|
@ -228,11 +219,11 @@ async fn lint_command(
|
|||
}
|
||||
|
||||
if list_rules {
|
||||
lint::print_rules_list(json);
|
||||
tools::lint::print_rules_list(json);
|
||||
return Ok(());
|
||||
}
|
||||
|
||||
lint::lint_files(files, ignore, json).await
|
||||
tools::lint::lint_files(files, ignore, json).await
|
||||
}
|
||||
|
||||
async fn cache_command(
|
||||
|
@ -523,7 +514,7 @@ async fn run_repl(flags: Flags) -> Result<(), AnyError> {
|
|||
MainWorker::new(&program_state, main_module.clone(), permissions);
|
||||
worker.run_event_loop().await?;
|
||||
|
||||
repl::run(&program_state, worker).await
|
||||
tools::repl::run(&program_state, worker).await
|
||||
}
|
||||
|
||||
async fn run_from_stdin(flags: Flags) -> Result<(), AnyError> {
|
||||
|
@ -643,7 +634,8 @@ async fn test_command(
|
|||
let permissions = Permissions::from_flags(&flags);
|
||||
let cwd = std::env::current_dir().expect("No current directory");
|
||||
let include = include.unwrap_or_else(|| vec![".".to_string()]);
|
||||
let test_modules = test_runner::prepare_test_modules_urls(include, &cwd)?;
|
||||
let test_modules =
|
||||
tools::test_runner::prepare_test_modules_urls(include, &cwd)?;
|
||||
|
||||
if test_modules.is_empty() {
|
||||
println!("No matching test modules found");
|
||||
|
@ -656,7 +648,7 @@ async fn test_command(
|
|||
let test_file_path = cwd.join("$deno$test.ts");
|
||||
let test_file_url =
|
||||
Url::from_file_path(&test_file_path).expect("Should be valid file url");
|
||||
let test_file = test_runner::render_test_file(
|
||||
let test_file = tools::test_runner::render_test_file(
|
||||
test_modules.clone(),
|
||||
fail_fast,
|
||||
quiet,
|
||||
|
@ -680,7 +672,8 @@ async fn test_command(
|
|||
|
||||
let mut maybe_coverage_collector = if flags.coverage {
|
||||
let session = worker.create_inspector_session();
|
||||
let mut coverage_collector = CoverageCollector::new(session);
|
||||
let mut coverage_collector =
|
||||
tools::coverage::CoverageCollector::new(session);
|
||||
coverage_collector.start_collecting().await?;
|
||||
|
||||
Some(coverage_collector)
|
||||
|
@ -699,10 +692,14 @@ async fn test_command(
|
|||
let coverages = coverage_collector.collect().await?;
|
||||
coverage_collector.stop_collecting().await?;
|
||||
|
||||
let filtered_coverages =
|
||||
coverage::filter_script_coverages(coverages, test_file_url, test_modules);
|
||||
let filtered_coverages = tools::coverage::filter_script_coverages(
|
||||
coverages,
|
||||
test_file_url,
|
||||
test_modules,
|
||||
);
|
||||
|
||||
let mut coverage_reporter = PrettyCoverageReporter::new(quiet);
|
||||
let mut coverage_reporter =
|
||||
tools::coverage::PrettyCoverageReporter::new(quiet);
|
||||
for coverage in filtered_coverages {
|
||||
coverage_reporter.visit_coverage(&coverage);
|
||||
}
|
||||
|
@ -796,7 +793,7 @@ pub fn main() {
|
|||
check,
|
||||
files,
|
||||
ignore,
|
||||
} => fmt::format(files, check, ignore).boxed_local(),
|
||||
} => tools::fmt::format(files, check, ignore).boxed_local(),
|
||||
DenoSubcommand::Info { file, json } => {
|
||||
info_command(flags, file, json).boxed_local()
|
||||
}
|
||||
|
@ -847,7 +844,8 @@ pub fn main() {
|
|||
output,
|
||||
ca_file,
|
||||
} => {
|
||||
upgrade_command(dry_run, force, version, output, ca_file).boxed_local()
|
||||
tools::upgrade::upgrade_command(dry_run, force, version, output, ca_file)
|
||||
.boxed_local()
|
||||
}
|
||||
};
|
||||
|
||||
|
|
|
@ -8,10 +8,10 @@
|
|||
//! the same functions as ops available in JS runtime.
|
||||
use crate::ast;
|
||||
use crate::colors;
|
||||
use crate::fmt::run_parallelized;
|
||||
use crate::fmt_errors;
|
||||
use crate::fs_util::{collect_files, is_supported_ext};
|
||||
use crate::media_type::MediaType;
|
||||
use crate::tools::fmt::run_parallelized;
|
||||
use deno_core::error::{generic_error, AnyError, JsStackFrame};
|
||||
use deno_core::serde_json;
|
||||
use deno_lint::diagnostic::LintDiagnostic;
|
9
cli/tools/mod.rs
Normal file
9
cli/tools/mod.rs
Normal file
|
@ -0,0 +1,9 @@
|
|||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||
|
||||
pub mod coverage;
|
||||
pub mod fmt;
|
||||
pub mod installer;
|
||||
pub mod lint;
|
||||
pub mod repl;
|
||||
pub mod test_runner;
|
||||
pub mod upgrade;
|
|
@ -1,7 +1,7 @@
|
|||
// Copyright 2018-2020 the Deno authors. All rights reserved. MIT license.
|
||||
|
||||
use crate::fs_util;
|
||||
use crate::installer::is_remote_url;
|
||||
use crate::tools::installer::is_remote_url;
|
||||
use deno_core::error::AnyError;
|
||||
use deno_core::serde_json::json;
|
||||
use deno_core::url::Url;
|
Loading…
Reference in a new issue