aboutsummaryrefslogtreecommitdiff
path: root/src/checker/expr.cpp
diff options
context:
space:
mode:
authorGinger Bill <bill@gingerbill.org>2016-10-07 09:41:38 +0100
committerGinger Bill <bill@gingerbill.org>2016-10-07 09:41:38 +0100
commitc5d20d2eef6c25b23c2aa69cdc1dbc7ce7d6753a (patch)
tree23c6a0a5badbf67634a000df4d856f384fc51176 /src/checker/expr.cpp
parentf40482aa29f687b4630744457844bad7f45ec614 (diff)
Demaybe operator ?
Diffstat (limited to 'src/checker/expr.cpp')
-rw-r--r--src/checker/expr.cpp62
1 files changed, 37 insertions, 25 deletions
diff --git a/src/checker/expr.cpp b/src/checker/expr.cpp
index 527b2d92d..26b8399d5 100644
--- a/src/checker/expr.cpp
+++ b/src/checker/expr.cpp
@@ -3028,31 +3028,6 @@ b32 check_builtin_procedure(Checker *c, Operand *operand, AstNode *call, i32 id)
operand->mode = Addressing_Value;
operand->type = t_string;
} break;
-
- case BuiltinProc_maybe_value: {
- Type *type = operand->type;
- if (!is_type_maybe(type)) {
- gbString type_str = type_to_string(operand->type);
- defer (gb_string_free(type_str));
- error(ast_node_token(call),
- "Expected a maybe to `maybe_value`, got `%s`",
- type_str);
- return false;
- }
-
- operand->mode = Addressing_Value;
-
- Entity **variables = gb_alloc_array(c->allocator, Entity *, 2);
- Type *elem = base_type(type)->Maybe.elem;
- Token t = make_token_ident(make_string(""));
- variables[0] = make_entity_param(c->allocator, NULL, t, elem, false);
- variables[1] = make_entity_param(c->allocator, NULL, t, t_bool, false);
-
- Type *tuple = make_type_tuple(c->allocator);
- tuple->Tuple.variables = variables;
- tuple->Tuple.variable_count = 2;
- operand->type = tuple;
- } break;
}
return true;
@@ -3270,6 +3245,10 @@ ExprKind check__expr_base(Checker *c, Operand *o, AstNode *node, Type *type_hint
o->type = t_invalid;
switch (node->kind) {
+ default:
+ goto error;
+ break;
+
case_ast_node(be, BadExpr, node)
goto error;
case_end;
@@ -3731,6 +3710,34 @@ ExprKind check__expr_base(Checker *c, Operand *o, AstNode *node, Type *type_hint
}
case_end;
+ case_ast_node(de, DemaybeExpr, node);
+ check_expr_or_type(c, o, de->expr);
+ if (o->mode == Addressing_Invalid) {
+ goto error;
+ } else {
+ Type *t = base_type(o->type);
+ if (t->kind == Type_Maybe) {
+ Entity **variables = gb_alloc_array(c->allocator, Entity *, 2);
+ Type *elem = t->Maybe.elem;
+ Token tok = make_token_ident(make_string(""));
+ variables[0] = make_entity_param(c->allocator, NULL, tok, elem, false);
+ variables[1] = make_entity_param(c->allocator, NULL, tok, t_bool, false);
+
+ Type *tuple = make_type_tuple(c->allocator);
+ tuple->Tuple.variables = variables;
+ tuple->Tuple.variable_count = 2;
+
+ o->type = tuple;
+ o->mode = Addressing_Variable;
+ } else {
+ gbString str = expr_to_string(o->expr);
+ error(ast_node_token(o->expr), "Cannot demaybe `%s`", str);
+ gb_string_free(str);
+ goto error;
+ }
+ }
+ case_end;
+
case AstNode_ProcType:
case AstNode_PointerType:
case AstNode_MaybeType:
@@ -3910,6 +3917,11 @@ gbString write_expr_to_string(gbString str, AstNode *node) {
str = gb_string_appendc(str, "^");
case_end;
+ case_ast_node(de, DemaybeExpr, node);
+ str = write_expr_to_string(str, de->expr);
+ str = gb_string_appendc(str, "?");
+ case_end;
+
case_ast_node(be, BinaryExpr, node);
str = write_expr_to_string(str, be->left);
str = gb_string_appendc(str, " ");