mirror of
https://github.com/denoland/deno.git
synced 2025-01-03 12:58:54 -05:00
fix: shell completion hints (#13876)
This commit is contained in:
parent
c6bf07ec6d
commit
5eb0e4c2df
1 changed files with 62 additions and 21 deletions
83
cli/flags.rs
83
cli/flags.rs
|
@ -6,6 +6,7 @@ use clap::Arg;
|
||||||
use clap::ArgMatches;
|
use clap::ArgMatches;
|
||||||
use clap::ArgSettings;
|
use clap::ArgSettings;
|
||||||
use clap::ColorChoice;
|
use clap::ColorChoice;
|
||||||
|
use clap::ValueHint;
|
||||||
use deno_core::serde::Deserialize;
|
use deno_core::serde::Deserialize;
|
||||||
use deno_core::serde::Serialize;
|
use deno_core::serde::Serialize;
|
||||||
use deno_core::url::Url;
|
use deno_core::url::Url;
|
||||||
|
@ -640,8 +641,18 @@ Directory arguments are expanded to all contained files matching the glob
|
||||||
|
|
||||||
fn bundle_subcommand<'a>() -> App<'a> {
|
fn bundle_subcommand<'a>() -> App<'a> {
|
||||||
compile_args(App::new("bundle"))
|
compile_args(App::new("bundle"))
|
||||||
.arg(Arg::new("source_file").takes_value(true).required(true))
|
.arg(
|
||||||
.arg(Arg::new("out_file").takes_value(true).required(false))
|
Arg::new("source_file")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(true)
|
||||||
|
.value_hint(ValueHint::FilePath),
|
||||||
|
)
|
||||||
|
.arg(
|
||||||
|
Arg::new("out_file")
|
||||||
|
.takes_value(true)
|
||||||
|
.required(false)
|
||||||
|
.value_hint(ValueHint::FilePath),
|
||||||
|
)
|
||||||
.arg(watch_arg(false))
|
.arg(watch_arg(false))
|
||||||
.arg(no_clear_screen_arg())
|
.arg(no_clear_screen_arg())
|
||||||
.about("Bundle module and dependencies into single file")
|
.about("Bundle module and dependencies into single file")
|
||||||
|
@ -662,7 +673,8 @@ fn cache_subcommand<'a>() -> App<'a> {
|
||||||
Arg::new("file")
|
Arg::new("file")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.required(true)
|
.required(true)
|
||||||
.min_values(1),
|
.min_values(1)
|
||||||
|
.value_hint(ValueHint::FilePath),
|
||||||
)
|
)
|
||||||
.about("Cache the dependencies")
|
.about("Cache the dependencies")
|
||||||
.long_about(
|
.long_about(
|
||||||
|
@ -690,6 +702,7 @@ fn compile_subcommand<'a>() -> App<'a> {
|
||||||
.short('o')
|
.short('o')
|
||||||
.help("Output file (defaults to $PWD/<inferred-name>)")
|
.help("Output file (defaults to $PWD/<inferred-name>)")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("target")
|
Arg::new("target")
|
||||||
|
@ -783,7 +796,8 @@ Generate html reports from lcov:
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Ignore coverage files"),
|
.help("Ignore coverage files")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("include")
|
Arg::new("include")
|
||||||
|
@ -824,13 +838,15 @@ If no --output arg is specified then the report is written to stdout."
|
||||||
)
|
)
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("files")
|
Arg::new("files")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_values(true)
|
.multiple_values(true)
|
||||||
.multiple_occurrences(true)
|
.multiple_occurrences(true)
|
||||||
.required(true),
|
.required(true)
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -880,7 +896,11 @@ Show documentation for runtime built-ins:
|
||||||
// just a possible value of `source_file` so leading hyphens must be
|
// just a possible value of `source_file` so leading hyphens must be
|
||||||
// enabled.
|
// enabled.
|
||||||
.setting(clap::AppSettings::AllowHyphenValues)
|
.setting(clap::AppSettings::AllowHyphenValues)
|
||||||
.arg(Arg::new("source_file").takes_value(true))
|
.arg(
|
||||||
|
Arg::new("source_file")
|
||||||
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath),
|
||||||
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("filter")
|
Arg::new("filter")
|
||||||
.help("Dot separated path to symbol")
|
.help("Dot separated path to symbol")
|
||||||
|
@ -985,14 +1005,16 @@ Ignore formatting a file by adding an ignore comment at the top of the file:
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Ignore formatting particular source files"),
|
.help("Ignore formatting particular source files")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("files")
|
Arg::new("files")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_values(true)
|
.multiple_values(true)
|
||||||
.multiple_occurrences(true)
|
.multiple_occurrences(true)
|
||||||
.required(false),
|
.required(false)
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(watch_arg(false))
|
.arg(watch_arg(false))
|
||||||
.arg(no_clear_screen_arg())
|
.arg(no_clear_screen_arg())
|
||||||
|
@ -1062,7 +1084,7 @@ DENO_DIR: Directory containing Deno-managed files.
|
||||||
Remote modules cache: Subdirectory containing downloaded remote modules.
|
Remote modules cache: Subdirectory containing downloaded remote modules.
|
||||||
TypeScript compiler cache: Subdirectory containing TS compiler output.",
|
TypeScript compiler cache: Subdirectory containing TS compiler output.",
|
||||||
)
|
)
|
||||||
.arg(Arg::new("file").takes_value(true).required(false))
|
.arg(Arg::new("file").takes_value(true).required(false).value_hint(ValueHint::FilePath))
|
||||||
.arg(reload_arg().requires("file"))
|
.arg(reload_arg().requires("file"))
|
||||||
.arg(ca_file_arg())
|
.arg(ca_file_arg())
|
||||||
.arg(
|
.arg(
|
||||||
|
@ -1084,7 +1106,7 @@ TypeScript compiler cache: Subdirectory containing TS compiler output.",
|
||||||
fn install_subcommand<'a>() -> App<'a> {
|
fn install_subcommand<'a>() -> App<'a> {
|
||||||
runtime_args(App::new("install"), true, true)
|
runtime_args(App::new("install"), true, true)
|
||||||
.setting(AppSettings::TrailingVarArg)
|
.setting(AppSettings::TrailingVarArg)
|
||||||
.arg(Arg::new("cmd").required(true).multiple_values(true))
|
.arg(Arg::new("cmd").required(true).multiple_values(true).value_hint(ValueHint::FilePath))
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("name")
|
Arg::new("name")
|
||||||
.long("name")
|
.long("name")
|
||||||
|
@ -1098,7 +1120,8 @@ fn install_subcommand<'a>() -> App<'a> {
|
||||||
.help("Installation root")
|
.help("Installation root")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_occurrences(false)
|
.multiple_occurrences(false)
|
||||||
.multiple_values(false))
|
.multiple_values(false)
|
||||||
|
.value_hint(ValueHint::DirPath))
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("force")
|
Arg::new("force")
|
||||||
.long("force")
|
.long("force")
|
||||||
|
@ -1149,7 +1172,8 @@ fn uninstall_subcommand<'a>() -> App<'a> {
|
||||||
.long("root")
|
.long("root")
|
||||||
.help("Installation root")
|
.help("Installation root")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_occurrences(false))
|
.multiple_occurrences(false)
|
||||||
|
.value_hint(ValueHint::DirPath))
|
||||||
.about("Uninstall a script previously installed with deno install")
|
.about("Uninstall a script previously installed with deno install")
|
||||||
.long_about(
|
.long_about(
|
||||||
"Uninstalls an executable script in the installation root's bin directory.
|
"Uninstalls an executable script in the installation root's bin directory.
|
||||||
|
@ -1249,7 +1273,8 @@ Ignore linting a file by adding an ignore comment at the top of the file:
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Ignore linting particular source files"),
|
.help("Ignore linting particular source files")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("json")
|
Arg::new("json")
|
||||||
|
@ -1262,7 +1287,8 @@ Ignore linting a file by adding an ignore comment at the top of the file:
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_values(true)
|
.multiple_values(true)
|
||||||
.multiple_occurrences(true)
|
.multiple_occurrences(true)
|
||||||
.required(false),
|
.required(false)
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(watch_arg(false))
|
.arg(watch_arg(false))
|
||||||
.arg(no_clear_screen_arg())
|
.arg(no_clear_screen_arg())
|
||||||
|
@ -1346,7 +1372,8 @@ fn test_subcommand<'a>() -> App<'a> {
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Ignore files"),
|
.help("Ignore files")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("no-run")
|
Arg::new("no-run")
|
||||||
|
@ -1436,7 +1463,8 @@ fn test_subcommand<'a>() -> App<'a> {
|
||||||
.help("List of file names to run")
|
.help("List of file names to run")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.multiple_values(true)
|
.multiple_values(true)
|
||||||
.multiple_occurrences(true),
|
.multiple_occurrences(true)
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
watch_arg(false)
|
watch_arg(false)
|
||||||
|
@ -1499,7 +1527,8 @@ update to a different location, use the --output flag
|
||||||
Arg::new("output")
|
Arg::new("output")
|
||||||
.long("output")
|
.long("output")
|
||||||
.help("The path to output the updated version to")
|
.help("The path to output the updated version to")
|
||||||
.takes_value(true),
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("dry-run")
|
Arg::new("dry-run")
|
||||||
|
@ -1548,7 +1577,8 @@ Remote modules and multiple modules may also be specified:
|
||||||
Arg::new("output")
|
Arg::new("output")
|
||||||
.long("output")
|
.long("output")
|
||||||
.help("The directory to output the vendored modules to")
|
.help("The directory to output the vendored modules to")
|
||||||
.takes_value(true),
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::DirPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("force")
|
Arg::new("force")
|
||||||
|
@ -1587,7 +1617,8 @@ fn permission_args(app: App) -> App {
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Allow file system read access"),
|
.help("Allow file system read access")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("allow-write")
|
Arg::new("allow-write")
|
||||||
|
@ -1596,7 +1627,8 @@ fn permission_args(app: App) -> App {
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Allow file system write access"),
|
.help("Allow file system write access")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("allow-net")
|
Arg::new("allow-net")
|
||||||
|
@ -1642,7 +1674,8 @@ fn permission_args(app: App) -> App {
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
.use_delimiter(true)
|
.use_delimiter(true)
|
||||||
.require_equals(true)
|
.require_equals(true)
|
||||||
.help("Allow loading dynamic libraries"),
|
.help("Allow loading dynamic libraries")
|
||||||
|
.value_hint(ValueHint::AnyPath),
|
||||||
)
|
)
|
||||||
.arg(
|
.arg(
|
||||||
Arg::new("allow-hrtime")
|
Arg::new("allow-hrtime")
|
||||||
|
@ -1727,6 +1760,7 @@ Specification: https://wicg.github.io/import-maps/
|
||||||
Examples: https://github.com/WICG/import-maps#the-import-map",
|
Examples: https://github.com/WICG/import-maps#the-import-map",
|
||||||
)
|
)
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn reload_arg<'a>() -> Arg<'a> {
|
fn reload_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1748,6 +1782,7 @@ fn reload_arg<'a>() -> Arg<'a> {
|
||||||
--reload=https://deno.land/std/fs/utils.ts,https://deno.land/std/fmt/colors.ts
|
--reload=https://deno.land/std/fs/utils.ts,https://deno.land/std/fmt/colors.ts
|
||||||
Reloads specific modules",
|
Reloads specific modules",
|
||||||
)
|
)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn ca_file_arg<'a>() -> Arg<'a> {
|
fn ca_file_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1756,6 +1791,7 @@ fn ca_file_arg<'a>() -> Arg<'a> {
|
||||||
.value_name("FILE")
|
.value_name("FILE")
|
||||||
.help("Load certificate authority from PEM encoded file")
|
.help("Load certificate authority from PEM encoded file")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn cached_only_arg<'a>() -> Arg<'a> {
|
fn cached_only_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1783,6 +1819,7 @@ fn location_arg<'a>() -> Arg<'a> {
|
||||||
Ok(())
|
Ok(())
|
||||||
})
|
})
|
||||||
.help("Value of 'globalThis.location' used by some web APIs")
|
.help("Value of 'globalThis.location' used by some web APIs")
|
||||||
|
.value_hint(ValueHint::Url)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn enable_testing_features_arg<'a>() -> Arg<'a> {
|
fn enable_testing_features_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1837,6 +1874,7 @@ fn watch_arg<'a>(takes_files: bool) -> Arg<'a> {
|
||||||
Local files from entry point module graph are watched by default.
|
Local files from entry point module graph are watched by default.
|
||||||
Additional paths might be watched by passing them as arguments to this flag.",
|
Additional paths might be watched by passing them as arguments to this flag.",
|
||||||
)
|
)
|
||||||
|
.value_hint(ValueHint::AnyPath)
|
||||||
} else {
|
} else {
|
||||||
arg.long_help(
|
arg.long_help(
|
||||||
"UNSTABLE: Watch for file changes and restart process automatically.
|
"UNSTABLE: Watch for file changes and restart process automatically.
|
||||||
|
@ -1880,6 +1918,7 @@ fn script_arg<'a>() -> Arg<'a> {
|
||||||
])
|
])
|
||||||
.help("Script arg")
|
.help("Script arg")
|
||||||
.value_name("SCRIPT_ARG")
|
.value_name("SCRIPT_ARG")
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn lock_arg<'a>() -> Arg<'a> {
|
fn lock_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1888,6 +1927,7 @@ fn lock_arg<'a>() -> Arg<'a> {
|
||||||
.value_name("FILE")
|
.value_name("FILE")
|
||||||
.help("Check the specified lock file")
|
.help("Check the specified lock file")
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn lock_write_arg<'a>() -> Arg<'a> {
|
fn lock_write_arg<'a>() -> Arg<'a> {
|
||||||
|
@ -1914,6 +1954,7 @@ subcommands like `deno lint` or `deno fmt`.
|
||||||
It's recommended to use `deno.json` or `deno.jsonc` as a filename.",
|
It's recommended to use `deno.json` or `deno.jsonc` as a filename.",
|
||||||
)
|
)
|
||||||
.takes_value(true)
|
.takes_value(true)
|
||||||
|
.value_hint(ValueHint::FilePath)
|
||||||
}
|
}
|
||||||
|
|
||||||
fn no_remote_arg<'a>() -> Arg<'a> {
|
fn no_remote_arg<'a>() -> Arg<'a> {
|
||||||
|
|
Loading…
Reference in a new issue