aboutsummaryrefslogtreecommitdiff
path: root/src/check_expr.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2024-03-23 16:51:04 +0000
committergingerBill <bill@gingerbill.org>2024-03-23 16:51:04 +0000
commit1d46adb598328b4977d5b4cfad2a1dc679b05a21 (patch)
treec74cbdb96967efbb05b58e6f4a059f7d5123bb8f /src/check_expr.cpp
parent61aa4558dc864019192072ff9a7f1f1ee23096bf (diff)
Treat `*x` as an unary operator to improve error messages for common C-programmer mistakes
Diffstat (limited to 'src/check_expr.cpp')
-rw-r--r--src/check_expr.cpp13
1 files changed, 13 insertions, 0 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index d1f393bef..f09c8fe3c 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -1800,6 +1800,19 @@ gb_internal bool check_unary_op(CheckerContext *c, Operand *o, Token op) {
}
break;
+ case Token_Mul:
+ {
+ ERROR_BLOCK();
+ error(op, "Operator '%.*s' is not a valid unary operator in Odin", LIT(op.string));
+ if (is_type_pointer(o->type)) {
+ str = expr_to_string(o->expr);
+ error_line("\tSuggestion: Did you mean '%s^'?\n", str);
+ } else if (is_type_multi_pointer(o->type)) {
+ str = expr_to_string(o->expr);
+ error_line("\tSuggestion: The value is a multi-pointer, did you mean '%s[0]'?\n", str);
+ }
+ }
+ break;
default:
error(op, "Unknown operator '%.*s'", LIT(op.string));
return false;