Add missing check to warning for packed attribute. PR14259.
authorEli Friedman <eli.friedman@gmail.com>
Wed, 7 Nov 2012 00:35:20 +0000 (00:35 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Wed, 7 Nov 2012 00:35:20 +0000 (00:35 +0000)
llvm-svn: 167510

clang/lib/Sema/SemaDeclAttr.cpp
clang/test/SemaTemplate/instantiate-attr.cpp

index 6db30be..aef87c6 100644 (file)
@@ -963,7 +963,8 @@ static void handlePackedAttr(Sema &S, Decl *D, const AttributeList &Attr) {
   else if (FieldDecl *FD = dyn_cast<FieldDecl>(D)) {
     // If the alignment is less than or equal to 8 bits, the packed attribute
     // has no effect.
-    if (!FD->getType()->isIncompleteType() &&
+    if (!FD->getType()->isDependentType() &&
+        !FD->getType()->isIncompleteType() &&
         S.Context.getTypeAlign(FD->getType()) <= 8)
       S.Diag(Attr.getLoc(), diag::warn_attribute_ignored_for_field_of_type)
         << Attr.getName() << FD->getType();
index 45136f6..1e94614 100644 (file)
@@ -25,3 +25,12 @@ namespace test1 {
   int test1[__builtin_offsetof(type, a) == 0 ? 1 : -1];
   int test2[__builtin_offsetof(type, b) == 4 ? 1 : -1];
 }
+
+namespace test2 {
+  template <class type>
+  struct fastscriptmember {
+      type Member __attribute__ ((packed));
+      char x;
+  };
+  int test0[sizeof(fastscriptmember<int>) == 5 ? 1 : -1];
+}