[cfe-commits] r163145 - in /cfe/trunk: include/clang/Basic/DiagnosticSemaKinds.td lib/AST/MicrosoftCXXABI.cpp lib/Sema/SemaDeclAttr.cpp lib/Sema/SemaType.cpp test/SemaCXX/member-pointer-ms.cpp
Joao Matos
ripzonetriton at gmail.com
Tue Sep 4 10:18:12 PDT 2012
Author: triton
Date: Tue Sep 4 12:18:12 2012
New Revision: 163145
URL: http://llvm.org/viewvc/llvm-project?rev=163145&view=rev
Log:
Revert r163078 per chandlerc's request.
Modified:
cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
cfe/trunk/lib/AST/MicrosoftCXXABI.cpp
cfe/trunk/lib/Sema/SemaDeclAttr.cpp
cfe/trunk/lib/Sema/SemaType.cpp
cfe/trunk/test/SemaCXX/member-pointer-ms.cpp
Modified: cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td?rev=163145&r1=163144&r2=163145&view=diff
==============================================================================
--- cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td (original)
+++ cfe/trunk/include/clang/Basic/DiagnosticSemaKinds.td Tue Sep 4 12:18:12 2012
@@ -1672,9 +1672,7 @@
def err_attr_tlsmodel_arg : Error<"tls_model must be \"global-dynamic\", "
"\"local-dynamic\", \"initial-exec\" or \"local-exec\"">;
-def warn_ms_inheritance_already_declared : Warning<
- "ignored since inheritance model was already declared as '"
- "%select{single|multiple|virtual}0'">, InGroup<Microsoft>;
+
def err_only_annotate_after_access_spec : Error<
"access specifier can only have annotation attributes">;
Modified: cfe/trunk/lib/AST/MicrosoftCXXABI.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/AST/MicrosoftCXXABI.cpp?rev=163145&r1=163144&r2=163145&view=diff
==============================================================================
--- cfe/trunk/lib/AST/MicrosoftCXXABI.cpp (original)
+++ cfe/trunk/lib/AST/MicrosoftCXXABI.cpp Tue Sep 4 12:18:12 2012
@@ -55,16 +55,6 @@
unsigned MicrosoftCXXABI::getMemberPointerSize(const MemberPointerType *MPT) const {
QualType Pointee = MPT->getPointeeType();
CXXRecordDecl *RD = MPT->getClass()->getAsCXXRecordDecl();
-
- if (RD->getTypeForDecl()->isIncompleteType()) {
- if (RD->hasAttr<SingleInheritanceAttr>())
- return 1;
- else if (RD->hasAttr<MultipleInheritanceAttr>())
- return 2;
- else
- return 3;
- }
-
if (RD->getNumVBases() > 0) {
if (Pointee->isFunctionType())
return 3;
Modified: cfe/trunk/lib/Sema/SemaDeclAttr.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaDeclAttr.cpp?rev=163145&r1=163144&r2=163145&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaDeclAttr.cpp (original)
+++ cfe/trunk/lib/Sema/SemaDeclAttr.cpp Tue Sep 4 12:18:12 2012
@@ -4149,50 +4149,20 @@
S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << "uuid";
}
-static bool hasOtherInheritanceAttr(Decl *D, AttributeList::Kind Kind,
- int& Existing) {
- if (Kind != AttributeList::AT_SingleInheritance &&
- D->hasAttr<SingleInheritanceAttr>()) {
- Existing = 0;
- return true;
- }
- else if (Kind != AttributeList::AT_MultipleInheritance &&
- D->hasAttr<MultipleInheritanceAttr>()) {
- Existing = 1;
- return true;
- }
- else if (Kind != AttributeList::AT_VirtualInheritance &&
- D->hasAttr<VirtualInheritanceAttr>()) {
- Existing = 2;
- return true;
- }
- return false;
-}
-
static void handleInheritanceAttr(Sema &S, Decl *D, const AttributeList &Attr) {
- if (!S.LangOpts.MicrosoftExt) {
+ if (S.LangOpts.MicrosoftExt) {
+ AttributeList::Kind Kind = Attr.getKind();
+ if (Kind == AttributeList::AT_SingleInheritance)
+ D->addAttr(
+ ::new (S.Context) SingleInheritanceAttr(Attr.getRange(), S.Context));
+ else if (Kind == AttributeList::AT_MultipleInheritance)
+ D->addAttr(
+ ::new (S.Context) MultipleInheritanceAttr(Attr.getRange(), S.Context));
+ else if (Kind == AttributeList::AT_VirtualInheritance)
+ D->addAttr(
+ ::new (S.Context) VirtualInheritanceAttr(Attr.getRange(), S.Context));
+ } else
S.Diag(Attr.getLoc(), diag::warn_attribute_ignored) << Attr.getName();
- return;
- }
-
- AttributeList::Kind Kind = Attr.getKind();
-
- int Existing;
- if (hasOtherInheritanceAttr(D->getCanonicalDecl(), Kind, Existing)) {
- S.Diag(Attr.getLoc(), diag::warn_ms_inheritance_already_declared) << Existing;
- return;
- }
-
- if (Kind == AttributeList::AT_SingleInheritance) {
- D->addAttr(
- ::new (S.Context) SingleInheritanceAttr(Attr.getRange(), S.Context));
- } else if (Kind == AttributeList::AT_MultipleInheritance) {
- D->addAttr(
- ::new (S.Context) MultipleInheritanceAttr(Attr.getRange(), S.Context));
- } else if (Kind == AttributeList::AT_VirtualInheritance) {
- D->addAttr(
- ::new (S.Context) VirtualInheritanceAttr(Attr.getRange(), S.Context));
- }
}
static void handlePortabilityAttr(Sema &S, Decl *D, const AttributeList &Attr) {
Modified: cfe/trunk/lib/Sema/SemaType.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Sema/SemaType.cpp?rev=163145&r1=163144&r2=163145&view=diff
==============================================================================
--- cfe/trunk/lib/Sema/SemaType.cpp (original)
+++ cfe/trunk/lib/Sema/SemaType.cpp Tue Sep 4 12:18:12 2012
@@ -1583,6 +1583,14 @@
return QualType();
}
+ // In the Microsoft ABI, the class is allowed to be an incomplete
+ // type. In such cases, the compiler makes a worst-case assumption.
+ // We make no such assumption right now, so emit an error if the
+ // class isn't a complete type.
+ if (Context.getTargetInfo().getCXXABI() == CXXABI_Microsoft &&
+ RequireCompleteType(Loc, Class, diag::err_incomplete_type))
+ return QualType();
+
return Context.getMemberPointerType(T, Class.getTypePtr());
}
Modified: cfe/trunk/test/SemaCXX/member-pointer-ms.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/SemaCXX/member-pointer-ms.cpp?rev=163145&r1=163144&r2=163145&view=diff
==============================================================================
--- cfe/trunk/test/SemaCXX/member-pointer-ms.cpp (original)
+++ cfe/trunk/test/SemaCXX/member-pointer-ms.cpp Tue Sep 4 12:18:12 2012
@@ -1,4 +1,8 @@
-// RUN: %clang_cc1 -cxx-abi microsoft -fms-compatibility -fsyntax-only -verify %s
+// RUN: %clang_cc1 -cxx-abi microsoft -fsyntax-only -verify %s
+
+// Test that we reject pointers to members of incomplete classes (for now)
+struct A; //expected-note{{forward declaration of 'A'}}
+int A::*pai1; //expected-error{{incomplete type 'A'}}
// Test that we don't allow reinterpret_casts from pointers of one size to
// pointers of a different size.
@@ -8,9 +12,3 @@
void (A::*paf)();
void (C::*pcf)() = reinterpret_cast<void (C::*)()>(paf); //expected-error{{cannot reinterpret_cast from member pointer type}}
-
-class __single_inheritance D;
-class __multiple_inheritance D; // expected-warning {{ignored since inheritance model was already declared as 'single'}}
-
-class __virtual_inheritance E;
-class __virtual_inheritance E; // no warning expected since same attribute
More information about the cfe-commits
mailing list