diff options
| author | Brad Lewis <22850972+BradLewis@users.noreply.github.com> | 2025-06-10 12:36:29 -0400 |
|---|---|---|
| committer | Brad Lewis <22850972+BradLewis@users.noreply.github.com> | 2025-06-10 13:11:28 -0400 |
| commit | f6335de738e47dff08ab4fefc8aad027f860076b (patch) | |
| tree | f59db5d6ce11805469eb0b6cf1ffd9e033ac468c /tests | |
| parent | a42400e0c9f1471ec27454476f6fe6c19dc95242 (diff) | |
Ensure for locals that they are defined in the same file as the identifier
Diffstat (limited to 'tests')
| -rw-r--r-- | tests/hover_test.odin | 43 |
1 files changed, 43 insertions, 0 deletions
diff --git a/tests/hover_test.odin b/tests/hover_test.odin index bdd583a..244a4f9 100644 --- a/tests/hover_test.odin +++ b/tests/hover_test.odin @@ -412,6 +412,49 @@ ast_hover_union_implicit_selector :: proc(t: ^testing.T) { test.expect_hover(t, &source, "test.Bar: .Foo1") } +@(test) +ast_hover_foreign_package_name_collision :: proc(t: ^testing.T) { + packages := make([dynamic]test.Package, context.temp_allocator) + + append( + &packages, + test.Package { + pkg = "my_package", + source = `package my_package + + data :: struct { + nodes: []node, + } + + bar :: struct { + } + + node :: struct { + bar: ^bar + } + + get_data :: proc() -> ^data { + return &data{} + } + `, + }, + ) + source := test.Source { + main = `package test + import "my_package" + main :: proc() { + data := my_package.get_data() + + for node in data.nodes { + bar := node.b{*}ar + } + } + `, + packages = packages[:], + } + + test.expect_hover(t, &source, "node.bar: ^bar") +} /* Waiting for odin fix |