diff options
| author | DanielGavin <danielgavin5@hotmail.com> | 2025-07-03 11:47:56 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-07-03 11:47:56 +0200 |
| commit | 718fee642d34da5d43fe9bdeee54abdb34385bb8 (patch) | |
| tree | 79b2170876a8492f7a427c637b3407eedfd9c48a /src/server/completion.odin | |
| parent | 4ec40cec010b4c8c28fe4bb428c6b53a089a7d30 (diff) | |
| parent | 5348ee2fc5b7609e58baaa835b4fb55d5c13fc3e (diff) | |
Merge pull request #710 from BradLewis/feat/improve-enum-completions
Enum completion improvements
Diffstat (limited to 'src/server/completion.odin')
| -rw-r--r-- | src/server/completion.odin | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/src/server/completion.odin b/src/server/completion.odin index 6a172ef..80c5ae1 100644 --- a/src/server/completion.odin +++ b/src/server/completion.odin @@ -727,6 +727,7 @@ get_implicit_completion :: proc( //value decl infer a : My_Enum = .* if position_context.value_decl != nil && position_context.value_decl.type != nil { enum_value: Maybe(SymbolEnumValue) + exclude_names := make([dynamic]string, context.temp_allocator) if _enum_value, ok := unwrap_enum(ast_context, position_context.value_decl.type); ok { enum_value = _enum_value @@ -739,16 +740,25 @@ get_implicit_completion :: proc( enum_value = _enum_value } } + for elem in position_context.comp_lit.elems { + if expr, ok := elem.derived.(^ast.Implicit_Selector_Expr); ok { + if expr.field.name != "_" { + append(&exclude_names, expr.field.name) + } + } + } } if ev, ok := enum_value.?; ok { for name in ev.names { - item := CompletionItem { - label = name, - kind = .EnumMember, - detail = name, + if !slice.contains(exclude_names[:], name) { + item := CompletionItem { + label = name, + kind = .EnumMember, + detail = name, + } + append(&items, item) } - append(&items, item) } list.items = items[:] |