checker: make sure all FnDecl types are valid
parent
3c08f655af
commit
270566055f
|
@ -356,6 +356,8 @@ pub fn (a []byte) contains(val byte) bool {
|
|||
return false
|
||||
}
|
||||
|
||||
|
||||
/*
|
||||
pub fn (c rune) str() string {
|
||||
fst_byte := int(c)>>8 * 3 & 0xff
|
||||
len := utf8_char_len(fst_byte)
|
||||
|
@ -369,6 +371,7 @@ pub fn (c rune) str() string {
|
|||
str.str[len] = `\0`
|
||||
return str
|
||||
}
|
||||
*/
|
||||
|
||||
pub fn (c byte) str() string {
|
||||
mut str := string{
|
||||
|
|
|
@ -1217,6 +1217,15 @@ fn (mut c Checker) stmt(node ast.Stmt) {
|
|||
// c.warn('duplicate method `$it.name`', it.pos)
|
||||
// }
|
||||
// }
|
||||
if !it.is_c {
|
||||
// Make sure all types are valid
|
||||
for arg in it.args {
|
||||
sym := c.table.get_type_symbol(arg.typ)
|
||||
if sym.kind == .placeholder {
|
||||
c.error('unknown type `$sym.name`', it.pos)
|
||||
}
|
||||
}
|
||||
}
|
||||
c.expected_type = table.void_type
|
||||
c.fn_return_type = it.return_type
|
||||
c.stmts(it.stmts)
|
||||
|
|
Loading…
Reference in New Issue