mirror of
https://github.com/denoland/deno.git
synced 2025-01-11 16:42:21 -05:00
fix(doc): deno doc --lint mod.ts
should output how many files checked (#21084)
As pointed out in https://github.com/denoland/deno/issues/21067 , it's confusing that `deno doc --lint mod.ts` outputs the documentation to stdout on success. Instead, it would be better if it outputted how many files were checked similar to what `deno lint` does on success. It still outputs the documentation if `--lint` or `--html` are provided so this is non-breaking.
This commit is contained in:
parent
efa1c1c964
commit
8acf059ac6
7 changed files with 94 additions and 27 deletions
|
@ -70,6 +70,23 @@ itest!(deno_doc_html_lint_referenced_private_types_fixed {
|
||||||
output: "doc/referenced_private_types_lint.out",
|
output: "doc/referenced_private_types_lint.out",
|
||||||
});
|
});
|
||||||
|
|
||||||
|
itest!(deno_doc_lint_success {
|
||||||
|
args: "doc --lint doc/lint_success.ts",
|
||||||
|
output: "doc/lint_success.out",
|
||||||
|
});
|
||||||
|
|
||||||
|
itest!(deno_doc_lint_json_success {
|
||||||
|
args: "doc --lint --json doc/lint_success.ts",
|
||||||
|
output: "doc/lint_success_json.out",
|
||||||
|
});
|
||||||
|
|
||||||
|
itest!(deno_doc_lint_html_success {
|
||||||
|
args: "doc --lint --html --name=Library lint_success.ts",
|
||||||
|
copy_temp_dir: Some("doc"),
|
||||||
|
cwd: Some("doc"),
|
||||||
|
output: "doc/lint_success_html.out",
|
||||||
|
});
|
||||||
|
|
||||||
itest!(_060_deno_doc_displays_all_overloads_in_details_view {
|
itest!(_060_deno_doc_displays_all_overloads_in_details_view {
|
||||||
args:
|
args:
|
||||||
"doc --filter NS.test doc/060_deno_doc_displays_all_overloads_in_details_view.ts",
|
"doc --filter NS.test doc/060_deno_doc_displays_all_overloads_in_details_view.ts",
|
||||||
|
|
1
cli/tests/testdata/doc/lint_success.out
vendored
Normal file
1
cli/tests/testdata/doc/lint_success.out
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Checked 1 file
|
5
cli/tests/testdata/doc/lint_success.ts
vendored
Normal file
5
cli/tests/testdata/doc/lint_success.ts
vendored
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
/** My test class. */
|
||||||
|
export class Test {
|
||||||
|
/** My property. */
|
||||||
|
prop: string;
|
||||||
|
}
|
1
cli/tests/testdata/doc/lint_success_html.out
vendored
Normal file
1
cli/tests/testdata/doc/lint_success_html.out
vendored
Normal file
|
@ -0,0 +1 @@
|
||||||
|
Written 7 files to "./docs/"
|
48
cli/tests/testdata/doc/lint_success_json.out
vendored
Normal file
48
cli/tests/testdata/doc/lint_success_json.out
vendored
Normal file
|
@ -0,0 +1,48 @@
|
||||||
|
[
|
||||||
|
{
|
||||||
|
"kind": "class",
|
||||||
|
"name": "Test",
|
||||||
|
"location": {
|
||||||
|
"filename": "file:///[WILDCARD]/lint_success.ts",
|
||||||
|
"line": 2,
|
||||||
|
"col": 0
|
||||||
|
},
|
||||||
|
"declarationKind": "export",
|
||||||
|
"jsDoc": {
|
||||||
|
"doc": "My test class."
|
||||||
|
},
|
||||||
|
"classDef": {
|
||||||
|
"isAbstract": false,
|
||||||
|
"constructors": [],
|
||||||
|
"properties": [
|
||||||
|
{
|
||||||
|
"jsDoc": {
|
||||||
|
"doc": "My property."
|
||||||
|
},
|
||||||
|
"tsType": {
|
||||||
|
"repr": "string",
|
||||||
|
"kind": "keyword",
|
||||||
|
"keyword": "string"
|
||||||
|
},
|
||||||
|
"readonly": false,
|
||||||
|
"accessibility": null,
|
||||||
|
"optional": false,
|
||||||
|
"isAbstract": false,
|
||||||
|
"isStatic": false,
|
||||||
|
"name": "prop",
|
||||||
|
"location": {
|
||||||
|
"filename": "file:///[WILDCARD]/lint_success.ts",
|
||||||
|
"line": 4,
|
||||||
|
"col": 2
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"indexSignatures": [],
|
||||||
|
"methods": [],
|
||||||
|
"extends": null,
|
||||||
|
"implements": [],
|
||||||
|
"typeParams": [],
|
||||||
|
"superTypeParams": []
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
|
@ -1,16 +1 @@
|
||||||
Defined in file:///[WILDCARD]/referenced_private_types_fixed.ts:8:1
|
Checked 1 file
|
||||||
|
|
||||||
class MyClass
|
|
||||||
Doc comment
|
|
||||||
|
|
||||||
prop: MyInterface
|
|
||||||
Doc comment
|
|
||||||
|
|
||||||
Defined in file:///[WILDCARD]/referenced_private_types_fixed.ts:2:1
|
|
||||||
|
|
||||||
interface MyInterface
|
|
||||||
Doc comment
|
|
||||||
|
|
||||||
prop?: string
|
|
||||||
Doc comment
|
|
||||||
|
|
||||||
|
|
|
@ -138,9 +138,9 @@ pub async fn doc(flags: Flags, doc_flags: DocFlags) -> Result<(), AnyError> {
|
||||||
let mut doc_nodes_by_url =
|
let mut doc_nodes_by_url =
|
||||||
IndexMap::with_capacity(module_specifiers.len());
|
IndexMap::with_capacity(module_specifiers.len());
|
||||||
|
|
||||||
for module_specifier in &module_specifiers {
|
for module_specifier in module_specifiers {
|
||||||
let nodes = doc_parser.parse_with_reexports(module_specifier)?;
|
let nodes = doc_parser.parse_with_reexports(&module_specifier)?;
|
||||||
doc_nodes_by_url.insert(module_specifier.clone(), nodes);
|
doc_nodes_by_url.insert(module_specifier, nodes);
|
||||||
}
|
}
|
||||||
|
|
||||||
if doc_flags.lint {
|
if doc_flags.lint {
|
||||||
|
@ -157,9 +157,23 @@ pub async fn doc(flags: Flags, doc_flags: DocFlags) -> Result<(), AnyError> {
|
||||||
.boxed_local()
|
.boxed_local()
|
||||||
.await
|
.await
|
||||||
} else {
|
} else {
|
||||||
let doc_nodes: Vec<doc::DocNode> =
|
let modules_len = doc_nodes_by_url.len();
|
||||||
doc_nodes_by_url.values().flatten().cloned().collect();
|
let doc_nodes =
|
||||||
print_docs(doc_flags, doc_nodes)
|
doc_nodes_by_url.into_values().flatten().collect::<Vec<_>>();
|
||||||
|
|
||||||
|
if doc_flags.json {
|
||||||
|
write_json_to_stdout(&doc_nodes)
|
||||||
|
} else if doc_flags.lint {
|
||||||
|
// don't output docs if running with only the --lint flag
|
||||||
|
log::info!(
|
||||||
|
"Checked {} file{}",
|
||||||
|
modules_len,
|
||||||
|
if modules_len == 1 { "" } else { "s" }
|
||||||
|
);
|
||||||
|
Ok(())
|
||||||
|
} else {
|
||||||
|
print_docs_to_stdout(doc_flags, doc_nodes)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -204,14 +218,10 @@ async fn generate_docs_directory(
|
||||||
Ok(())
|
Ok(())
|
||||||
}
|
}
|
||||||
|
|
||||||
fn print_docs(
|
fn print_docs_to_stdout(
|
||||||
doc_flags: DocFlags,
|
doc_flags: DocFlags,
|
||||||
mut doc_nodes: Vec<deno_doc::DocNode>,
|
mut doc_nodes: Vec<deno_doc::DocNode>,
|
||||||
) -> Result<(), AnyError> {
|
) -> Result<(), AnyError> {
|
||||||
if doc_flags.json {
|
|
||||||
return write_json_to_stdout(&doc_nodes);
|
|
||||||
}
|
|
||||||
|
|
||||||
doc_nodes.retain(|doc_node| doc_node.kind != doc::DocNodeKind::Import);
|
doc_nodes.retain(|doc_node| doc_node.kind != doc::DocNodeKind::Import);
|
||||||
let details = if let Some(filter) = doc_flags.filter {
|
let details = if let Some(filter) = doc_flags.filter {
|
||||||
let nodes = doc::find_nodes_by_name_recursively(doc_nodes, filter.clone());
|
let nodes = doc::find_nodes_by_name_recursively(doc_nodes, filter.clone());
|
||||||
|
|
Loading…
Reference in a new issue