Revert 'compiler: allow mut passed as argument to be modified'. This broke

pull/792/head
Alexander Medvednikov 2019-06-29 11:41:17 +02:00
parent e4bfd32191
commit 249fa95eab
2 changed files with 1 additions and 23 deletions

View File

@ -1197,7 +1197,7 @@ fn (p mut Parser) name_expr() string {
hack_lit := p.lit
// amp
ptr := p.tok == AMP
mut deref := p.tok == MUL
deref := p.tok == MUL
if ptr || deref {
p.next()
}
@ -1241,7 +1241,6 @@ fn (p mut Parser) name_expr() string {
// Variable
v := p.cur_fn.find_var(name)
if v.name.len != 0 {
deref = deref || (v.is_arg && v.is_mut && is_mutable_type(v.typ))
if ptr {
p.gen('& /*vvar*/ ')
}

View File

@ -713,24 +713,3 @@ fn (s mut Scanner) create_type_string(T Type, name string) {
fn (p mut Parser) create_type_string(T Type, name string) {
p.scanner.create_type_string(T, name)
}
//Checks if mut type can be dereferenced to be modified
fn is_mutable_type(typ string) bool {
if typ == 'bool*' {
return true
}
if typ == 'int*' || typ == 'rune*' || typ == 'i8*' ||
typ == 'i16*' || typ == 'i32*' || typ == 'i64*' {
return true
}
if typ == 'byte*' || typ == 'u8*' || typ == 'u16*' ||
typ == 'u32*' || typ == 'u64*' {
return true
}
if typ == 'f32*' || typ == 'f64*' {
return true
}
if typ == 'string*' {
return true
}
}