aboutsummaryrefslogtreecommitdiff
path: root/src/check_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2021-10-23 19:24:47 +0100
committergingerBill <bill@gingerbill.org>2021-10-23 19:24:47 +0100
commitb4df51e4834cda2d37a353717133663e9e1393c3 (patch)
treed98a3621bed8e2079c9f9d5794d3fd24bd9269b3 /src/check_expr.cpp
parent209684d5a4843fd52a248acd361b9791a96e6205 (diff)
parent06f47621442973a664b5928bb20295f4b7b56196 (diff)
Merge branch 'master' into new-matrix-type
Diffstat (limited to 'src/check_expr.cpp')
-rw-r--r--src/check_expr.cpp30
1 files changed, 21 insertions, 9 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index ee7493553..d8ca190b7 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -837,7 +837,7 @@ void check_assignment(CheckerContext *c, Operand *operand, Type *type, String co
operand->mode = Addressing_Invalid;
}
-
+ convert_to_typed(c, operand, type);
return;
}
@@ -3208,6 +3208,10 @@ void update_untyped_expr_type(CheckerContext *c, Ast *e, Type *type, bool final)
if (type != nullptr && type != t_invalid) {
if (e->tav.type == nullptr || e->tav.type == t_invalid) {
add_type_and_value(c->info, e, e->tav.mode, type ? type : e->tav.type, e->tav.value);
+ if (e->kind == Ast_TernaryIfExpr) {
+ update_untyped_expr_type(c, e->TernaryIfExpr.x, type, final);
+ update_untyped_expr_type(c, e->TernaryIfExpr.y, type, final);
+ }
}
}
return;
@@ -3414,9 +3418,9 @@ void convert_to_typed(CheckerContext *c, Operand *operand, Type *target_type) {
case Basic_UntypedNil:
if (is_type_any(target_type)) {
- target_type = t_untyped_nil;
+ // target_type = t_untyped_nil;
} else if (is_type_cstring(target_type)) {
- target_type = t_untyped_nil;
+ // target_type = t_untyped_nil;
} else if (!type_has_nil(target_type)) {
operand->mode = Addressing_Invalid;
convert_untyped_error(c, operand, target_type);
@@ -3587,6 +3591,14 @@ void convert_to_typed(CheckerContext *c, Operand *operand, Type *target_type) {
}
break;
}
+
+ if (is_type_any(target_type) && is_type_untyped(operand->type)) {
+ if (is_type_untyped_nil(operand->type) && is_type_untyped_undef(operand->type)) {
+
+ } else {
+ target_type = default_type(operand->type);
+ }
+ }
update_untyped_expr_type(c, operand->expr, target_type, true);
operand->type = target_type;
@@ -7030,18 +7042,18 @@ ExprKind check_expr_base_internal(CheckerContext *c, Operand *o, Ast *node, Type
return kind;
}
- Type *type = x.type;
- if (is_type_untyped_nil(type) || is_type_untyped_undef(type)) {
- type = y.type;
+ o->type = x.type;
+ if (is_type_untyped_nil(o->type) || is_type_untyped_undef(o->type)) {
+ o->type = y.type;
}
- o->type = type;
o->mode = Addressing_Value;
- if (type_hint != nullptr && is_type_untyped(type)) {
+ o->expr = node;
+ if (type_hint != nullptr && is_type_untyped(o->type)) {
if (check_cast_internal(c, &x, type_hint) &&
check_cast_internal(c, &y, type_hint)) {
+ convert_to_typed(c, o, type_hint);
update_untyped_expr_type(c, node, type_hint, !is_type_untyped(type_hint));
- o->type = type_hint;
}
}
case_end;