diff options
| author | Bradley Lewis <22850972+BradLewis@users.noreply.github.com> | 2025-11-17 08:31:00 +1100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-11-17 08:31:00 +1100 |
| commit | bf2ec00dc58e75ec6224e59172ae3c591c58bb9c (patch) | |
| tree | e26678f19ec0ee3e33ea0abdf928d95ada721118 /src | |
| parent | b893410bc7ff44a73f4c77d31d7ae5c7defbd9e6 (diff) | |
| parent | 12deb18a07dc28f840555fb6c875d888ab5be13b (diff) | |
Merge pull request #1185 from BradLewis/fix/unary-expr-function-call
Diffstat (limited to 'src')
| -rw-r--r-- | src/server/analysis.odin | 17 |
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 |