aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2018-08-14 19:33:42 +0100
committergingerBill <bill@gingerbill.org>2018-08-14 19:33:42 +0100
commit2d41a42f61b28cc046321f88b2ab990abd2e1bec (patch)
tree73c850e5f368c98e96fac47d9f76f24dc53bc3a4 /src
parente1e4a916a5ffb81b4a9fbe6a2ca146db17c42bc8 (diff)
Cleaning type hinting for assignments
Diffstat (limited to 'src')
-rw-r--r--src/check_expr.cpp12
-rw-r--r--src/check_stmt.cpp2
2 files changed, 7 insertions, 7 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index df3a5dcff..41b5df135 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -3711,7 +3711,7 @@ isize add_dependencies_from_unpacking(CheckerContext *c, Entity **lhs, isize lhs
}
-void check_assignment_arguments(CheckerContext *ctx, Array<Operand> const &lhs, Array<Operand> *operands, Array<Ast *> const &rhs, bool allow_ok, bool *optional_ok_ = nullptr) {
+bool check_assignment_arguments(CheckerContext *ctx, Array<Operand> const &lhs, Array<Operand> *operands, Array<Ast *> const &rhs) {
bool optional_ok = false;
isize tuple_index = 0;
for_array(i, rhs) {
@@ -3733,7 +3733,7 @@ void check_assignment_arguments(CheckerContext *ctx, Array<Operand> const &lhs,
}
if (o.type == nullptr || o.type->kind != Type_Tuple) {
- if (allow_ok && lhs.count == 2 && rhs.count == 1 &&
+ if (lhs.count == 2 && rhs.count == 1 &&
(o.mode == Addressing_MapIndex || o.mode == Addressing_OptionalOk)) {
Type *tuple = make_optional_ok_type(o.type);
add_type_and_value(&c->checker->info, o.expr, o.mode, tuple, o.value);
@@ -3742,7 +3742,7 @@ void check_assignment_arguments(CheckerContext *ctx, Array<Operand> const &lhs,
Operand ok = o;
val.mode = Addressing_Value;
ok.mode = Addressing_Value;
- ok.type = t_bool;
+ ok.type = t_untyped_bool;
array_add(operands, val);
array_add(operands, ok);
@@ -3764,12 +3764,12 @@ void check_assignment_arguments(CheckerContext *ctx, Array<Operand> const &lhs,
}
}
- if (optional_ok_) *optional_ok_ = optional_ok;
+ return optional_ok;
}
-void check_unpack_arguments(CheckerContext *ctx, Entity **lhs, isize lhs_count, Array<Operand> *operands, Array<Ast *> const &rhs, bool allow_ok, bool *optional_ok_ = nullptr) {
+bool check_unpack_arguments(CheckerContext *ctx, Entity **lhs, isize lhs_count, Array<Operand> *operands, Array<Ast *> const &rhs, bool allow_ok) {
bool optional_ok = false;
isize tuple_index = 0;
for_array(i, rhs) {
@@ -3826,7 +3826,7 @@ void check_unpack_arguments(CheckerContext *ctx, Entity **lhs, isize lhs_count,
}
}
- if (optional_ok_) *optional_ok_ = optional_ok;
+ return optional_ok;
}
diff --git a/src/check_stmt.cpp b/src/check_stmt.cpp
index 1475d7b03..2040471b5 100644
--- a/src/check_stmt.cpp
+++ b/src/check_stmt.cpp
@@ -1122,7 +1122,7 @@ void check_stmt_internal(CheckerContext *ctx, Ast *node, u32 flags) {
}
}
- check_assignment_arguments(ctx, lhs_operands, &rhs_operands, as->rhs, true);
+ check_assignment_arguments(ctx, lhs_operands, &rhs_operands, as->rhs);
isize rhs_count = rhs_operands.count;
for_array(i, rhs_operands) {