mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
use defer
This commit is contained in:
parent
17c6ba04a2
commit
100bcc2034
@ -114,6 +114,7 @@ fn new_fn(pkg string, is_public bool) *Fn {
|
|||||||
// Function signatures are added to the top of the .c file in the first run.
|
// Function signatures are added to the top of the .c file in the first run.
|
||||||
fn (p mut Parser) fn_decl() {
|
fn (p mut Parser) fn_decl() {
|
||||||
p.fgen('fn ')
|
p.fgen('fn ')
|
||||||
|
defer { p.fgenln('\n') }
|
||||||
is_pub := p.tok == .key_pub
|
is_pub := p.tok == .key_pub
|
||||||
is_live := p.attr == 'live' && !p.pref.is_so
|
is_live := p.attr == 'live' && !p.pref.is_so
|
||||||
if is_live && !p.pref.is_live {
|
if is_live && !p.pref.is_live {
|
||||||
@ -344,7 +345,6 @@ fn (p mut Parser) fn_decl() {
|
|||||||
}
|
}
|
||||||
p.cgen.fns << fn_decl + ';'
|
p.cgen.fns << fn_decl + ';'
|
||||||
}
|
}
|
||||||
p.fgenln('\n')// TODO defer this instead of copy pasting
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
if f.name == 'main' || f.name == 'WinMain' {
|
if f.name == 'main' || f.name == 'WinMain' {
|
||||||
@ -373,7 +373,6 @@ pthread_create(&_thread_so , NULL, &reload_so, NULL); ')
|
|||||||
// println('is_c=$is_c name=$f.name')
|
// println('is_c=$is_c name=$f.name')
|
||||||
if is_c || is_sig || is_fn_header {
|
if is_c || is_sig || is_fn_header {
|
||||||
// println('IS SIG .key_returnING tok=${p.strtok()}')
|
// println('IS SIG .key_returnING tok=${p.strtok()}')
|
||||||
p.fgenln('\n')
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
// We are in profile mode? Start counting at the beginning of the function (save current time).
|
// We are in profile mode? Start counting at the beginning of the function (save current time).
|
||||||
@ -403,12 +402,10 @@ pthread_create(&_thread_so , NULL, &reload_so, NULL); ')
|
|||||||
// if p.builtin_pkg || p.mod == 'os' ||p.mod=='http'{
|
// if p.builtin_pkg || p.mod == 'os' ||p.mod=='http'{
|
||||||
if p.mod != 'main' {
|
if p.mod != 'main' {
|
||||||
p.genln('}')
|
p.genln('}')
|
||||||
p.fgenln('\n')
|
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
p.check_unused_variables()
|
p.check_unused_variables()
|
||||||
p.cur_fn = EmptyFn
|
p.cur_fn = EmptyFn
|
||||||
p.fgenln('\n')
|
|
||||||
p.genln('}')
|
p.genln('}')
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -555,7 +552,7 @@ fn (p mut Parser) fn_call(f Fn, method_ph int, receiver_var, receiver_type strin
|
|||||||
// return an updated Fn object with args[] field set
|
// return an updated Fn object with args[] field set
|
||||||
fn (p mut Parser) fn_args(f mut Fn) {
|
fn (p mut Parser) fn_args(f mut Fn) {
|
||||||
p.check(.lpar)
|
p.check(.lpar)
|
||||||
// TODO defer p.check(.rpar)
|
defer { p.check(.rpar) }
|
||||||
if f.is_interface {
|
if f.is_interface {
|
||||||
int_arg := Var {
|
int_arg := Var {
|
||||||
typ: f.receiver_typ
|
typ: f.receiver_typ
|
||||||
@ -626,7 +623,6 @@ fn (p mut Parser) fn_args(f mut Fn) {
|
|||||||
p.next()
|
p.next()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
p.check(.rpar)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
fn (p mut Parser) fn_call_args(f *Fn) *Fn {
|
fn (p mut Parser) fn_call_args(f *Fn) *Fn {
|
||||||
|
Loading…
Reference in New Issue
Block a user