diff options
Diffstat (limited to 'clang/lib/Sema')
| -rw-r--r-- | clang/lib/Sema/SemaDecl.cpp | 17 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaDeclCXX.cpp | 4 | ||||
| -rw-r--r-- | clang/lib/Sema/SemaTemplateInstantiate.cpp | 5 | 
3 files changed, 13 insertions, 13 deletions
| diff --git a/clang/lib/Sema/SemaDecl.cpp b/clang/lib/Sema/SemaDecl.cpp index 1057defc44f..0e817658ae0 100644 --- a/clang/lib/Sema/SemaDecl.cpp +++ b/clang/lib/Sema/SemaDecl.cpp @@ -8673,7 +8673,7 @@ void Sema::ActOnLastBitfield(SourceLocation DeclLoc,  void Sema::ActOnFields(Scope* S,                         SourceLocation RecLoc, Decl *EnclosingDecl, -                       Decl **Fields, unsigned NumFields, +                       llvm::ArrayRef<Decl *> Fields,                         SourceLocation LBrac, SourceLocation RBrac,                         AttributeList *Attr) {    assert(EnclosingDecl && "missing record or interface decl"); @@ -8689,8 +8689,9 @@ void Sema::ActOnFields(Scope* S,    RecordDecl *Record = dyn_cast<RecordDecl>(EnclosingDecl);    bool ARCErrReported = false; -  for (unsigned i = 0; i != NumFields; ++i) { -    FieldDecl *FD = cast<FieldDecl>(Fields[i]); +  for (llvm::ArrayRef<Decl *>::iterator i = Fields.begin(), end = Fields.end(); +       i != end; ++i) { +    FieldDecl *FD = cast<FieldDecl>(*i);      // Get the type for the field.      const Type *FDTy = FD->getType().getTypePtr(); @@ -8725,10 +8726,10 @@ void Sema::ActOnFields(Scope* S,        EnclosingDecl->setInvalidDecl();        continue;      } else if (FDTy->isIncompleteArrayType() && Record &&  -               ((i == NumFields - 1 && !Record->isUnion()) || +               ((i + 1 == Fields.end() && !Record->isUnion()) ||                  ((getLangOptions().MicrosoftExt ||                    getLangOptions().CPlusPlus) && -                 (i == NumFields - 1 || Record->isUnion())))) { +                 (i + 1 == Fields.end() || Record->isUnion())))) {        // Flexible array member.        // Microsoft and g++ is more permissive regarding flexible array.        // It will accept flexible array in union and also @@ -8737,14 +8738,14 @@ void Sema::ActOnFields(Scope* S,          if (Record->isUnion())             Diag(FD->getLocation(), diag::ext_flexible_array_union_ms)              << FD->getDeclName(); -        else if (NumFields == 1)  +        else if (Fields.size() == 1)             Diag(FD->getLocation(), diag::ext_flexible_array_empty_aggregate_ms)              << FD->getDeclName() << Record->getTagKind();        } else if (getLangOptions().CPlusPlus) {          if (Record->isUnion())             Diag(FD->getLocation(), diag::ext_flexible_array_union_gnu)              << FD->getDeclName(); -        else if (NumFields == 1)  +        else if (Fields.size() == 1)             Diag(FD->getLocation(), diag::ext_flexible_array_empty_aggregate_gnu)              << FD->getDeclName() << Record->getTagKind();        } else if (NumNamedMembers < 1) { @@ -8781,7 +8782,7 @@ void Sema::ActOnFields(Scope* S,            // If this is a struct/class and this is not the last element, reject            // it.  Note that GCC supports variable sized arrays in the middle of            // structures. -          if (i != NumFields-1) +          if (i + 1 != Fields.end())              Diag(FD->getLocation(), diag::ext_variable_sized_type_in_struct)                << FD->getDeclName() << FD->getType();            else { diff --git a/clang/lib/Sema/SemaDeclCXX.cpp b/clang/lib/Sema/SemaDeclCXX.cpp index f9787e85c46..c197a4ea9fa 100644 --- a/clang/lib/Sema/SemaDeclCXX.cpp +++ b/clang/lib/Sema/SemaDeclCXX.cpp @@ -4652,10 +4652,10 @@ void Sema::ActOnFinishCXXMemberSpecification(Scope* S, SourceLocation RLoc,    AdjustDeclIfTemplate(TagDecl); -  ActOnFields(S, RLoc, TagDecl, +  ActOnFields(S, RLoc, TagDecl, llvm::makeArrayRef(                // strict aliasing violation!                reinterpret_cast<Decl**>(FieldCollector->getCurFields()), -              FieldCollector->getCurNumFields(), LBrac, RBrac, AttrList); +              FieldCollector->getCurNumFields()), LBrac, RBrac, AttrList);    CheckCompletedCXXClass(                          dyn_cast_or_null<CXXRecordDecl>(TagDecl)); diff --git a/clang/lib/Sema/SemaTemplateInstantiate.cpp b/clang/lib/Sema/SemaTemplateInstantiate.cpp index c8f7ac60a04..38cd349601b 100644 --- a/clang/lib/Sema/SemaTemplateInstantiate.cpp +++ b/clang/lib/Sema/SemaTemplateInstantiate.cpp @@ -1794,9 +1794,8 @@ Sema::InstantiateClass(SourceLocation PointOfInstantiation,    }    // Finish checking fields. -  ActOnFields(0, Instantiation->getLocation(), Instantiation, -              Fields.data(), Fields.size(), SourceLocation(), SourceLocation(), -              0); +  ActOnFields(0, Instantiation->getLocation(), Instantiation, Fields,  +              SourceLocation(), SourceLocation(), 0);    CheckCompletedCXXClass(Instantiation);    // Attach any in-class member initializers now the class is complete. | 

