aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/server/position_context.odin26
-rw-r--r--tests/hover_test.odin13
2 files changed, 38 insertions, 1 deletions
diff --git a/src/server/position_context.odin b/src/server/position_context.odin
index 33de8f3..2792194 100644
--- a/src/server/position_context.odin
+++ b/src/server/position_context.odin
@@ -1,10 +1,10 @@
package server
-import "core:strings"
import "core:log"
import "core:odin/ast"
import "core:odin/parser"
import "core:odin/tokenizer"
+import "core:strings"
import "core:unicode/utf8"
import "src:common"
@@ -63,9 +63,33 @@ DocumentPositionContext :: struct {
call_commas: []int,
}
+
+get_stmt_attrs :: proc(decl: ^ast.Stmt) -> []^ast.Attribute {
+ if decl == nil {
+ return nil
+ }
+ #partial switch v in decl.derived {
+ case ^ast.Value_Decl:
+ return v.attributes[:]
+ case ^ast.Import_Decl:
+ return v.attributes[:]
+ case ^ast.Foreign_Block_Decl:
+ return v.attributes[:]
+ case ^ast.Foreign_Import_Decl:
+ return v.attributes[:]
+ }
+ return nil
+}
+
get_document_position_decls :: proc(decls: []^ast.Stmt, position_context: ^DocumentPositionContext) -> bool {
exists_in_decl := false
for decl in decls {
+ for attr in get_stmt_attrs(decl) {
+ if position_in_node(attr, position_context.position) {
+ get_document_position(attr, position_context)
+ return true
+ }
+ }
if position_in_node(decl, position_context.position) {
get_document_position(decl, position_context)
exists_in_decl = true
diff --git a/tests/hover_test.odin b/tests/hover_test.odin
index 8a54ad4..842360b 100644
--- a/tests/hover_test.odin
+++ b/tests/hover_test.odin
@@ -5852,6 +5852,19 @@ ast_hover_propagate_docs_alias_in_package_override :: proc(t: ^testing.T) {
test.expect_hover(t, &source, "my_package.bar :: proc()\n Overridden\n\n// Comment!")
}
+@(test)
+ast_hover_deferred_attributes :: proc(t: ^testing.T) {
+ source := test.Source {
+ main = `package test
+ foo :: proc() {}
+
+ @(deferred_in = fo{*}o)
+ bar :: proc() {}
+ `,
+ }
+ test.expect_hover(t, &source, "test.foo :: proc()")
+}
+
/*
Waiting for odin fix