forked from OSchip/llvm-project
AST: Mangle fields in anonymous structs/unions
The Itanium mangler couldn't cope with mangling an IndirectFieldDecl. Instead, mangle the field the IndirectFieldDecl refers to. Further, give IndirectFieldDecl no linkage just like FieldDecl. N.B. Decl.cpp:getLVForNamespaceScopeDecl tried to calculate linkage for data members of anonymous structs/unions. However, this seems impossible so turn it into an assertion. llvm-svn: 193269
This commit is contained in:
parent
3197b25b27
commit
0eb8bbdeab
|
@ -575,11 +575,10 @@ static LinkageInfo getLVForNamespaceScopeDecl(const NamedDecl *D,
|
|||
// Explicitly declared static.
|
||||
if (Function->getCanonicalDecl()->getStorageClass() == SC_Static)
|
||||
return LinkageInfo(InternalLinkage, DefaultVisibility, false);
|
||||
} else if (const FieldDecl *Field = dyn_cast<FieldDecl>(D)) {
|
||||
// - a data member of an anonymous union.
|
||||
if (cast<RecordDecl>(Field->getDeclContext())->isAnonymousStructOrUnion())
|
||||
return LinkageInfo::internal();
|
||||
}
|
||||
// - a data member of an anonymous union.
|
||||
assert(!isa<IndirectFieldDecl>(D) && "Didn't expect an IndirectFieldDecl!");
|
||||
assert(!isa<FieldDecl>(D) && "Didn't expect a FieldDecl!");
|
||||
|
||||
if (D->isInAnonymousNamespace()) {
|
||||
const VarDecl *Var = dyn_cast<VarDecl>(D);
|
||||
|
@ -786,6 +785,7 @@ static LinkageInfo getLVForClassMember(const NamedDecl *D,
|
|||
if (!(isa<CXXMethodDecl>(D) ||
|
||||
isa<VarDecl>(D) ||
|
||||
isa<FieldDecl>(D) ||
|
||||
isa<IndirectFieldDecl>(D) ||
|
||||
isa<TagDecl>(D)))
|
||||
return LinkageInfo::none();
|
||||
|
||||
|
|
|
@ -439,6 +439,8 @@ void CXXNameMangler::mangle(const NamedDecl *D, StringRef Prefix) {
|
|||
mangleFunctionEncoding(FD);
|
||||
else if (const VarDecl *VD = dyn_cast<VarDecl>(D))
|
||||
mangleName(VD);
|
||||
else if (const IndirectFieldDecl *IFD = dyn_cast<IndirectFieldDecl>(D))
|
||||
mangleName(IFD->getAnonField());
|
||||
else
|
||||
mangleName(cast<FieldDecl>(D));
|
||||
}
|
||||
|
|
|
@ -933,3 +933,12 @@ namespace test42 {
|
|||
|
||||
void g() { func(foo<20, X>()); }
|
||||
}
|
||||
|
||||
namespace test43 {
|
||||
// CHECK-LABEL: define void @_ZN6test431gEPNS_3zedIXadL_ZNS_3fooUt_3barEEEEE
|
||||
struct foo { union { int bar; }; };
|
||||
template <int (foo::*)>
|
||||
struct zed {};
|
||||
void g(zed<&foo::bar>*)
|
||||
{}
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue