checker: make the method warning an error
parent
01dbb25a37
commit
9609b3a9c8
|
@ -2441,7 +2441,18 @@ fn (mut c Checker) fn_decl(it ast.FnDecl) {
|
|||
// }
|
||||
// Do not allow to modify types from other modules
|
||||
if sym.mod != c.mod && !c.is_builtin_mod && sym.mod != '' { // TODO remove != ''
|
||||
c.warn('cannot define methods on types from other modules (' + 'current module is `$c.mod`, `$sym.name` is from `$sym.mod`)',
|
||||
// remove the method to hide other related errors (`method is private` etc)
|
||||
mut idx := 0
|
||||
for i, m in sym.methods {
|
||||
if m.name == it.name {
|
||||
println('got it')
|
||||
idx = i
|
||||
break
|
||||
}
|
||||
}
|
||||
sym.methods.delete(idx)
|
||||
//
|
||||
c.error('cannot define new methods on non-local `$sym.name` (' + 'current module is `$c.mod`, `$sym.name` is from `$sym.mod`)',
|
||||
it.pos)
|
||||
}
|
||||
}
|
||||
|
|
|
@ -159,12 +159,6 @@ fn (mut p Parser) fn_decl() ast.FnDecl {
|
|||
// TODO: talk to alex, should mut be parsed with the type like this?
|
||||
// or should it be a property of the arg, like this ptr/mut becomes indistinguishable
|
||||
rec_type = p.parse_type_with_mut(rec_mut)
|
||||
/*
|
||||
sym := p.table.get_type_symbol(rec_type)
|
||||
if sym.mod != p.mod { // && sym.mod != '' {
|
||||
p.warn('cannot define methods on types from other modules (current module is `$p.mod`, `$sym.name` is from `$sym.mod`)')
|
||||
}
|
||||
*/
|
||||
if is_amp && rec_mut {
|
||||
p.error('use `(mut f Foo)` or `(f &Foo)` instead of `(mut f &Foo)`')
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue