diff options
author | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-02-01 08:12:08 +0000 |
---|---|---|
committer | Richard Smith <richard-llvm@metafoo.co.uk> | 2013-02-01 08:12:08 +0000 |
commit | 848e1f19605a1769f28f5f08a37999c4043ae33b (patch) | |
tree | 2c7009338101c4c8c9f2640a0a0e34e3c6b3f4e0 /clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | |
parent | 4349f6963eead14e67ebb0cbe0042778be683484 (diff) | |
download | bcm5719-llvm-848e1f19605a1769f28f5f08a37999c4043ae33b.tar.gz bcm5719-llvm-848e1f19605a1769f28f5f08a37999c4043ae33b.zip |
Implement [dcl.align]p5 and C11 6.7.5/4: alignas cannot underalign.
Also support alignas(0), which C++11 and C11 require us to ignore.
llvm-svn: 174157
Diffstat (limited to 'clang/lib/Sema/SemaTemplateInstantiateDecl.cpp')
-rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiateDecl.cpp | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp index c146e9dd449..2d3d0bd5b69 100644 --- a/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiateDecl.cpp @@ -347,6 +347,9 @@ Decl *TemplateDeclInstantiator::VisitVarDecl(VarDecl *D) { } SemaRef.InstantiateAttrs(TemplateArgs, D, Var, LateAttrs, StartingScope); + if (Var->hasAttrs()) + SemaRef.CheckAlignasUnderalignment(Var); + // Link instantiations of static data members back to the template from // which they were instantiated. if (Var->isStaticDataMember()) @@ -459,6 +462,9 @@ Decl *TemplateDeclInstantiator::VisitFieldDecl(FieldDecl *D) { SemaRef.InstantiateAttrs(TemplateArgs, D, Field, LateAttrs, StartingScope); + if (Field->hasAttrs()) + SemaRef.CheckAlignasUnderalignment(Field); + if (Invalid) Field->setInvalidDecl(); |