]> granicus.if.org Git - clang/commit
DR1113: anonymous namespaces formally give their contents internal linkage.
authorRichard Smith <richard-llvm@metafoo.co.uk>
Fri, 22 Sep 2017 22:21:44 +0000 (22:21 +0000)
committerRichard Smith <richard-llvm@metafoo.co.uk>
Fri, 22 Sep 2017 22:21:44 +0000 (22:21 +0000)
commitdd94e045be9b18d4a967fb747522b6da743aa18d
tree7edf530a9764889e0d1af3e0c43b6514c3ea79c3
parent945869ef7ba9f6a64f4ed7ec218c75b0a8ed7edb
DR1113: anonymous namespaces formally give their contents internal linkage.

This doesn't affect our code generation in any material way -- we already give
such declarations internal linkage from a codegen perspective -- but it has
some subtle effects on code validity.

We suppress the 'L' (internal linkage) marker for mangled names in anonymous
namespaces, because it is redundant (the information is already carried by the
namespace); this deviates from GCC's behavior if a variable or function in an
anonymous namespace is redundantly declared 'static' (where GCC does include
the 'L'), but GCC's behavior is incoherent because such a declaration can be
validly declared with or without the 'static'.

We still deviate from the standard in one regard here: extern "C" declarations
in anonymous namespaces are still granted external linkage. Changing those does
not appear to have been an intentional consequence of the standard change in
DR1113.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@314037 91177308-0d34-0410-b5e6-96231b3b80d8
lib/AST/Decl.cpp
lib/AST/ItaniumMangle.cpp
test/CXX/basic/basic.link/p8.cpp
test/CXX/drs/dr11xx.cpp [new file with mode: 0644]
test/CodeGenCXX/anonymous-namespaces.cpp
test/SemaCXX/linkage2.cpp
test/SemaCXX/undefined-internal.cpp