Namespace inline mismatch diagnostic refers to unhelpful previous definition · Issue #50794 · llvm/llvm-project (original) (raw)
Bugzilla Link | 51452 |
---|---|
Version | trunk |
OS | Linux |
CC | @zygoloid |
Extended Description
See: https://godbolt.org/z/x87K78TnW
Take this C++ code:
1: inline namespace abc {};
2: namespace abc {};
3: namespace abc {};
Clang will emit a warning for line 2, because the namespace is re-opened as non-inline, while the previous definition was inline. It will add a Note for the previous definition, in this case line 1.
However, it will also emit the same warning for line 3. In this case, it would be helpful to have the Note refer to the definition in line 1, but it instead refers to line 2. That is confusing since the problem is the inline mismatch, but the Note refers to a definition that is not inline.