mirror of
https://github.com/vlang/v.git
synced 2023-08-10 21:13:21 +03:00
checker: allow casting from floats/enums to byte
This commit is contained in:
parent
aa81ebb600
commit
628b136e85
@ -2627,8 +2627,9 @@ pub fn (mut c Checker) expr(node ast.Expr) table.Type {
|
|||||||
}
|
}
|
||||||
c.error(error_msg, node.pos)
|
c.error(error_msg, node.pos)
|
||||||
}
|
}
|
||||||
} else if !node.expr_type.is_int() && node.expr_type != table.voidptr_type && !node.expr_type.is_ptr() &&
|
} else if to_type_sym.kind == .byte &&
|
||||||
to_type_sym.kind == .byte {
|
node.expr_type != table.voidptr_type && from_type_sym.kind != .enum_ && !node.expr_type.is_int() &&
|
||||||
|
!node.expr_type.is_float() && !node.expr_type.is_ptr() {
|
||||||
type_name := c.table.type_to_str(node.expr_type)
|
type_name := c.table.type_to_str(node.expr_type)
|
||||||
c.error('cannot cast type `$type_name` to `byte`', node.pos)
|
c.error('cannot cast type `$type_name` to `byte`', node.pos)
|
||||||
} else if to_type_sym.kind == .struct_ && !node.typ.is_ptr() && !(to_type_sym.info as table.Struct).is_typedef {
|
} else if to_type_sym.kind == .struct_ && !node.typ.is_ptr() && !(to_type_sym.info as table.Struct).is_typedef {
|
||||||
|
Loading…
Reference in New Issue
Block a user