]> granicus.if.org Git - clang/commitdiff
Check for unexpanded parameter packs in static assertion expressions.
authorDouglas Gregor <dgregor@apple.com>
Wed, 15 Dec 2010 23:55:21 +0000 (23:55 +0000)
committerDouglas Gregor <dgregor@apple.com>
Wed, 15 Dec 2010 23:55:21 +0000 (23:55 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@121922 91177308-0d34-0410-b5e6-96231b3b80d8

include/clang/Basic/DiagnosticSemaKinds.td
include/clang/Sema/Sema.h
lib/Sema/SemaDeclCXX.cpp
test/CXX/temp/temp.decls/temp.variadic/p5.cpp

index 78a7a17eb5e981aebebe3942084babeb605f3934..7cdfab6200daabb21169ecfc5e84a5f53258e82a 100644 (file)
@@ -1823,19 +1823,19 @@ def note_template_parameter_pack_here : Note<
   
 def err_unexpanded_parameter_pack_0 : Error<
   "%select{expression|base type|declaration type|data member type|bit-field "
-  "size}0 "
+  "size|static assertion}0 "
   "contains unexpanded parameter pack">;
 def err_unexpanded_parameter_pack_1 : Error<
   "%select{expression|base type|declaration type|data member type|bit-field "
-  "size}0 "
+  "size|static assertion}0 "
   "contains unexpanded parameter pack %1">;
 def err_unexpanded_parameter_pack_2 : Error<
   "%select{expression|base type|declaration type|data member type|bit-field "
-  "size}0 "
+  "size|static assertion}0 "
   "contains unexpanded parameter packs %1 and %2">;
 def err_unexpanded_parameter_pack_3_or_more : Error<
   "%select{expression|base type|declaration type|data member type|bit-field "
-  "size}0 "
+  "size|static assertion}0 "
   "contains unexpanded parameter packs %1, %2, ...">;
 
 def err_unexpected_typedef : Error<
index 2dc09d339c4778416850a57ab38dc3c314cb7c98..07a7be298e536775d5378e86837ae35491f05b5f 100644 (file)
@@ -3148,7 +3148,10 @@ public:
     UPPC_DataMemberType,
 
     /// \brief The size of a bit-field.
-    UPPC_BitFieldWidth
+    UPPC_BitFieldWidth,
+
+    /// \brief The expression in a static assertion.
+    UPPC_StaticAssertExpression
   };
 
   /// \brief If the given type contains an unexpanded parameter pack,
index d53871591708f92b5141861e42095a746f13287f..555f5fd42422ac0594b0126687c0cb561069b888 100644 (file)
@@ -6175,6 +6175,9 @@ Decl *Sema::ActOnStaticAssertDeclaration(SourceLocation AssertLoc,
     }
   }
 
+  if (DiagnoseUnexpandedParameterPack(AssertExpr, UPPC_StaticAssertExpression))
+    return 0;
+
   Decl *Decl = StaticAssertDecl::Create(Context, CurContext, AssertLoc,
                                         AssertExpr, AssertMessage);
 
index 0e5c9c097981cb0b396673cd376e4045d051d99c..52a619010d3b7806eff8febabeec4f513a383603 100644 (file)
@@ -111,6 +111,7 @@ struct TestUnexpandedDecls {
   Types data_member;  // expected-error{{data member type contains unexpanded parameter pack 'Types'}}
   static Types static_data_member; // expected-error{{declaration type contains unexpanded parameter pack 'Types'}}
   unsigned bit_field : static_cast<Types>(0);  // expected-error{{bit-field size contains unexpanded parameter pack 'Types'}}
+  static_assert(static_cast<Types>(0), "Boom"); // expected-error{{static assertion contains unexpanded parameter pack 'Types'}}
 };
 
 // Test for diagnostics in the presence of multiple unexpanded