tools: tweak missdoc defaults, add CLI flags to control what's ignored (#13384)
parent
fd9aa8bee6
commit
31df2c4f45
|
@ -6,7 +6,7 @@ import flag
|
||||||
|
|
||||||
const (
|
const (
|
||||||
tool_name = os.file_name(os.executable())
|
tool_name = os.file_name(os.executable())
|
||||||
tool_version = '0.0.2'
|
tool_version = '0.0.3'
|
||||||
tool_description = 'Prints all V functions in .v files under PATH/, that do not yet have documentation comments.'
|
tool_description = 'Prints all V functions in .v files under PATH/, that do not yet have documentation comments.'
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -20,6 +20,8 @@ struct Options {
|
||||||
show_help bool
|
show_help bool
|
||||||
collect_tags bool
|
collect_tags bool
|
||||||
deprecated bool
|
deprecated bool
|
||||||
|
private bool
|
||||||
|
js bool
|
||||||
}
|
}
|
||||||
|
|
||||||
fn collect(path string, mut l []string, f fn (string, mut []string)) {
|
fn collect(path string, mut l []string, f fn (string, mut []string)) {
|
||||||
|
@ -50,6 +52,9 @@ fn report_undocumented_functions_in_path(opt Options, path string) {
|
||||||
if file.ends_with('_test.v') {
|
if file.ends_with('_test.v') {
|
||||||
continue
|
continue
|
||||||
}
|
}
|
||||||
|
if !opt.js && file.ends_with('.js.v') {
|
||||||
|
continue
|
||||||
|
}
|
||||||
report_undocumented_functions_in_file(opt, file)
|
report_undocumented_functions_in_file(opt, file)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -59,8 +64,8 @@ fn report_undocumented_functions_in_file(opt Options, file string) {
|
||||||
lines := contents.split('\n')
|
lines := contents.split('\n')
|
||||||
mut info := []UndocumentedFN{}
|
mut info := []UndocumentedFN{}
|
||||||
for i, line in lines {
|
for i, line in lines {
|
||||||
if line.starts_with('pub fn') || (line.starts_with('fn ') && !(line.starts_with('fn C.')
|
if line.starts_with('pub fn') || (opt.private && (line.starts_with('fn ')
|
||||||
|| line.starts_with('fn main'))) {
|
&& !(line.starts_with('fn C.') || line.starts_with('fn main')))) {
|
||||||
// println('Match: $line')
|
// println('Match: $line')
|
||||||
if i > 0 && lines.len > 0 {
|
if i > 0 && lines.len > 0 {
|
||||||
mut line_above := lines[i - 1]
|
mut line_above := lines[i - 1]
|
||||||
|
@ -125,6 +130,8 @@ fn main() {
|
||||||
opt := Options{
|
opt := Options{
|
||||||
show_help: fp.bool('help', `h`, false, 'Show this help text.')
|
show_help: fp.bool('help', `h`, false, 'Show this help text.')
|
||||||
deprecated: fp.bool('deprecated', `d`, false, 'Include deprecated functions in output.')
|
deprecated: fp.bool('deprecated', `d`, false, 'Include deprecated functions in output.')
|
||||||
|
private: fp.bool('private', `p`, false, 'Include private functions in output.')
|
||||||
|
js: fp.bool('js', 0, false, 'Include JavaScript functions in output.')
|
||||||
collect_tags: fp.bool('tags', `t`, false, 'Also print function tags if any is found.')
|
collect_tags: fp.bool('tags', `t`, false, 'Also print function tags if any is found.')
|
||||||
}
|
}
|
||||||
if opt.show_help {
|
if opt.show_help {
|
||||||
|
|
Loading…
Reference in New Issue