missdoc: add support for single files as arguments (#7894)

pull/7897/head
Larpon 2021-01-05 15:13:01 +01:00 committed by GitHub
parent 5841d5d8e1
commit 2aea11e607
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
1 changed files with 47 additions and 40 deletions

View File

@ -46,52 +46,55 @@ fn report_undocumented_functions_in_path(opt Options, path string) {
} }
} }
collect(path, mut files, collect_fn) collect(path, mut files, collect_fn)
for f in files { for file in files {
contents := os.read_file(f) or { panic(err) } if file.ends_with('_test.v') {
lines := contents.split('\n')
// Skip test files
if f.ends_with('_test.v') {
continue continue
} }
mut info := []UndocumentedFN{} report_undocumented_functions_in_file(opt, file)
for i, line in lines { }
if line.starts_with('pub fn') || }
(line.starts_with('fn ') && !(line.starts_with('fn C.') || line.starts_with('fn main'))) {
// println('Match: $line') fn report_undocumented_functions_in_file(opt Options, file string) {
if i > 0 && lines.len > 0 { contents := os.read_file(file) or { panic(err) }
mut line_above := lines[i - 1] lines := contents.split('\n')
if !line_above.starts_with('//') { mut info := []UndocumentedFN{}
mut tags := []string{} for i, line in lines {
mut grab := true if line.starts_with('pub fn') ||
for j := i - 1; j >= 0; j-- { (line.starts_with('fn ') && !(line.starts_with('fn C.') || line.starts_with('fn main'))) {
prev_line := lines[j] // println('Match: $line')
if prev_line.contains('}') { // We've looked back to the above scope, stop here if i > 0 && lines.len > 0 {
break mut line_above := lines[i - 1]
} else if prev_line.starts_with('[') { if !line_above.starts_with('//') {
tags << collect_tags(prev_line) mut tags := []string{}
continue mut grab := true
} else if prev_line.starts_with('//') { // Single-line comment for j := i - 1; j >= 0; j-- {
grab = false prev_line := lines[j]
break if prev_line.contains('}') { // We've looked back to the above scope, stop here
} break
} } else if prev_line.starts_with('[') {
if grab { tags << collect_tags(prev_line)
clean_line := line.all_before_last(' {') continue
info << UndocumentedFN{i + 1, clean_line, tags} } else if prev_line.starts_with('//') { // Single-line comment
grab = false
break
} }
} }
if grab {
clean_line := line.all_before_last(' {')
info << UndocumentedFN{i + 1, clean_line, tags}
}
} }
} }
} }
if info.len > 0 { }
for undocumented_fn in info { if info.len > 0 {
tags_str := if opt.collect_tags && undocumented_fn.tags.len > 0 { '$undocumented_fn.tags' } else { '' } for undocumented_fn in info {
if opt.deprecated { tags_str := if opt.collect_tags && undocumented_fn.tags.len > 0 { '$undocumented_fn.tags' } else { '' }
println('$f:$undocumented_fn.line:0:$undocumented_fn.signature $tags_str') if opt.deprecated {
} else { println('$file:$undocumented_fn.line:0:$undocumented_fn.signature $tags_str')
if 'deprecated' !in undocumented_fn.tags { } else {
println('$f:$undocumented_fn.line:0:$undocumented_fn.signature $tags_str') if 'deprecated' !in undocumented_fn.tags {
} println('$file:$undocumented_fn.line:0:$undocumented_fn.signature $tags_str')
} }
} }
} }
@ -125,6 +128,10 @@ fn main() {
exit(0) exit(0)
} }
for path in os.args[1..] { for path in os.args[1..] {
report_undocumented_functions_in_path(opt, path) if os.is_file(path) {
report_undocumented_functions_in_file(opt, path)
} else {
report_undocumented_functions_in_path(opt, path)
}
} }
} }