ci: run v vet vlib/v/parser

pull/5612/head
Alexander Medvednikov 2020-07-01 18:57:14 +02:00
parent 40a393926d
commit da99868a28
3 changed files with 25 additions and 10 deletions

View File

@ -42,6 +42,9 @@ jobs:
run: ./v test-fixed
- name: Test building v tools
run: ./v build-tools
- name: v vet
run: |
v vet vlib/v/parser
# - name: Test v binaries
# run: ./v -silent build-vbinaries

View File

@ -0,0 +1,7 @@
struct User {
name string // name
// last comment
// last comment2
}

View File

@ -220,7 +220,8 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
mut end_pos := p.prev_tok.position()
// Return type
mut return_type := table.void_type
if p.tok.kind.is_start_of_type() || (p.tok.kind == .key_fn && p.tok.line_nr == p.prev_tok.line_nr) {
if p.tok.kind.is_start_of_type() || (p.tok.kind == .key_fn &&
p.tok.line_nr == p.prev_tok.line_nr) {
end_pos = p.tok.position()
return_type = p.parse_type()
}
@ -251,7 +252,7 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
if _ := p.table.find_fn(name) {
p.fn_redefinition_error(name)
}
//p.warn('reg functn $name ()')
// p.warn('reg functn $name ()')
p.table.register_fn(table.Fn{
name: name
args: args
@ -273,9 +274,12 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
if p.tok.kind == .lcbr {
stmts = p.parse_block_no_scope(true)
// Add return if `fn(...) ? {...}` have no return at end
if return_type != table.void_type && p.table.get_type_symbol(return_type).kind == .void &&
return_type.has_flag(.optional) && (stmts.len == 0 || stmts[stmts.len-1] !is ast.Return) {
stmts << ast.Return{ pos: p.tok.position() }
if return_type != table.void_type &&
p.table.get_type_symbol(return_type).kind == .void && return_type.has_flag(.optional) &&
(stmts.len == 0 || stmts[stmts.len - 1] !is ast.Return) {
stmts << ast.Return{
pos: p.tok.position()
}
}
}
p.close_scope()
@ -376,7 +380,8 @@ fn (mut p Parser) fn_args() ([]table.Arg, bool, bool) {
mut is_variadic := false
// `int, int, string` (no names, just types)
argname := if p.tok.kind == .name && p.tok.lit.len > 0 && p.tok.lit[0].is_capital() { p.prepend_mod(p.tok.lit) } else { p.tok.lit }
types_only := p.tok.kind in [.amp, .ellipsis, .key_fn] || (p.peek_tok.kind == .comma && p.table.known_type(argname)) ||
types_only := p.tok.kind in [.amp, .ellipsis, .key_fn] ||
(p.peek_tok.kind == .comma && p.table.known_type(argname)) ||
p.peek_tok.kind == .rpar
// TODO copy pasta, merge 2 branches
if types_only {