case Type::ConstantArray:
case Type::IncompleteArray:
case Type::VariableArray:
+ case Type::Enum:
return BuildTypeInfo(Ty);
case Type::Vector:
case Type::ExtVector:
return BuildSimpleType(Ty, "_ZTVN10__cxxabiv117__array_type_infoE");
- case Type::Enum:
- return BuildSimpleType(Ty, "_ZTVN10__cxxabiv116__enum_type_infoE");
}
}
return llvm::GlobalVariable::InternalLinkage;
return llvm::GlobalVariable::WeakODRLinkage;
- break;
+ }
+
+ case Type::Enum: {
+ const EnumType *EnumTy = cast<EnumType>(Ty);
+ const EnumDecl *ED = EnumTy->getDecl();
+
+ // If we're in an anonymous namespace, then we always want internal linkage.
+ if (ED->isInAnonymousNamespace() || !ED->hasLinkage())
+ return llvm::GlobalVariable::InternalLinkage;
+
+ return llvm::GlobalValue::WeakODRLinkage;
}
case Type::Record: {
VtableName = "_ZTVN10__cxxabiv120__function_type_infoE";
break;
+ case Type::Enum:
+ // abi::__enum_type_info
+ VtableName = "_ZTVN10__cxxabiv116__enum_type_infoE";
+ break;
+
case Type::Record: {
const CXXRecordDecl *RD =
cast<CXXRecordDecl>(cast<RecordType>(Ty)->getDecl());
// abi::__function_type_info adds no data members to std::type_info;
break;
+ case Type::Enum:
+ // Itanium C++ ABI 2.9.5p4:
+ // abi::__enum_type_info adds no data members to std::type_info;
+ break;
+
case Type::Record: {
const CXXRecordDecl *RD =
cast<CXXRecordDecl>(cast<RecordType>(Ty)->getDecl());
// CHECK: _ZTIFvvE = weak_odr
// CHECK: _ZTIPFvvE = weak_odr constant
+// CHECK: _ZTSN12_GLOBAL__N_11EE = internal constant
+// CHECK: _ZTIN12_GLOBAL__N_11EE = internal constant
+
// A has no key function, so its RTTI data should be weak_odr.
struct A { };
// D is inside an anonymous namespace, so all type information related to D should have
// internal linkage.
struct D { };
+
+ // E is also inside an anonymous namespace.
+ enum E { };
+
};
const D getD();
// internal linkage.
(void)typeid(void (*)() throw (D));
+ (void)typeid(E);
+
// CHECK: _ZTIN12_GLOBAL__N_11DE to
return typeid(getD());
}