]> granicus.if.org Git - clang/commitdiff
In microsoft mode, downgrade pseudo-destructors on void from error to warning.
authorNico Weber <nicolasweber@gmx.de>
Mon, 23 Jan 2012 05:50:57 +0000 (05:50 +0000)
committerNico Weber <nicolasweber@gmx.de>
Mon, 23 Jan 2012 05:50:57 +0000 (05:50 +0000)
This matches cl.exe's behavior and fixes PR11791.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@148682 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticSemaKinds.td
lib/Sema/SemaExprCXX.cpp
test/SemaCXX/MicrosoftCompatibility.cpp

index 96f85f6f6eb46c6ea205c61c15353a62d62441f7..56fca58475d8c339a90cdd1a384860cfe2e4d8c5 100644 (file)
@@ -4053,6 +4053,9 @@ def err_operator_arrow_circular : Error<
 def err_pseudo_dtor_base_not_scalar : Error<
   "object expression of non-scalar type %0 cannot be used in a "
   "pseudo-destructor expression">;
+def ext_pseudo_dtor_on_void : ExtWarn<
+  "pseudo-destructors on type void are a Microsoft extension">,
+  InGroup<Microsoft>;
 def err_pseudo_dtor_type_mismatch : Error<
   "the type of object expression (%0) does not match the type being destroyed "
   "(%1) in pseudo-destructor expression">;
index edc5b0890067c233401ae63921e5e1cfb6fde53d..d3bbc14728ccc4d8d0316ad9b2292e97e7c1ef3c 100644 (file)
@@ -4380,8 +4380,11 @@ ExprResult Sema::BuildPseudoDestructorExpr(Expr *Base,
     return ExprError();
 
   if (!ObjectType->isDependentType() && !ObjectType->isScalarType()) {
-    Diag(OpLoc, diag::err_pseudo_dtor_base_not_scalar)
-      << ObjectType << Base->getSourceRange();
+    if (getLangOptions().MicrosoftMode && ObjectType->isVoidType())
+      Diag(OpLoc, diag::ext_pseudo_dtor_on_void);
+    else
+      Diag(OpLoc, diag::err_pseudo_dtor_base_not_scalar)
+        << ObjectType << Base->getSourceRange();
     return ExprError();
   }
 
index 90a7ff731c0c90156788e297f1a36a40ba5ba194..3634fa34627242e53636fac26164ebde78f532cf 100644 (file)
@@ -163,3 +163,14 @@ enum ENUM2 {
 };
 
 
+namespace PR11791 {
+  template<class _Ty>
+  void del(_Ty *_Ptr) {
+    _Ptr->~_Ty();  // expected-warning {{pseudo-destructors on type void are a Microsoft extension}}
+  }
+
+  void f() {
+    int* a = 0;
+    del((void*)a);  // expected-note {{in instantiation of function template specialization}}
+  }
+}