aboutsummaryrefslogtreecommitdiff
path: root/src/check_expr.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/check_expr.cpp')
-rw-r--r--src/check_expr.cpp9
1 files changed, 6 insertions, 3 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp
index 1168a9ba3..0a42c6618 100644
--- a/src/check_expr.cpp
+++ b/src/check_expr.cpp
@@ -2053,15 +2053,18 @@ bool check_is_expressible(CheckerContext *ctx, Operand *o, Type *type) {
o->mode = Addressing_Invalid;
);
+ gbString s = exact_value_to_string(o->value);
+ defer (gb_string_free(s));
+
if (is_type_numeric(o->type) && is_type_numeric(type)) {
if (!is_type_integer(o->type) && is_type_integer(type)) {
- error(o->expr, "'%s' truncated to '%s'", a, b);
+ error(o->expr, "'%s' truncated to '%s', got %s", a, b, s);
} else {
- error(o->expr, "Cannot convert numeric value '%s' to '%s' from '%s", a, b, c);
+ error(o->expr, "Cannot convert numeric value '%s' to '%s' from '%s', got %s", a, b, c, s);
check_assignment_error_suggestion(ctx, o, type);
}
} else {
- error(o->expr, "Cannot convert '%s' to '%s' from '%s", a, b, c);
+ error(o->expr, "Cannot convert '%s' to '%s' from '%s', got %s", a, b, c, s);
check_assignment_error_suggestion(ctx, o, type);
}
return false;