zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 2c8864f634cbb42bf45f4f6b7109e9129b357247 (tree)
parent b89a09af4bb0064bb3d37acef4c9c1d4ee1515a6
Author: LemonBoy <thatlemon@gmail.com>
Date:   Thu, 26 Sep 2019 17:54:45 +0200

Don't warn about redeclaration for the same var node

Closes #3316

Diffstat:
Msrc/analyze.cpp | 2+-
Mtest/stage1/behavior/usingnamespace.zig | 8++++++++
2 files changed, 9 insertions(+), 1 deletion(-)

diff --git a/src/analyze.cpp b/src/analyze.cpp @@ -3676,7 +3676,7 @@ ZigVar *add_variable(CodeGen *g, AstNode *source_node, Scope *parent_scope, Buf } if (search_scope != nullptr) { Tld *tld = find_decl(g, search_scope, name); - if (tld != nullptr) { + if (tld != nullptr && tld != src_tld) { ErrorMsg *msg = add_node_error(g, source_node, buf_sprintf("redefinition of '%s'", buf_ptr(name))); add_error_note(g, msg, tld->source_node, buf_sprintf("previous definition is here")); diff --git a/test/stage1/behavior/usingnamespace.zig b/test/stage1/behavior/usingnamespace.zig @@ -12,3 +12,11 @@ test "usingnamespace inside a generic struct" { std2.testing.expect(true); testing2.expect(true); } + +usingnamespace struct { + pub const foo = 42; +}; + +test "usingnamespace does not redeclare an imported variable" { + comptime std.testing.expect(foo == 42); +}