diff options
| author | Brad Lewis <22850972+BradLewis@users.noreply.github.com> | 2025-12-06 05:34:10 -0500 |
|---|---|---|
| committer | Brad Lewis <22850972+BradLewis@users.noreply.github.com> | 2025-12-06 05:34:10 -0500 |
| commit | aa2378e8bd44f7ff5b8772802a020e47009c114b (patch) | |
| tree | f31a2395ace5d9941ce3804e4826b8bd531c0231 /src/server/position_context.odin | |
| parent | 84e77e089c17a07bb5920b64083c2d983e9c654e (diff) | |
Check attributes when building the position context
Diffstat (limited to 'src/server/position_context.odin')
| -rw-r--r-- | src/server/position_context.odin | 26 |
1 files changed, 25 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 |