parser: check fn args in declarations too with `-Wimpure-v`
`v -Wimpure-v examples/2048/` now passes cleanly.pull/12379/head
parent
4bafc5042b
commit
c4e282a0c8
|
@ -122,7 +122,7 @@ pub fn (mut ctx Context) refresh_ui() {
|
||||||
ctx.ticks = 0
|
ctx.ticks = 0
|
||||||
}
|
}
|
||||||
|
|
||||||
fn gg_event_fn(ce &C.sapp_event, user_data voidptr) {
|
fn gg_event_fn(ce voidptr, user_data voidptr) {
|
||||||
// e := unsafe { &sapp.Event(ce) }
|
// e := unsafe { &sapp.Event(ce) }
|
||||||
mut e := unsafe { &Event(ce) }
|
mut e := unsafe { &Event(ce) }
|
||||||
mut g := unsafe { &Context(user_data) }
|
mut g := unsafe { &Context(user_data) }
|
||||||
|
|
|
@ -591,6 +591,10 @@ fn (mut p Parser) fn_receiver(mut params []ast.Param, mut rec ReceiverParsingInf
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if rec.language != .v {
|
||||||
|
p.check_for_impure_v(rec.language, rec.type_pos)
|
||||||
|
}
|
||||||
|
|
||||||
params << ast.Param{
|
params << ast.Param{
|
||||||
pos: rec_start_pos
|
pos: rec_start_pos
|
||||||
name: rec.name
|
name: rec.name
|
||||||
|
@ -833,6 +837,10 @@ fn (mut p Parser) fn_args() ([]ast.Param, bool, bool) {
|
||||||
}
|
}
|
||||||
p.next()
|
p.next()
|
||||||
}
|
}
|
||||||
|
alanguage := p.table.get_type_symbol(arg_type).language
|
||||||
|
if alanguage != .v {
|
||||||
|
p.check_for_impure_v(alanguage, pos)
|
||||||
|
}
|
||||||
args << ast.Param{
|
args << ast.Param{
|
||||||
pos: pos
|
pos: pos
|
||||||
name: ''
|
name: ''
|
||||||
|
@ -918,6 +926,10 @@ fn (mut p Parser) fn_args() ([]ast.Param, bool, bool) {
|
||||||
typ = ast.new_type(p.table.find_or_register_array(typ)).derive(typ).set_flag(.variadic)
|
typ = ast.new_type(p.table.find_or_register_array(typ)).derive(typ).set_flag(.variadic)
|
||||||
}
|
}
|
||||||
for i, arg_name in arg_names {
|
for i, arg_name in arg_names {
|
||||||
|
alanguage := p.table.get_type_symbol(typ).language
|
||||||
|
if alanguage != .v {
|
||||||
|
p.check_for_impure_v(alanguage, type_pos[i])
|
||||||
|
}
|
||||||
args << ast.Param{
|
args << ast.Param{
|
||||||
pos: arg_pos[i]
|
pos: arg_pos[i]
|
||||||
name: arg_name
|
name: arg_name
|
||||||
|
|
Loading…
Reference in New Issue