aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorBradley Lewis <22850972+BradLewis@users.noreply.github.com>2025-11-17 08:31:00 +1100
committerGitHub <noreply@github.com>2025-11-17 08:31:00 +1100
commitbf2ec00dc58e75ec6224e59172ae3c591c58bb9c (patch)
treee26678f19ec0ee3e33ea0abdf928d95ada721118 /src
parentb893410bc7ff44a73f4c77d31d7ae5c7defbd9e6 (diff)
parent12deb18a07dc28f840555fb6c875d888ab5be13b (diff)
Merge pull request #1185 from BradLewis/fix/unary-expr-function-call
Diffstat (limited to 'src')
-rw-r--r--src/server/analysis.odin17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/server/analysis.odin b/src/server/analysis.odin
index 45bf0fd..c9a6275 100644
--- a/src/server/analysis.odin
+++ b/src/server/analysis.odin
@@ -1223,13 +1223,22 @@ internal_resolve_type_expression :: proc(ast_context: ^AstContext, node: ^ast.Ex
case ^Comp_Lit:
return internal_resolve_type_expression(ast_context, v.type, out)
case ^Unary_Expr:
+ ok := internal_resolve_type_expression(ast_context, v.expr, out)
if v.op.kind == .And {
- ok := internal_resolve_type_expression(ast_context, v.expr, out)
out.pointers += 1
- return ok
- } else {
- return internal_resolve_type_expression(ast_context, v.expr, out)
+ } else if v.op.kind == .Sub || v.op.kind == .Add {
+ if value, ok := out.value.(SymbolProcedureValue); ok {
+ if len(value.return_types) > 0 {
+ type := value.return_types[0].type
+ if type == nil {
+ type = value.return_types[0].default_value
+ }
+ ok = internal_resolve_type_expression(ast_context, type, out)
+ return ok
+ }
+ }
}
+ return ok
case ^Deref_Expr:
ok := internal_resolve_type_expression(ast_context, v.expr, out)
out.pointers -= 1