aboutsummaryrefslogtreecommitdiff
path: root/src/server/analysis.odin
diff options
context:
space:
mode:
authorBradley Lewis <22850972+BradLewis@users.noreply.github.com>2025-09-16 18:28:35 -0400
committerGitHub <noreply@github.com>2025-09-16 18:28:35 -0400
commit379c55200570277d68a78006844cd32b1802f328 (patch)
treeec5a37dfe0b72e56c630c6b347142206a5caa889 /src/server/analysis.odin
parentc3195c07d4756219bb01f5815bd5e76285f959d9 (diff)
parent01e247bb7a4142713fba8ac2c60fb0085816078d (diff)
Merge pull request #1021 from BradLewis/fix/implicit-selector-binary-expr
Diffstat (limited to 'src/server/analysis.odin')
-rw-r--r--src/server/analysis.odin8
1 files changed, 5 insertions, 3 deletions
diff --git a/src/server/analysis.odin b/src/server/analysis.odin
index 856f0ae..113f913 100644
--- a/src/server/analysis.odin
+++ b/src/server/analysis.odin
@@ -2275,10 +2275,12 @@ resolve_implicit_selector :: proc(
}
if position_context.binary != nil {
- if position_in_node(position_context.binary.left, position_context.position) {
+ if position_in_node(position_context.binary, position_context.position) {
+ // We resolve whichever is not the implicit_selector
+ if implicit, ok := position_context.binary.left.derived.(^ast.Implicit_Selector_Expr); ok {
+ return resolve_type_expression(ast_context, position_context.binary.right)
+ }
return resolve_type_expression(ast_context, position_context.binary.left)
- } else if position_in_node(position_context.binary.left, position_context.position) {
- return resolve_type_expression(ast_context, position_context.binary.right)
}
}