1
0
Fork 0
mirror of https://github.com/denoland/deno.git synced 2024-12-22 15:24:46 -05:00

Improve 'deno lsp' help text (#9610)

This commit is contained in:
Ryan Dahl 2021-02-26 09:51:25 -05:00 committed by GitHub
parent 67ca978f97
commit 07eb009044
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 17 additions and 15 deletions

View file

@ -69,7 +69,7 @@ pub enum DenoSubcommand {
root: Option<PathBuf>,
force: bool,
},
LanguageServer,
Lsp,
Lint {
files: Vec<PathBuf>,
ignore: Vec<PathBuf>,
@ -331,7 +331,7 @@ pub fn flags_from_vec(args: Vec<String>) -> clap::Result<Flags> {
} else if let Some(m) = matches.subcommand_matches("compile") {
compile_parse(&mut flags, m);
} else if let Some(m) = matches.subcommand_matches("lsp") {
language_server_parse(&mut flags, m);
lsp_parse(&mut flags, m);
} else {
repl_parse(&mut flags, &matches);
}
@ -389,7 +389,7 @@ If the flag is set, restrict these messages to errors.",
.subcommand(fmt_subcommand())
.subcommand(info_subcommand())
.subcommand(install_subcommand())
.subcommand(language_server_subcommand())
.subcommand(lsp_subcommand())
.subcommand(lint_subcommand())
.subcommand(repl_subcommand())
.subcommand(run_subcommand())
@ -782,8 +782,8 @@ fn doc_parse(flags: &mut Flags, matches: &clap::ArgMatches) {
};
}
fn language_server_parse(flags: &mut Flags, _matches: &clap::ArgMatches) {
flags.subcommand = DenoSubcommand::LanguageServer;
fn lsp_parse(flags: &mut Flags, _matches: &clap::ArgMatches) {
flags.subcommand = DenoSubcommand::Lsp;
}
fn lint_parse(flags: &mut Flags, matches: &clap::ArgMatches) {
@ -1288,15 +1288,17 @@ Show documentation for runtime built-ins:
)
}
fn language_server_subcommand<'a, 'b>() -> App<'a, 'b> {
fn lsp_subcommand<'a, 'b>() -> App<'a, 'b> {
SubCommand::with_name("lsp")
.about("Start the language server")
.long_about(
r#"Start the Deno language server which will take input
from stdin and provide output to stdout.
deno lsp
"#,
)
"The 'deno lsp' subcommand provides a way for code editors and IDEs to
interact with Deno using the Language Server Protocol. Usually humans do not
use this subcommand directly. For example, 'deno lsp' can provide IDEs with
go-to-definition support and automatic code formatting.
How to connect various editors and IDEs to 'deno lsp':
https://deno.land/manual/getting_started/setup_your_environment#editors-and-ides")
}
fn lint_subcommand<'a, 'b>() -> App<'a, 'b> {
@ -2186,12 +2188,12 @@ mod tests {
}
#[test]
fn language_server() {
fn lsp() {
let r = flags_from_vec(svec!["deno", "lsp"]);
assert_eq!(
r.unwrap(),
Flags {
subcommand: DenoSubcommand::LanguageServer,
subcommand: DenoSubcommand::Lsp,
..Flags::default()
}
);

View file

@ -417,7 +417,7 @@ async fn install_command(
tools::installer::install(flags, &module_url, args, name, root, force)
}
async fn language_server_command() -> Result<(), AnyError> {
async fn lsp_command() -> Result<(), AnyError> {
lsp::start().await
}
@ -1099,7 +1099,7 @@ fn get_subcommand(
} => {
install_command(flags, module_url, args, name, root, force).boxed_local()
}
DenoSubcommand::LanguageServer => language_server_command().boxed_local(),
DenoSubcommand::Lsp => lsp_command().boxed_local(),
DenoSubcommand::Lint {
files,
rules,