diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:02:28 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2017-04-16 16:02:28 +0000 | 
| commit | 7442d6faa2719e4e7d33a7021c406c5a4facd74d (patch) | |
| tree | c72b9241553fc9966179aba84f90f17bfa9235c3 /lib/Parse/Parser.cpp | |
| parent | b52119637f743680a99710ce5fdb6646da2772af (diff) | |
Notes
Diffstat (limited to 'lib/Parse/Parser.cpp')
| -rw-r--r-- | lib/Parse/Parser.cpp | 52 | 
1 files changed, 28 insertions, 24 deletions
| diff --git a/lib/Parse/Parser.cpp b/lib/Parse/Parser.cpp index 52e5194e6236..aa8ed91d382f 100644 --- a/lib/Parse/Parser.cpp +++ b/lib/Parse/Parser.cpp @@ -12,11 +12,11 @@  //===----------------------------------------------------------------------===//  #include "clang/Parse/Parser.h" -#include "RAIIObjectsForParser.h"  #include "clang/AST/ASTConsumer.h"  #include "clang/AST/ASTContext.h"  #include "clang/AST/DeclTemplate.h"  #include "clang/Parse/ParseDiagnostic.h" +#include "clang/Parse/RAIIObjectsForParser.h"  #include "clang/Sema/DeclSpec.h"  #include "clang/Sema/ParsedTemplate.h"  #include "clang/Sema/Scope.h" @@ -37,26 +37,6 @@ public:      return false;    }  }; - -/// \brief RAIIObject to destroy the contents of a SmallVector of -/// TemplateIdAnnotation pointers and clear the vector. -class DestroyTemplateIdAnnotationsRAIIObj { -  SmallVectorImpl<TemplateIdAnnotation *> &Container; - -public: -  DestroyTemplateIdAnnotationsRAIIObj( -      SmallVectorImpl<TemplateIdAnnotation *> &Container) -      : Container(Container) {} - -  ~DestroyTemplateIdAnnotationsRAIIObj() { -    for (SmallVectorImpl<TemplateIdAnnotation *>::iterator I = -             Container.begin(), -                                                           E = Container.end(); -         I != E; ++I) -      (*I)->Destroy(); -    Container.clear(); -  } -};  } // end anonymous namespace  IdentifierInfo *Parser::getSEHExceptKeyword() { @@ -231,6 +211,21 @@ void Parser::ConsumeExtraSemi(ExtraSemiKind Kind, unsigned TST) {        << FixItHint::CreateRemoval(SourceRange(StartLoc, EndLoc));  } +bool Parser::expectIdentifier() { +  if (Tok.is(tok::identifier)) +    return false; +  if (const auto *II = Tok.getIdentifierInfo()) { +    if (II->isCPlusPlusKeyword(getLangOpts())) { +      Diag(Tok, diag::err_expected_token_instead_of_objcxx_keyword) +          << tok::identifier << Tok.getIdentifierInfo(); +      // Objective-C++: Recover by treating this keyword as a valid identifier. +      return false; +    } +  } +  Diag(Tok, diag::err_expected) << tok::identifier; +  return true; +} +  //===----------------------------------------------------------------------===//  // Error recovery.  //===----------------------------------------------------------------------===// @@ -493,6 +488,8 @@ void Parser::Initialize() {    Ident_strict = nullptr;    Ident_replacement = nullptr; +  Ident_language = Ident_defined_in = Ident_generated_declaration = nullptr; +    Ident__except = nullptr;    Ident__exception_code = Ident__exception_info = nullptr; @@ -688,6 +685,9 @@ Parser::ParseExternalDeclaration(ParsedAttributesWithRange &attrs,    case tok::annot_pragma_fp_contract:      HandlePragmaFPContract();      return nullptr; +  case tok::annot_pragma_fp: +    HandlePragmaFP(); +    break;    case tok::annot_pragma_opencl_extension:      HandlePragmaOpenCLExtension();      return nullptr; @@ -1701,6 +1701,7 @@ bool Parser::TryAnnotateTypeOrScopeToken() {        Ty = Actions.ActOnTypenameType(getCurScope(), TypenameLoc, SS,                                       TemplateId->TemplateKWLoc,                                       TemplateId->Template, +                                     TemplateId->Name,                                       TemplateId->TemplateNameLoc,                                       TemplateId->LAngleLoc,                                       TemplateArgsPtr, @@ -1742,7 +1743,8 @@ bool Parser::TryAnnotateTypeOrScopeTokenAfterScopeSpec(CXXScopeSpec &SS,              *Tok.getIdentifierInfo(), Tok.getLocation(), getCurScope(), &SS,              false, NextToken().is(tok::period), nullptr,              /*IsCtorOrDtorName=*/false, -            /*NonTrivialTypeSourceInfo*/ true)) { +            /*NonTrivialTypeSourceInfo*/ true, +            /*IsClassTemplateDeductionContext*/GreaterThanIsOperator)) {        SourceLocation BeginLoc = Tok.getLocation();        if (SS.isNotEmpty()) // it was a C++ qualified type name.          BeginLoc = SS.getBeginLoc(); @@ -1964,8 +1966,10 @@ bool Parser::ParseMicrosoftIfExistsCondition(IfExistsCondition& Result) {    // Parse the unqualified-id.    SourceLocation TemplateKWLoc; // FIXME: parsed, but unused. -  if (ParseUnqualifiedId(Result.SS, false, true, true, nullptr, TemplateKWLoc, -                         Result.Name)) { +  if (ParseUnqualifiedId( +          Result.SS, /*EnteringContext*/false, /*AllowDestructorName*/true, +          /*AllowConstructorName*/true, /*AllowDeductionGuide*/false, nullptr, +          TemplateKWLoc, Result.Name)) {      T.skipToEnd();      return true;    } | 
