1 //===--- Parser.cpp - C Language Family Parser ----------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file implements the Parser interfaces. 11 // 12 //===----------------------------------------------------------------------===// 13 14 #include "clang/Parse/Parser.h" 15 #include "ParsePragma.h" 16 #include "RAIIObjectsForParser.h" 17 #include "clang/AST/ASTConsumer.h" 18 #include "clang/AST/ASTContext.h" 19 #include "clang/AST/DeclTemplate.h" 20 #include "clang/Parse/ParseDiagnostic.h" 21 #include "clang/Sema/DeclSpec.h" 22 #include "clang/Sema/ParsedTemplate.h" 23 #include "clang/Sema/Scope.h" 24 #include "llvm/Support/raw_ostream.h" 25 using namespace clang; 26 27 28 namespace { 29 /// \brief A comment handler that passes comments found by the preprocessor 30 /// to the parser action. 31 class ActionCommentHandler : public CommentHandler { 32 Sema &S; 33 34 public: 35 explicit ActionCommentHandler(Sema &S) : S(S) { } 36 37 virtual bool HandleComment(Preprocessor &PP, SourceRange Comment) { 38 S.ActOnComment(Comment); 39 return false; 40 } 41 }; 42 } // end anonymous namespace 43 44 IdentifierInfo *Parser::getSEHExceptKeyword() { 45 // __except is accepted as a (contextual) keyword 46 if (!Ident__except && (getLangOpts().MicrosoftExt || getLangOpts().Borland)) 47 Ident__except = PP.getIdentifierInfo("__except"); 48 49 return Ident__except; 50 } 51 52 Parser::Parser(Preprocessor &pp, Sema &actions, bool skipFunctionBodies) 53 : PP(pp), Actions(actions), Diags(PP.getDiagnostics()), 54 GreaterThanIsOperator(true), ColonIsSacred(false), 55 InMessageExpression(false), TemplateParameterDepth(0), 56 ParsingInObjCContainer(false) { 57 SkipFunctionBodies = pp.isCodeCompletionEnabled() || skipFunctionBodies; 58 Tok.startToken(); 59 Tok.setKind(tok::eof); 60 Actions.CurScope = 0; 61 NumCachedScopes = 0; 62 ParenCount = BracketCount = BraceCount = 0; 63 CurParsedObjCImpl = 0; 64 65 // Add #pragma handlers. These are removed and destroyed in the 66 // destructor. 67 AlignHandler.reset(new PragmaAlignHandler()); 68 PP.AddPragmaHandler(AlignHandler.get()); 69 70 GCCVisibilityHandler.reset(new PragmaGCCVisibilityHandler()); 71 PP.AddPragmaHandler("GCC", GCCVisibilityHandler.get()); 72 73 OptionsHandler.reset(new PragmaOptionsHandler()); 74 PP.AddPragmaHandler(OptionsHandler.get()); 75 76 PackHandler.reset(new PragmaPackHandler()); 77 PP.AddPragmaHandler(PackHandler.get()); 78 79 MSStructHandler.reset(new PragmaMSStructHandler()); 80 PP.AddPragmaHandler(MSStructHandler.get()); 81 82 UnusedHandler.reset(new PragmaUnusedHandler()); 83 PP.AddPragmaHandler(UnusedHandler.get()); 84 85 WeakHandler.reset(new PragmaWeakHandler()); 86 PP.AddPragmaHandler(WeakHandler.get()); 87 88 RedefineExtnameHandler.reset(new PragmaRedefineExtnameHandler()); 89 PP.AddPragmaHandler(RedefineExtnameHandler.get()); 90 91 FPContractHandler.reset(new PragmaFPContractHandler()); 92 PP.AddPragmaHandler("STDC", FPContractHandler.get()); 93 94 if (getLangOpts().OpenCL) { 95 OpenCLExtensionHandler.reset(new PragmaOpenCLExtensionHandler()); 96 PP.AddPragmaHandler("OPENCL", OpenCLExtensionHandler.get()); 97 98 PP.AddPragmaHandler("OPENCL", FPContractHandler.get()); 99 } 100 if (getLangOpts().OpenMP) 101 OpenMPHandler.reset(new PragmaOpenMPHandler()); 102 else 103 OpenMPHandler.reset(new PragmaNoOpenMPHandler()); 104 PP.AddPragmaHandler(OpenMPHandler.get()); 105 106 if (getLangOpts().MicrosoftExt) { 107 MSCommentHandler.reset(new PragmaCommentHandler(actions)); 108 PP.AddPragmaHandler(MSCommentHandler.get()); 109 MSDetectMismatchHandler.reset(new PragmaDetectMismatchHandler(actions)); 110 PP.AddPragmaHandler(MSDetectMismatchHandler.get()); 111 MSPointersToMembers.reset(new PragmaMSPointersToMembers()); 112 PP.AddPragmaHandler(MSPointersToMembers.get()); 113 MSVtorDisp.reset(new PragmaMSVtorDisp()); 114 PP.AddPragmaHandler(MSVtorDisp.get()); 115 } 116 117 CommentSemaHandler.reset(new ActionCommentHandler(actions)); 118 PP.addCommentHandler(CommentSemaHandler.get()); 119 120 PP.setCodeCompletionHandler(*this); 121 } 122 123 DiagnosticBuilder Parser::Diag(SourceLocation Loc, unsigned DiagID) { 124 return Diags.Report(Loc, DiagID); 125 } 126 127 DiagnosticBuilder Parser::Diag(const Token &Tok, unsigned DiagID) { 128 return Diag(Tok.getLocation(), DiagID); 129 } 130 131 /// \brief Emits a diagnostic suggesting parentheses surrounding a 132 /// given range. 133 /// 134 /// \param Loc The location where we'll emit the diagnostic. 135 /// \param DK The kind of diagnostic to emit. 136 /// \param ParenRange Source range enclosing code that should be parenthesized. 137 void Parser::SuggestParentheses(SourceLocation Loc, unsigned DK, 138 SourceRange ParenRange) { 139 SourceLocation EndLoc = PP.getLocForEndOfToken(ParenRange.getEnd()); 140 if (!ParenRange.getEnd().isFileID() || EndLoc.isInvalid()) { 141 // We can't display the parentheses, so just dig the 142 // warning/error and return. 143 Diag(Loc, DK); 144 return; 145 } 146 147 Diag(Loc, DK) 148 << FixItHint::CreateInsertion(ParenRange.getBegin(), "(") 149 << FixItHint::CreateInsertion(EndLoc, ")"); 150 } 151 152 static bool IsCommonTypo(tok::TokenKind ExpectedTok, const Token &Tok) { 153 switch (ExpectedTok) { 154 case tok::semi: 155 return Tok.is(tok::colon) || Tok.is(tok::comma); // : or , for ; 156 default: return false; 157 } 158 } 159 160 bool Parser::ExpectAndConsume(tok::TokenKind ExpectedTok, unsigned DiagID, 161 const char *Msg) { 162 if (Tok.is(ExpectedTok) || Tok.is(tok::code_completion)) { 163 ConsumeAnyToken(); 164 return false; 165 } 166 167 // Detect common single-character typos and resume. 168 if (IsCommonTypo(ExpectedTok, Tok)) { 169 SourceLocation Loc = Tok.getLocation(); 170 DiagnosticBuilder DB = Diag(Loc, DiagID); 171 DB << FixItHint::CreateReplacement(SourceRange(Loc), 172 getPunctuatorSpelling(ExpectedTok)); 173 if (DiagID == diag::err_expected) 174 DB << ExpectedTok; 175 else if (DiagID == diag::err_expected_after) 176 DB << Msg << ExpectedTok; 177 else 178 DB << Msg; 179 ConsumeAnyToken(); 180 181 // Pretend there wasn't a problem. 182 return false; 183 } 184 185 SourceLocation EndLoc = PP.getLocForEndOfToken(PrevTokLocation); 186 const char *Spelling = 0; 187 if (EndLoc.isValid()) 188 Spelling = tok::getPunctuatorSpelling(ExpectedTok); 189 190 DiagnosticBuilder DB = 191 Spelling 192 ? Diag(EndLoc, DiagID) << FixItHint::CreateInsertion(EndLoc, Spelling) 193 : Diag(Tok, DiagID); 194 if (DiagID == diag::err_expected) 195 DB << ExpectedTok; 196 else if (DiagID == diag::err_expected_after) 197 DB << Msg << ExpectedTok; 198 else 199 DB << Msg; 200 201 return true; 202 } 203 204 bool Parser::ExpectAndConsumeSemi(unsigned DiagID) { 205 if (TryConsumeToken(tok::semi)) 206 return false; 207 208 if (Tok.is(tok::code_completion)) { 209 handleUnexpectedCodeCompletionToken(); 210 return false; 211 } 212 213 if ((Tok.is(tok::r_paren) || Tok.is(tok::r_square)) && 214 NextToken().is(tok::semi)) { 215 Diag(Tok, diag::err_extraneous_token_before_semi) 216 << PP.getSpelling(Tok) 217 << FixItHint::CreateRemoval(Tok.getLocation()); 218 ConsumeAnyToken(); // The ')' or ']'. 219 ConsumeToken(); // The ';'. 220 return false; 221 } 222 223 return ExpectAndConsume(tok::semi, DiagID); 224 } 225 226 void Parser::ConsumeExtraSemi(ExtraSemiKind Kind, unsigned TST) { 227 if (!Tok.is(tok::semi)) return; 228 229 bool HadMultipleSemis = false; 230 SourceLocation StartLoc = Tok.getLocation(); 231 SourceLocation EndLoc = Tok.getLocation(); 232 ConsumeToken(); 233 234 while ((Tok.is(tok::semi) && !Tok.isAtStartOfLine())) { 235 HadMultipleSemis = true; 236 EndLoc = Tok.getLocation(); 237 ConsumeToken(); 238 } 239 240 // C++11 allows extra semicolons at namespace scope, but not in any of the 241 // other contexts. 242 if (Kind == OutsideFunction && getLangOpts().CPlusPlus) { 243 if (getLangOpts().CPlusPlus11) 244 Diag(StartLoc, diag::warn_cxx98_compat_top_level_semi) 245 << FixItHint::CreateRemoval(SourceRange(StartLoc, EndLoc)); 246 else 247 Diag(StartLoc, diag::ext_extra_semi_cxx11) 248 << FixItHint::CreateRemoval(SourceRange(StartLoc, EndLoc)); 249 return; 250 } 251 252 if (Kind != AfterMemberFunctionDefinition || HadMultipleSemis) 253 Diag(StartLoc, diag::ext_extra_semi) 254 << Kind << DeclSpec::getSpecifierName((DeclSpec::TST)TST, 255 Actions.getASTContext().getPrintingPolicy()) 256 << FixItHint::CreateRemoval(SourceRange(StartLoc, EndLoc)); 257 else 258 // A single semicolon is valid after a member function definition. 259 Diag(StartLoc, diag::warn_extra_semi_after_mem_fn_def) 260 << FixItHint::CreateRemoval(SourceRange(StartLoc, EndLoc)); 261 } 262 263 //===----------------------------------------------------------------------===// 264 // Error recovery. 265 //===----------------------------------------------------------------------===// 266 267 static bool HasFlagsSet(Parser::SkipUntilFlags L, Parser::SkipUntilFlags R) { 268 return (static_cast<unsigned>(L) & static_cast<unsigned>(R)) != 0; 269 } 270 271 /// SkipUntil - Read tokens until we get to the specified token, then consume 272 /// it (unless no flag StopBeforeMatch). Because we cannot guarantee that the 273 /// token will ever occur, this skips to the next token, or to some likely 274 /// good stopping point. If StopAtSemi is true, skipping will stop at a ';' 275 /// character. 276 /// 277 /// If SkipUntil finds the specified token, it returns true, otherwise it 278 /// returns false. 279 bool Parser::SkipUntil(ArrayRef<tok::TokenKind> Toks, SkipUntilFlags Flags) { 280 // We always want this function to skip at least one token if the first token 281 // isn't T and if not at EOF. 282 bool isFirstTokenSkipped = true; 283 while (1) { 284 // If we found one of the tokens, stop and return true. 285 for (unsigned i = 0, NumToks = Toks.size(); i != NumToks; ++i) { 286 if (Tok.is(Toks[i])) { 287 if (HasFlagsSet(Flags, StopBeforeMatch)) { 288 // Noop, don't consume the token. 289 } else { 290 ConsumeAnyToken(); 291 } 292 return true; 293 } 294 } 295 296 // Important special case: The caller has given up and just wants us to 297 // skip the rest of the file. Do this without recursing, since we can 298 // get here precisely because the caller detected too much recursion. 299 if (Toks.size() == 1 && Toks[0] == tok::eof && 300 !HasFlagsSet(Flags, StopAtSemi) && 301 !HasFlagsSet(Flags, StopAtCodeCompletion)) { 302 while (Tok.isNot(tok::eof)) 303 ConsumeAnyToken(); 304 return true; 305 } 306 307 switch (Tok.getKind()) { 308 case tok::eof: 309 // Ran out of tokens. 310 return false; 311 312 case tok::annot_pragma_openmp_end: 313 // Stop before an OpenMP pragma boundary. 314 case tok::annot_module_begin: 315 case tok::annot_module_end: 316 case tok::annot_module_include: 317 // Stop before we change submodules. They generally indicate a "good" 318 // place to pick up parsing again (except in the special case where 319 // we're trying to skip to EOF). 320 return false; 321 322 case tok::code_completion: 323 if (!HasFlagsSet(Flags, StopAtCodeCompletion)) 324 handleUnexpectedCodeCompletionToken(); 325 return false; 326 327 case tok::l_paren: 328 // Recursively skip properly-nested parens. 329 ConsumeParen(); 330 if (HasFlagsSet(Flags, StopAtCodeCompletion)) 331 SkipUntil(tok::r_paren, StopAtCodeCompletion); 332 else 333 SkipUntil(tok::r_paren); 334 break; 335 case tok::l_square: 336 // Recursively skip properly-nested square brackets. 337 ConsumeBracket(); 338 if (HasFlagsSet(Flags, StopAtCodeCompletion)) 339 SkipUntil(tok::r_square, StopAtCodeCompletion); 340 else 341 SkipUntil(tok::r_square); 342 break; 343 case tok::l_brace: 344 // Recursively skip properly-nested braces. 345 ConsumeBrace(); 346 if (HasFlagsSet(Flags, StopAtCodeCompletion)) 347 SkipUntil(tok::r_brace, StopAtCodeCompletion); 348 else 349 SkipUntil(tok::r_brace); 350 break; 351 352 // Okay, we found a ']' or '}' or ')', which we think should be balanced. 353 // Since the user wasn't looking for this token (if they were, it would 354 // already be handled), this isn't balanced. If there is a LHS token at a 355 // higher level, we will assume that this matches the unbalanced token 356 // and return it. Otherwise, this is a spurious RHS token, which we skip. 357 case tok::r_paren: 358 if (ParenCount && !isFirstTokenSkipped) 359 return false; // Matches something. 360 ConsumeParen(); 361 break; 362 case tok::r_square: 363 if (BracketCount && !isFirstTokenSkipped) 364 return false; // Matches something. 365 ConsumeBracket(); 366 break; 367 case tok::r_brace: 368 if (BraceCount && !isFirstTokenSkipped) 369 return false; // Matches something. 370 ConsumeBrace(); 371 break; 372 373 case tok::string_literal: 374 case tok::wide_string_literal: 375 case tok::utf8_string_literal: 376 case tok::utf16_string_literal: 377 case tok::utf32_string_literal: 378 ConsumeStringToken(); 379 break; 380 381 case tok::semi: 382 if (HasFlagsSet(Flags, StopAtSemi)) 383 return false; 384 // FALL THROUGH. 385 default: 386 // Skip this token. 387 ConsumeToken(); 388 break; 389 } 390 isFirstTokenSkipped = false; 391 } 392 } 393 394 //===----------------------------------------------------------------------===// 395 // Scope manipulation 396 //===----------------------------------------------------------------------===// 397 398 /// EnterScope - Start a new scope. 399 void Parser::EnterScope(unsigned ScopeFlags) { 400 if (NumCachedScopes) { 401 Scope *N = ScopeCache[--NumCachedScopes]; 402 N->Init(getCurScope(), ScopeFlags); 403 Actions.CurScope = N; 404 } else { 405 Actions.CurScope = new Scope(getCurScope(), ScopeFlags, Diags); 406 } 407 } 408 409 /// ExitScope - Pop a scope off the scope stack. 410 void Parser::ExitScope() { 411 assert(getCurScope() && "Scope imbalance!"); 412 413 // Inform the actions module that this scope is going away if there are any 414 // decls in it. 415 if (!getCurScope()->decl_empty()) 416 Actions.ActOnPopScope(Tok.getLocation(), getCurScope()); 417 418 Scope *OldScope = getCurScope(); 419 Actions.CurScope = OldScope->getParent(); 420 421 if (NumCachedScopes == ScopeCacheSize) 422 delete OldScope; 423 else 424 ScopeCache[NumCachedScopes++] = OldScope; 425 } 426 427 /// Set the flags for the current scope to ScopeFlags. If ManageFlags is false, 428 /// this object does nothing. 429 Parser::ParseScopeFlags::ParseScopeFlags(Parser *Self, unsigned ScopeFlags, 430 bool ManageFlags) 431 : CurScope(ManageFlags ? Self->getCurScope() : 0) { 432 if (CurScope) { 433 OldFlags = CurScope->getFlags(); 434 CurScope->setFlags(ScopeFlags); 435 } 436 } 437 438 /// Restore the flags for the current scope to what they were before this 439 /// object overrode them. 440 Parser::ParseScopeFlags::~ParseScopeFlags() { 441 if (CurScope) 442 CurScope->setFlags(OldFlags); 443 } 444 445 446 //===----------------------------------------------------------------------===// 447 // C99 6.9: External Definitions. 448 //===----------------------------------------------------------------------===// 449 450 Parser::~Parser() { 451 // If we still have scopes active, delete the scope tree. 452 delete getCurScope(); 453 Actions.CurScope = 0; 454 455 // Free the scope cache. 456 for (unsigned i = 0, e = NumCachedScopes; i != e; ++i) 457 delete ScopeCache[i]; 458 459 // Remove the pragma handlers we installed. 460 PP.RemovePragmaHandler(AlignHandler.get()); 461 AlignHandler.reset(); 462 PP.RemovePragmaHandler("GCC", GCCVisibilityHandler.get()); 463 GCCVisibilityHandler.reset(); 464 PP.RemovePragmaHandler(OptionsHandler.get()); 465 OptionsHandler.reset(); 466 PP.RemovePragmaHandler(PackHandler.get()); 467 PackHandler.reset(); 468 PP.RemovePragmaHandler(MSStructHandler.get()); 469 MSStructHandler.reset(); 470 PP.RemovePragmaHandler(UnusedHandler.get()); 471 UnusedHandler.reset(); 472 PP.RemovePragmaHandler(WeakHandler.get()); 473 WeakHandler.reset(); 474 PP.RemovePragmaHandler(RedefineExtnameHandler.get()); 475 RedefineExtnameHandler.reset(); 476 477 if (getLangOpts().OpenCL) { 478 PP.RemovePragmaHandler("OPENCL", OpenCLExtensionHandler.get()); 479 OpenCLExtensionHandler.reset(); 480 PP.RemovePragmaHandler("OPENCL", FPContractHandler.get()); 481 } 482 PP.RemovePragmaHandler(OpenMPHandler.get()); 483 OpenMPHandler.reset(); 484 485 if (getLangOpts().MicrosoftExt) { 486 PP.RemovePragmaHandler(MSCommentHandler.get()); 487 MSCommentHandler.reset(); 488 PP.RemovePragmaHandler(MSDetectMismatchHandler.get()); 489 MSDetectMismatchHandler.reset(); 490 PP.RemovePragmaHandler(MSPointersToMembers.get()); 491 MSPointersToMembers.reset(); 492 PP.RemovePragmaHandler(MSVtorDisp.get()); 493 MSVtorDisp.reset(); 494 } 495 496 PP.RemovePragmaHandler("STDC", FPContractHandler.get()); 497 FPContractHandler.reset(); 498 499 PP.removeCommentHandler(CommentSemaHandler.get()); 500 501 PP.clearCodeCompletionHandler(); 502 503 assert(TemplateIds.empty() && "Still alive TemplateIdAnnotations around?"); 504 } 505 506 /// Initialize - Warm up the parser. 507 /// 508 void Parser::Initialize() { 509 // Create the translation unit scope. Install it as the current scope. 510 assert(getCurScope() == 0 && "A scope is already active?"); 511 EnterScope(Scope::DeclScope); 512 Actions.ActOnTranslationUnitScope(getCurScope()); 513 514 // Initialization for Objective-C context sensitive keywords recognition. 515 // Referenced in Parser::ParseObjCTypeQualifierList. 516 if (getLangOpts().ObjC1) { 517 ObjCTypeQuals[objc_in] = &PP.getIdentifierTable().get("in"); 518 ObjCTypeQuals[objc_out] = &PP.getIdentifierTable().get("out"); 519 ObjCTypeQuals[objc_inout] = &PP.getIdentifierTable().get("inout"); 520 ObjCTypeQuals[objc_oneway] = &PP.getIdentifierTable().get("oneway"); 521 ObjCTypeQuals[objc_bycopy] = &PP.getIdentifierTable().get("bycopy"); 522 ObjCTypeQuals[objc_byref] = &PP.getIdentifierTable().get("byref"); 523 } 524 525 Ident_instancetype = 0; 526 Ident_final = 0; 527 Ident_sealed = 0; 528 Ident_override = 0; 529 530 Ident_super = &PP.getIdentifierTable().get("super"); 531 532 if (getLangOpts().AltiVec) { 533 Ident_vector = &PP.getIdentifierTable().get("vector"); 534 Ident_pixel = &PP.getIdentifierTable().get("pixel"); 535 Ident_bool = &PP.getIdentifierTable().get("bool"); 536 } 537 538 Ident_introduced = 0; 539 Ident_deprecated = 0; 540 Ident_obsoleted = 0; 541 Ident_unavailable = 0; 542 543 Ident__except = 0; 544 545 Ident__exception_code = Ident__exception_info = Ident__abnormal_termination = 0; 546 Ident___exception_code = Ident___exception_info = Ident___abnormal_termination = 0; 547 Ident_GetExceptionCode = Ident_GetExceptionInfo = Ident_AbnormalTermination = 0; 548 549 if(getLangOpts().Borland) { 550 Ident__exception_info = PP.getIdentifierInfo("_exception_info"); 551 Ident___exception_info = PP.getIdentifierInfo("__exception_info"); 552 Ident_GetExceptionInfo = PP.getIdentifierInfo("GetExceptionInformation"); 553 Ident__exception_code = PP.getIdentifierInfo("_exception_code"); 554 Ident___exception_code = PP.getIdentifierInfo("__exception_code"); 555 Ident_GetExceptionCode = PP.getIdentifierInfo("GetExceptionCode"); 556 Ident__abnormal_termination = PP.getIdentifierInfo("_abnormal_termination"); 557 Ident___abnormal_termination = PP.getIdentifierInfo("__abnormal_termination"); 558 Ident_AbnormalTermination = PP.getIdentifierInfo("AbnormalTermination"); 559 560 PP.SetPoisonReason(Ident__exception_code,diag::err_seh___except_block); 561 PP.SetPoisonReason(Ident___exception_code,diag::err_seh___except_block); 562 PP.SetPoisonReason(Ident_GetExceptionCode,diag::err_seh___except_block); 563 PP.SetPoisonReason(Ident__exception_info,diag::err_seh___except_filter); 564 PP.SetPoisonReason(Ident___exception_info,diag::err_seh___except_filter); 565 PP.SetPoisonReason(Ident_GetExceptionInfo,diag::err_seh___except_filter); 566 PP.SetPoisonReason(Ident__abnormal_termination,diag::err_seh___finally_block); 567 PP.SetPoisonReason(Ident___abnormal_termination,diag::err_seh___finally_block); 568 PP.SetPoisonReason(Ident_AbnormalTermination,diag::err_seh___finally_block); 569 } 570 571 Actions.Initialize(); 572 573 // Prime the lexer look-ahead. 574 ConsumeToken(); 575 } 576 577 namespace { 578 /// \brief RAIIObject to destroy the contents of a SmallVector of 579 /// TemplateIdAnnotation pointers and clear the vector. 580 class DestroyTemplateIdAnnotationsRAIIObj { 581 SmallVectorImpl<TemplateIdAnnotation *> &Container; 582 public: 583 DestroyTemplateIdAnnotationsRAIIObj(SmallVectorImpl<TemplateIdAnnotation *> 584 &Container) 585 : Container(Container) {} 586 587 ~DestroyTemplateIdAnnotationsRAIIObj() { 588 for (SmallVectorImpl<TemplateIdAnnotation *>::iterator I = 589 Container.begin(), E = Container.end(); 590 I != E; ++I) 591 (*I)->Destroy(); 592 Container.clear(); 593 } 594 }; 595 } 596 597 /// ParseTopLevelDecl - Parse one top-level declaration, return whatever the 598 /// action tells us to. This returns true if the EOF was encountered. 599 bool Parser::ParseTopLevelDecl(DeclGroupPtrTy &Result) { 600 DestroyTemplateIdAnnotationsRAIIObj CleanupRAII(TemplateIds); 601 602 // Skip over the EOF token, flagging end of previous input for incremental 603 // processing 604 if (PP.isIncrementalProcessingEnabled() && Tok.is(tok::eof)) 605 ConsumeToken(); 606 607 Result = DeclGroupPtrTy(); 608 switch (Tok.getKind()) { 609 case tok::annot_pragma_unused: 610 HandlePragmaUnused(); 611 return false; 612 613 case tok::annot_module_include: 614 Actions.ActOnModuleInclude(Tok.getLocation(), 615 reinterpret_cast<Module *>( 616 Tok.getAnnotationValue())); 617 ConsumeToken(); 618 return false; 619 620 case tok::annot_module_begin: 621 case tok::annot_module_end: 622 // FIXME: Update visibility based on the submodule we're in. 623 ConsumeToken(); 624 return false; 625 626 case tok::eof: 627 // Late template parsing can begin. 628 if (getLangOpts().DelayedTemplateParsing) 629 Actions.SetLateTemplateParser(LateTemplateParserCallback, this); 630 if (!PP.isIncrementalProcessingEnabled()) 631 Actions.ActOnEndOfTranslationUnit(); 632 //else don't tell Sema that we ended parsing: more input might come. 633 return true; 634 635 default: 636 break; 637 } 638 639 ParsedAttributesWithRange attrs(AttrFactory); 640 MaybeParseCXX11Attributes(attrs); 641 MaybeParseMicrosoftAttributes(attrs); 642 643 Result = ParseExternalDeclaration(attrs); 644 return false; 645 } 646 647 /// ParseExternalDeclaration: 648 /// 649 /// external-declaration: [C99 6.9], declaration: [C++ dcl.dcl] 650 /// function-definition 651 /// declaration 652 /// [GNU] asm-definition 653 /// [GNU] __extension__ external-declaration 654 /// [OBJC] objc-class-definition 655 /// [OBJC] objc-class-declaration 656 /// [OBJC] objc-alias-declaration 657 /// [OBJC] objc-protocol-definition 658 /// [OBJC] objc-method-definition 659 /// [OBJC] @end 660 /// [C++] linkage-specification 661 /// [GNU] asm-definition: 662 /// simple-asm-expr ';' 663 /// [C++11] empty-declaration 664 /// [C++11] attribute-declaration 665 /// 666 /// [C++11] empty-declaration: 667 /// ';' 668 /// 669 /// [C++0x/GNU] 'extern' 'template' declaration 670 Parser::DeclGroupPtrTy 671 Parser::ParseExternalDeclaration(ParsedAttributesWithRange &attrs, 672 ParsingDeclSpec *DS) { 673 DestroyTemplateIdAnnotationsRAIIObj CleanupRAII(TemplateIds); 674 ParenBraceBracketBalancer BalancerRAIIObj(*this); 675 676 if (PP.isCodeCompletionReached()) { 677 cutOffParsing(); 678 return DeclGroupPtrTy(); 679 } 680 681 Decl *SingleDecl = 0; 682 switch (Tok.getKind()) { 683 case tok::annot_pragma_vis: 684 HandlePragmaVisibility(); 685 return DeclGroupPtrTy(); 686 case tok::annot_pragma_pack: 687 HandlePragmaPack(); 688 return DeclGroupPtrTy(); 689 case tok::annot_pragma_msstruct: 690 HandlePragmaMSStruct(); 691 return DeclGroupPtrTy(); 692 case tok::annot_pragma_align: 693 HandlePragmaAlign(); 694 return DeclGroupPtrTy(); 695 case tok::annot_pragma_weak: 696 HandlePragmaWeak(); 697 return DeclGroupPtrTy(); 698 case tok::annot_pragma_weakalias: 699 HandlePragmaWeakAlias(); 700 return DeclGroupPtrTy(); 701 case tok::annot_pragma_redefine_extname: 702 HandlePragmaRedefineExtname(); 703 return DeclGroupPtrTy(); 704 case tok::annot_pragma_fp_contract: 705 HandlePragmaFPContract(); 706 return DeclGroupPtrTy(); 707 case tok::annot_pragma_opencl_extension: 708 HandlePragmaOpenCLExtension(); 709 return DeclGroupPtrTy(); 710 case tok::annot_pragma_openmp: 711 ParseOpenMPDeclarativeDirective(); 712 return DeclGroupPtrTy(); 713 case tok::annot_pragma_ms_pointers_to_members: 714 HandlePragmaMSPointersToMembers(); 715 return DeclGroupPtrTy(); 716 case tok::annot_pragma_ms_vtordisp: 717 HandlePragmaMSVtorDisp(); 718 return DeclGroupPtrTy(); 719 case tok::semi: 720 // Either a C++11 empty-declaration or attribute-declaration. 721 SingleDecl = Actions.ActOnEmptyDeclaration(getCurScope(), 722 attrs.getList(), 723 Tok.getLocation()); 724 ConsumeExtraSemi(OutsideFunction); 725 break; 726 case tok::r_brace: 727 Diag(Tok, diag::err_extraneous_closing_brace); 728 ConsumeBrace(); 729 return DeclGroupPtrTy(); 730 case tok::eof: 731 Diag(Tok, diag::err_expected_external_declaration); 732 return DeclGroupPtrTy(); 733 case tok::kw___extension__: { 734 // __extension__ silences extension warnings in the subexpression. 735 ExtensionRAIIObject O(Diags); // Use RAII to do this. 736 ConsumeToken(); 737 return ParseExternalDeclaration(attrs); 738 } 739 case tok::kw_asm: { 740 ProhibitAttributes(attrs); 741 742 SourceLocation StartLoc = Tok.getLocation(); 743 SourceLocation EndLoc; 744 ExprResult Result(ParseSimpleAsm(&EndLoc)); 745 746 ExpectAndConsume(tok::semi, diag::err_expected_after, 747 "top-level asm block"); 748 749 if (Result.isInvalid()) 750 return DeclGroupPtrTy(); 751 SingleDecl = Actions.ActOnFileScopeAsmDecl(Result.get(), StartLoc, EndLoc); 752 break; 753 } 754 case tok::at: 755 return ParseObjCAtDirectives(); 756 case tok::minus: 757 case tok::plus: 758 if (!getLangOpts().ObjC1) { 759 Diag(Tok, diag::err_expected_external_declaration); 760 ConsumeToken(); 761 return DeclGroupPtrTy(); 762 } 763 SingleDecl = ParseObjCMethodDefinition(); 764 break; 765 case tok::code_completion: 766 Actions.CodeCompleteOrdinaryName(getCurScope(), 767 CurParsedObjCImpl? Sema::PCC_ObjCImplementation 768 : Sema::PCC_Namespace); 769 cutOffParsing(); 770 return DeclGroupPtrTy(); 771 case tok::kw_using: 772 case tok::kw_namespace: 773 case tok::kw_typedef: 774 case tok::kw_template: 775 case tok::kw_export: // As in 'export template' 776 case tok::kw_static_assert: 777 case tok::kw__Static_assert: 778 // A function definition cannot start with any of these keywords. 779 { 780 SourceLocation DeclEnd; 781 StmtVector Stmts; 782 return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs); 783 } 784 785 case tok::kw_static: 786 // Parse (then ignore) 'static' prior to a template instantiation. This is 787 // a GCC extension that we intentionally do not support. 788 if (getLangOpts().CPlusPlus && NextToken().is(tok::kw_template)) { 789 Diag(ConsumeToken(), diag::warn_static_inline_explicit_inst_ignored) 790 << 0; 791 SourceLocation DeclEnd; 792 StmtVector Stmts; 793 return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs); 794 } 795 goto dont_know; 796 797 case tok::kw_inline: 798 if (getLangOpts().CPlusPlus) { 799 tok::TokenKind NextKind = NextToken().getKind(); 800 801 // Inline namespaces. Allowed as an extension even in C++03. 802 if (NextKind == tok::kw_namespace) { 803 SourceLocation DeclEnd; 804 StmtVector Stmts; 805 return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs); 806 } 807 808 // Parse (then ignore) 'inline' prior to a template instantiation. This is 809 // a GCC extension that we intentionally do not support. 810 if (NextKind == tok::kw_template) { 811 Diag(ConsumeToken(), diag::warn_static_inline_explicit_inst_ignored) 812 << 1; 813 SourceLocation DeclEnd; 814 StmtVector Stmts; 815 return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs); 816 } 817 } 818 goto dont_know; 819 820 case tok::kw_extern: 821 if (getLangOpts().CPlusPlus && NextToken().is(tok::kw_template)) { 822 // Extern templates 823 SourceLocation ExternLoc = ConsumeToken(); 824 SourceLocation TemplateLoc = ConsumeToken(); 825 Diag(ExternLoc, getLangOpts().CPlusPlus11 ? 826 diag::warn_cxx98_compat_extern_template : 827 diag::ext_extern_template) << SourceRange(ExternLoc, TemplateLoc); 828 SourceLocation DeclEnd; 829 return Actions.ConvertDeclToDeclGroup( 830 ParseExplicitInstantiation(Declarator::FileContext, 831 ExternLoc, TemplateLoc, DeclEnd)); 832 } 833 // FIXME: Detect C++ linkage specifications here? 834 goto dont_know; 835 836 case tok::kw___if_exists: 837 case tok::kw___if_not_exists: 838 ParseMicrosoftIfExistsExternalDeclaration(); 839 return DeclGroupPtrTy(); 840 841 default: 842 dont_know: 843 // We can't tell whether this is a function-definition or declaration yet. 844 return ParseDeclarationOrFunctionDefinition(attrs, DS); 845 } 846 847 // This routine returns a DeclGroup, if the thing we parsed only contains a 848 // single decl, convert it now. 849 return Actions.ConvertDeclToDeclGroup(SingleDecl); 850 } 851 852 /// \brief Determine whether the current token, if it occurs after a 853 /// declarator, continues a declaration or declaration list. 854 bool Parser::isDeclarationAfterDeclarator() { 855 // Check for '= delete' or '= default' 856 if (getLangOpts().CPlusPlus && Tok.is(tok::equal)) { 857 const Token &KW = NextToken(); 858 if (KW.is(tok::kw_default) || KW.is(tok::kw_delete)) 859 return false; 860 } 861 862 return Tok.is(tok::equal) || // int X()= -> not a function def 863 Tok.is(tok::comma) || // int X(), -> not a function def 864 Tok.is(tok::semi) || // int X(); -> not a function def 865 Tok.is(tok::kw_asm) || // int X() __asm__ -> not a function def 866 Tok.is(tok::kw___attribute) || // int X() __attr__ -> not a function def 867 (getLangOpts().CPlusPlus && 868 Tok.is(tok::l_paren)); // int X(0) -> not a function def [C++] 869 } 870 871 /// \brief Determine whether the current token, if it occurs after a 872 /// declarator, indicates the start of a function definition. 873 bool Parser::isStartOfFunctionDefinition(const ParsingDeclarator &Declarator) { 874 assert(Declarator.isFunctionDeclarator() && "Isn't a function declarator"); 875 if (Tok.is(tok::l_brace)) // int X() {} 876 return true; 877 878 // Handle K&R C argument lists: int X(f) int f; {} 879 if (!getLangOpts().CPlusPlus && 880 Declarator.getFunctionTypeInfo().isKNRPrototype()) 881 return isDeclarationSpecifier(); 882 883 if (getLangOpts().CPlusPlus && Tok.is(tok::equal)) { 884 const Token &KW = NextToken(); 885 return KW.is(tok::kw_default) || KW.is(tok::kw_delete); 886 } 887 888 return Tok.is(tok::colon) || // X() : Base() {} (used for ctors) 889 Tok.is(tok::kw_try); // X() try { ... } 890 } 891 892 /// ParseDeclarationOrFunctionDefinition - Parse either a function-definition or 893 /// a declaration. We can't tell which we have until we read up to the 894 /// compound-statement in function-definition. TemplateParams, if 895 /// non-NULL, provides the template parameters when we're parsing a 896 /// C++ template-declaration. 897 /// 898 /// function-definition: [C99 6.9.1] 899 /// decl-specs declarator declaration-list[opt] compound-statement 900 /// [C90] function-definition: [C99 6.7.1] - implicit int result 901 /// [C90] decl-specs[opt] declarator declaration-list[opt] compound-statement 902 /// 903 /// declaration: [C99 6.7] 904 /// declaration-specifiers init-declarator-list[opt] ';' 905 /// [!C99] init-declarator-list ';' [TODO: warn in c99 mode] 906 /// [OMP] threadprivate-directive [TODO] 907 /// 908 Parser::DeclGroupPtrTy 909 Parser::ParseDeclOrFunctionDefInternal(ParsedAttributesWithRange &attrs, 910 ParsingDeclSpec &DS, 911 AccessSpecifier AS) { 912 // Parse the common declaration-specifiers piece. 913 ParseDeclarationSpecifiers(DS, ParsedTemplateInfo(), AS, DSC_top_level); 914 915 // If we had a free-standing type definition with a missing semicolon, we 916 // may get this far before the problem becomes obvious. 917 if (DS.hasTagDefinition() && 918 DiagnoseMissingSemiAfterTagDefinition(DS, AS, DSC_top_level)) 919 return DeclGroupPtrTy(); 920 921 // C99 6.7.2.3p6: Handle "struct-or-union identifier;", "enum { X };" 922 // declaration-specifiers init-declarator-list[opt] ';' 923 if (Tok.is(tok::semi)) { 924 ProhibitAttributes(attrs); 925 ConsumeToken(); 926 Decl *TheDecl = Actions.ParsedFreeStandingDeclSpec(getCurScope(), AS, DS); 927 DS.complete(TheDecl); 928 return Actions.ConvertDeclToDeclGroup(TheDecl); 929 } 930 931 DS.takeAttributesFrom(attrs); 932 933 // ObjC2 allows prefix attributes on class interfaces and protocols. 934 // FIXME: This still needs better diagnostics. We should only accept 935 // attributes here, no types, etc. 936 if (getLangOpts().ObjC2 && Tok.is(tok::at)) { 937 SourceLocation AtLoc = ConsumeToken(); // the "@" 938 if (!Tok.isObjCAtKeyword(tok::objc_interface) && 939 !Tok.isObjCAtKeyword(tok::objc_protocol)) { 940 Diag(Tok, diag::err_objc_unexpected_attr); 941 SkipUntil(tok::semi); // FIXME: better skip? 942 return DeclGroupPtrTy(); 943 } 944 945 DS.abort(); 946 947 const char *PrevSpec = 0; 948 unsigned DiagID; 949 if (DS.SetTypeSpecType(DeclSpec::TST_unspecified, AtLoc, PrevSpec, DiagID, 950 Actions.getASTContext().getPrintingPolicy())) 951 Diag(AtLoc, DiagID) << PrevSpec; 952 953 if (Tok.isObjCAtKeyword(tok::objc_protocol)) 954 return ParseObjCAtProtocolDeclaration(AtLoc, DS.getAttributes()); 955 956 return Actions.ConvertDeclToDeclGroup( 957 ParseObjCAtInterfaceDeclaration(AtLoc, DS.getAttributes())); 958 } 959 960 // If the declspec consisted only of 'extern' and we have a string 961 // literal following it, this must be a C++ linkage specifier like 962 // 'extern "C"'. 963 if (Tok.is(tok::string_literal) && getLangOpts().CPlusPlus && 964 DS.getStorageClassSpec() == DeclSpec::SCS_extern && 965 DS.getParsedSpecifiers() == DeclSpec::PQ_StorageClassSpecifier) { 966 Decl *TheDecl = ParseLinkage(DS, Declarator::FileContext); 967 return Actions.ConvertDeclToDeclGroup(TheDecl); 968 } 969 970 return ParseDeclGroup(DS, Declarator::FileContext, true); 971 } 972 973 Parser::DeclGroupPtrTy 974 Parser::ParseDeclarationOrFunctionDefinition(ParsedAttributesWithRange &attrs, 975 ParsingDeclSpec *DS, 976 AccessSpecifier AS) { 977 if (DS) { 978 return ParseDeclOrFunctionDefInternal(attrs, *DS, AS); 979 } else { 980 ParsingDeclSpec PDS(*this); 981 // Must temporarily exit the objective-c container scope for 982 // parsing c constructs and re-enter objc container scope 983 // afterwards. 984 ObjCDeclContextSwitch ObjCDC(*this); 985 986 return ParseDeclOrFunctionDefInternal(attrs, PDS, AS); 987 } 988 } 989 990 991 static inline bool isFunctionDeclaratorRequiringReturnTypeDeduction( 992 const Declarator &D) { 993 if (!D.isFunctionDeclarator() || !D.getDeclSpec().containsPlaceholderType()) 994 return false; 995 for (unsigned I = 0, E = D.getNumTypeObjects(); I != E; ++I) { 996 unsigned chunkIndex = E - I - 1; 997 const DeclaratorChunk &DeclType = D.getTypeObject(chunkIndex); 998 if (DeclType.Kind == DeclaratorChunk::Function) { 999 const DeclaratorChunk::FunctionTypeInfo &FTI = DeclType.Fun; 1000 if (!FTI.hasTrailingReturnType()) 1001 return true; 1002 QualType TrailingRetType = FTI.getTrailingReturnType().get(); 1003 return TrailingRetType->getCanonicalTypeInternal() 1004 ->getContainedAutoType(); 1005 } 1006 } 1007 return false; 1008 } 1009 1010 /// ParseFunctionDefinition - We parsed and verified that the specified 1011 /// Declarator is well formed. If this is a K&R-style function, read the 1012 /// parameters declaration-list, then start the compound-statement. 1013 /// 1014 /// function-definition: [C99 6.9.1] 1015 /// decl-specs declarator declaration-list[opt] compound-statement 1016 /// [C90] function-definition: [C99 6.7.1] - implicit int result 1017 /// [C90] decl-specs[opt] declarator declaration-list[opt] compound-statement 1018 /// [C++] function-definition: [C++ 8.4] 1019 /// decl-specifier-seq[opt] declarator ctor-initializer[opt] 1020 /// function-body 1021 /// [C++] function-definition: [C++ 8.4] 1022 /// decl-specifier-seq[opt] declarator function-try-block 1023 /// 1024 Decl *Parser::ParseFunctionDefinition(ParsingDeclarator &D, 1025 const ParsedTemplateInfo &TemplateInfo, 1026 LateParsedAttrList *LateParsedAttrs) { 1027 // Poison the SEH identifiers so they are flagged as illegal in function bodies 1028 PoisonSEHIdentifiersRAIIObject PoisonSEHIdentifiers(*this, true); 1029 const DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo(); 1030 1031 // If this is C90 and the declspecs were completely missing, fudge in an 1032 // implicit int. We do this here because this is the only place where 1033 // declaration-specifiers are completely optional in the grammar. 1034 if (getLangOpts().ImplicitInt && D.getDeclSpec().isEmpty()) { 1035 const char *PrevSpec; 1036 unsigned DiagID; 1037 const PrintingPolicy &Policy = Actions.getASTContext().getPrintingPolicy(); 1038 D.getMutableDeclSpec().SetTypeSpecType(DeclSpec::TST_int, 1039 D.getIdentifierLoc(), 1040 PrevSpec, DiagID, 1041 Policy); 1042 D.SetRangeBegin(D.getDeclSpec().getSourceRange().getBegin()); 1043 } 1044 1045 // If this declaration was formed with a K&R-style identifier list for the 1046 // arguments, parse declarations for all of the args next. 1047 // int foo(a,b) int a; float b; {} 1048 if (FTI.isKNRPrototype()) 1049 ParseKNRParamDeclarations(D); 1050 1051 // We should have either an opening brace or, in a C++ constructor, 1052 // we may have a colon. 1053 if (Tok.isNot(tok::l_brace) && 1054 (!getLangOpts().CPlusPlus || 1055 (Tok.isNot(tok::colon) && Tok.isNot(tok::kw_try) && 1056 Tok.isNot(tok::equal)))) { 1057 Diag(Tok, diag::err_expected_fn_body); 1058 1059 // Skip over garbage, until we get to '{'. Don't eat the '{'. 1060 SkipUntil(tok::l_brace, StopAtSemi | StopBeforeMatch); 1061 1062 // If we didn't find the '{', bail out. 1063 if (Tok.isNot(tok::l_brace)) 1064 return 0; 1065 } 1066 1067 // Check to make sure that any normal attributes are allowed to be on 1068 // a definition. Late parsed attributes are checked at the end. 1069 if (Tok.isNot(tok::equal)) { 1070 AttributeList *DtorAttrs = D.getAttributes(); 1071 while (DtorAttrs) { 1072 if (DtorAttrs->isKnownToGCC() && 1073 !DtorAttrs->isCXX11Attribute()) { 1074 Diag(DtorAttrs->getLoc(), diag::warn_attribute_on_function_definition) 1075 << DtorAttrs->getName(); 1076 } 1077 DtorAttrs = DtorAttrs->getNext(); 1078 } 1079 } 1080 1081 // In delayed template parsing mode, for function template we consume the 1082 // tokens and store them for late parsing at the end of the translation unit. 1083 if (getLangOpts().DelayedTemplateParsing && Tok.isNot(tok::equal) && 1084 TemplateInfo.Kind == ParsedTemplateInfo::Template && 1085 !D.getDeclSpec().isConstexprSpecified() && 1086 !isFunctionDeclaratorRequiringReturnTypeDeduction(D)) { 1087 MultiTemplateParamsArg TemplateParameterLists(*TemplateInfo.TemplateParams); 1088 1089 ParseScope BodyScope(this, Scope::FnScope|Scope::DeclScope); 1090 Scope *ParentScope = getCurScope()->getParent(); 1091 1092 D.setFunctionDefinitionKind(FDK_Definition); 1093 Decl *DP = Actions.HandleDeclarator(ParentScope, D, 1094 TemplateParameterLists); 1095 D.complete(DP); 1096 D.getMutableDeclSpec().abort(); 1097 1098 CachedTokens Toks; 1099 LexTemplateFunctionForLateParsing(Toks); 1100 1101 if (DP) { 1102 FunctionDecl *FnD = DP->getAsFunction(); 1103 Actions.CheckForFunctionRedefinition(FnD); 1104 Actions.MarkAsLateParsedTemplate(FnD, DP, Toks); 1105 } 1106 return DP; 1107 } 1108 else if (CurParsedObjCImpl && 1109 !TemplateInfo.TemplateParams && 1110 (Tok.is(tok::l_brace) || Tok.is(tok::kw_try) || 1111 Tok.is(tok::colon)) && 1112 Actions.CurContext->isTranslationUnit()) { 1113 ParseScope BodyScope(this, Scope::FnScope|Scope::DeclScope); 1114 Scope *ParentScope = getCurScope()->getParent(); 1115 1116 D.setFunctionDefinitionKind(FDK_Definition); 1117 Decl *FuncDecl = Actions.HandleDeclarator(ParentScope, D, 1118 MultiTemplateParamsArg()); 1119 D.complete(FuncDecl); 1120 D.getMutableDeclSpec().abort(); 1121 if (FuncDecl) { 1122 // Consume the tokens and store them for later parsing. 1123 StashAwayMethodOrFunctionBodyTokens(FuncDecl); 1124 CurParsedObjCImpl->HasCFunction = true; 1125 return FuncDecl; 1126 } 1127 } 1128 1129 // Enter a scope for the function body. 1130 ParseScope BodyScope(this, Scope::FnScope|Scope::DeclScope); 1131 1132 // Tell the actions module that we have entered a function definition with the 1133 // specified Declarator for the function. 1134 Decl *Res = TemplateInfo.TemplateParams? 1135 Actions.ActOnStartOfFunctionTemplateDef(getCurScope(), 1136 *TemplateInfo.TemplateParams, D) 1137 : Actions.ActOnStartOfFunctionDef(getCurScope(), D); 1138 1139 // Break out of the ParsingDeclarator context before we parse the body. 1140 D.complete(Res); 1141 1142 // Break out of the ParsingDeclSpec context, too. This const_cast is 1143 // safe because we're always the sole owner. 1144 D.getMutableDeclSpec().abort(); 1145 1146 if (TryConsumeToken(tok::equal)) { 1147 assert(getLangOpts().CPlusPlus && "Only C++ function definitions have '='"); 1148 Actions.ActOnFinishFunctionBody(Res, 0, false); 1149 1150 bool Delete = false; 1151 SourceLocation KWLoc; 1152 if (TryConsumeToken(tok::kw_delete, KWLoc)) { 1153 Diag(KWLoc, getLangOpts().CPlusPlus11 1154 ? diag::warn_cxx98_compat_deleted_function 1155 : diag::ext_deleted_function); 1156 Actions.SetDeclDeleted(Res, KWLoc); 1157 Delete = true; 1158 } else if (TryConsumeToken(tok::kw_default, KWLoc)) { 1159 Diag(KWLoc, getLangOpts().CPlusPlus11 1160 ? diag::warn_cxx98_compat_defaulted_function 1161 : diag::ext_defaulted_function); 1162 Actions.SetDeclDefaulted(Res, KWLoc); 1163 } else { 1164 llvm_unreachable("function definition after = not 'delete' or 'default'"); 1165 } 1166 1167 if (Tok.is(tok::comma)) { 1168 Diag(KWLoc, diag::err_default_delete_in_multiple_declaration) 1169 << Delete; 1170 SkipUntil(tok::semi); 1171 } else if (ExpectAndConsume(tok::semi, diag::err_expected_after, 1172 Delete ? "delete" : "default")) { 1173 SkipUntil(tok::semi); 1174 } 1175 1176 return Res; 1177 } 1178 1179 if (Tok.is(tok::kw_try)) 1180 return ParseFunctionTryBlock(Res, BodyScope); 1181 1182 // If we have a colon, then we're probably parsing a C++ 1183 // ctor-initializer. 1184 if (Tok.is(tok::colon)) { 1185 ParseConstructorInitializer(Res); 1186 1187 // Recover from error. 1188 if (!Tok.is(tok::l_brace)) { 1189 BodyScope.Exit(); 1190 Actions.ActOnFinishFunctionBody(Res, 0); 1191 return Res; 1192 } 1193 } else 1194 Actions.ActOnDefaultCtorInitializers(Res); 1195 1196 // Late attributes are parsed in the same scope as the function body. 1197 if (LateParsedAttrs) 1198 ParseLexedAttributeList(*LateParsedAttrs, Res, false, true); 1199 1200 return ParseFunctionStatementBody(Res, BodyScope); 1201 } 1202 1203 /// ParseKNRParamDeclarations - Parse 'declaration-list[opt]' which provides 1204 /// types for a function with a K&R-style identifier list for arguments. 1205 void Parser::ParseKNRParamDeclarations(Declarator &D) { 1206 // We know that the top-level of this declarator is a function. 1207 DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo(); 1208 1209 // Enter function-declaration scope, limiting any declarators to the 1210 // function prototype scope, including parameter declarators. 1211 ParseScope PrototypeScope(this, Scope::FunctionPrototypeScope | 1212 Scope::FunctionDeclarationScope | Scope::DeclScope); 1213 1214 // Read all the argument declarations. 1215 while (isDeclarationSpecifier()) { 1216 SourceLocation DSStart = Tok.getLocation(); 1217 1218 // Parse the common declaration-specifiers piece. 1219 DeclSpec DS(AttrFactory); 1220 ParseDeclarationSpecifiers(DS); 1221 1222 // C99 6.9.1p6: 'each declaration in the declaration list shall have at 1223 // least one declarator'. 1224 // NOTE: GCC just makes this an ext-warn. It's not clear what it does with 1225 // the declarations though. It's trivial to ignore them, really hard to do 1226 // anything else with them. 1227 if (TryConsumeToken(tok::semi)) { 1228 Diag(DSStart, diag::err_declaration_does_not_declare_param); 1229 continue; 1230 } 1231 1232 // C99 6.9.1p6: Declarations shall contain no storage-class specifiers other 1233 // than register. 1234 if (DS.getStorageClassSpec() != DeclSpec::SCS_unspecified && 1235 DS.getStorageClassSpec() != DeclSpec::SCS_register) { 1236 Diag(DS.getStorageClassSpecLoc(), 1237 diag::err_invalid_storage_class_in_func_decl); 1238 DS.ClearStorageClassSpecs(); 1239 } 1240 if (DS.getThreadStorageClassSpec() != DeclSpec::TSCS_unspecified) { 1241 Diag(DS.getThreadStorageClassSpecLoc(), 1242 diag::err_invalid_storage_class_in_func_decl); 1243 DS.ClearStorageClassSpecs(); 1244 } 1245 1246 // Parse the first declarator attached to this declspec. 1247 Declarator ParmDeclarator(DS, Declarator::KNRTypeListContext); 1248 ParseDeclarator(ParmDeclarator); 1249 1250 // Handle the full declarator list. 1251 while (1) { 1252 // If attributes are present, parse them. 1253 MaybeParseGNUAttributes(ParmDeclarator); 1254 1255 // Ask the actions module to compute the type for this declarator. 1256 Decl *Param = 1257 Actions.ActOnParamDeclarator(getCurScope(), ParmDeclarator); 1258 1259 if (Param && 1260 // A missing identifier has already been diagnosed. 1261 ParmDeclarator.getIdentifier()) { 1262 1263 // Scan the argument list looking for the correct param to apply this 1264 // type. 1265 for (unsigned i = 0; ; ++i) { 1266 // C99 6.9.1p6: those declarators shall declare only identifiers from 1267 // the identifier list. 1268 if (i == FTI.NumArgs) { 1269 Diag(ParmDeclarator.getIdentifierLoc(), diag::err_no_matching_param) 1270 << ParmDeclarator.getIdentifier(); 1271 break; 1272 } 1273 1274 if (FTI.ArgInfo[i].Ident == ParmDeclarator.getIdentifier()) { 1275 // Reject redefinitions of parameters. 1276 if (FTI.ArgInfo[i].Param) { 1277 Diag(ParmDeclarator.getIdentifierLoc(), 1278 diag::err_param_redefinition) 1279 << ParmDeclarator.getIdentifier(); 1280 } else { 1281 FTI.ArgInfo[i].Param = Param; 1282 } 1283 break; 1284 } 1285 } 1286 } 1287 1288 // If we don't have a comma, it is either the end of the list (a ';') or 1289 // an error, bail out. 1290 if (Tok.isNot(tok::comma)) 1291 break; 1292 1293 ParmDeclarator.clear(); 1294 1295 // Consume the comma. 1296 ParmDeclarator.setCommaLoc(ConsumeToken()); 1297 1298 // Parse the next declarator. 1299 ParseDeclarator(ParmDeclarator); 1300 } 1301 1302 // Consume ';' and continue parsing. 1303 if (!ExpectAndConsumeSemi(diag::err_expected_semi_declaration)) 1304 continue; 1305 1306 // Otherwise recover by skipping to next semi or mandatory function body. 1307 if (SkipUntil(tok::l_brace, StopAtSemi | StopBeforeMatch)) 1308 break; 1309 TryConsumeToken(tok::semi); 1310 } 1311 1312 // The actions module must verify that all arguments were declared. 1313 Actions.ActOnFinishKNRParamDeclarations(getCurScope(), D, Tok.getLocation()); 1314 } 1315 1316 1317 /// ParseAsmStringLiteral - This is just a normal string-literal, but is not 1318 /// allowed to be a wide string, and is not subject to character translation. 1319 /// 1320 /// [GNU] asm-string-literal: 1321 /// string-literal 1322 /// 1323 Parser::ExprResult Parser::ParseAsmStringLiteral() { 1324 switch (Tok.getKind()) { 1325 case tok::string_literal: 1326 break; 1327 case tok::utf8_string_literal: 1328 case tok::utf16_string_literal: 1329 case tok::utf32_string_literal: 1330 case tok::wide_string_literal: { 1331 SourceLocation L = Tok.getLocation(); 1332 Diag(Tok, diag::err_asm_operand_wide_string_literal) 1333 << (Tok.getKind() == tok::wide_string_literal) 1334 << SourceRange(L, L); 1335 return ExprError(); 1336 } 1337 default: 1338 Diag(Tok, diag::err_expected_string_literal) 1339 << /*Source='in...'*/0 << "'asm'"; 1340 return ExprError(); 1341 } 1342 1343 return ParseStringLiteralExpression(); 1344 } 1345 1346 /// ParseSimpleAsm 1347 /// 1348 /// [GNU] simple-asm-expr: 1349 /// 'asm' '(' asm-string-literal ')' 1350 /// 1351 Parser::ExprResult Parser::ParseSimpleAsm(SourceLocation *EndLoc) { 1352 assert(Tok.is(tok::kw_asm) && "Not an asm!"); 1353 SourceLocation Loc = ConsumeToken(); 1354 1355 if (Tok.is(tok::kw_volatile)) { 1356 // Remove from the end of 'asm' to the end of 'volatile'. 1357 SourceRange RemovalRange(PP.getLocForEndOfToken(Loc), 1358 PP.getLocForEndOfToken(Tok.getLocation())); 1359 1360 Diag(Tok, diag::warn_file_asm_volatile) 1361 << FixItHint::CreateRemoval(RemovalRange); 1362 ConsumeToken(); 1363 } 1364 1365 BalancedDelimiterTracker T(*this, tok::l_paren); 1366 if (T.consumeOpen()) { 1367 Diag(Tok, diag::err_expected_lparen_after) << "asm"; 1368 return ExprError(); 1369 } 1370 1371 ExprResult Result(ParseAsmStringLiteral()); 1372 1373 if (!Result.isInvalid()) { 1374 // Close the paren and get the location of the end bracket 1375 T.consumeClose(); 1376 if (EndLoc) 1377 *EndLoc = T.getCloseLocation(); 1378 } else if (SkipUntil(tok::r_paren, StopAtSemi | StopBeforeMatch)) { 1379 if (EndLoc) 1380 *EndLoc = Tok.getLocation(); 1381 ConsumeParen(); 1382 } 1383 1384 return Result; 1385 } 1386 1387 /// \brief Get the TemplateIdAnnotation from the token and put it in the 1388 /// cleanup pool so that it gets destroyed when parsing the current top level 1389 /// declaration is finished. 1390 TemplateIdAnnotation *Parser::takeTemplateIdAnnotation(const Token &tok) { 1391 assert(tok.is(tok::annot_template_id) && "Expected template-id token"); 1392 TemplateIdAnnotation * 1393 Id = static_cast<TemplateIdAnnotation *>(tok.getAnnotationValue()); 1394 return Id; 1395 } 1396 1397 void Parser::AnnotateScopeToken(CXXScopeSpec &SS, bool IsNewAnnotation) { 1398 // Push the current token back into the token stream (or revert it if it is 1399 // cached) and use an annotation scope token for current token. 1400 if (PP.isBacktrackEnabled()) 1401 PP.RevertCachedTokens(1); 1402 else 1403 PP.EnterToken(Tok); 1404 Tok.setKind(tok::annot_cxxscope); 1405 Tok.setAnnotationValue(Actions.SaveNestedNameSpecifierAnnotation(SS)); 1406 Tok.setAnnotationRange(SS.getRange()); 1407 1408 // In case the tokens were cached, have Preprocessor replace them 1409 // with the annotation token. We don't need to do this if we've 1410 // just reverted back to a prior state. 1411 if (IsNewAnnotation) 1412 PP.AnnotateCachedTokens(Tok); 1413 } 1414 1415 /// \brief Attempt to classify the name at the current token position. This may 1416 /// form a type, scope or primary expression annotation, or replace the token 1417 /// with a typo-corrected keyword. This is only appropriate when the current 1418 /// name must refer to an entity which has already been declared. 1419 /// 1420 /// \param IsAddressOfOperand Must be \c true if the name is preceded by an '&' 1421 /// and might possibly have a dependent nested name specifier. 1422 /// \param CCC Indicates how to perform typo-correction for this name. If NULL, 1423 /// no typo correction will be performed. 1424 Parser::AnnotatedNameKind 1425 Parser::TryAnnotateName(bool IsAddressOfOperand, 1426 CorrectionCandidateCallback *CCC) { 1427 assert(Tok.is(tok::identifier) || Tok.is(tok::annot_cxxscope)); 1428 1429 const bool EnteringContext = false; 1430 const bool WasScopeAnnotation = Tok.is(tok::annot_cxxscope); 1431 1432 CXXScopeSpec SS; 1433 if (getLangOpts().CPlusPlus && 1434 ParseOptionalCXXScopeSpecifier(SS, ParsedType(), EnteringContext)) 1435 return ANK_Error; 1436 1437 if (Tok.isNot(tok::identifier) || SS.isInvalid()) { 1438 if (TryAnnotateTypeOrScopeTokenAfterScopeSpec(EnteringContext, false, SS, 1439 !WasScopeAnnotation)) 1440 return ANK_Error; 1441 return ANK_Unresolved; 1442 } 1443 1444 IdentifierInfo *Name = Tok.getIdentifierInfo(); 1445 SourceLocation NameLoc = Tok.getLocation(); 1446 1447 // FIXME: Move the tentative declaration logic into ClassifyName so we can 1448 // typo-correct to tentatively-declared identifiers. 1449 if (isTentativelyDeclared(Name)) { 1450 // Identifier has been tentatively declared, and thus cannot be resolved as 1451 // an expression. Fall back to annotating it as a type. 1452 if (TryAnnotateTypeOrScopeTokenAfterScopeSpec(EnteringContext, false, SS, 1453 !WasScopeAnnotation)) 1454 return ANK_Error; 1455 return Tok.is(tok::annot_typename) ? ANK_Success : ANK_TentativeDecl; 1456 } 1457 1458 Token Next = NextToken(); 1459 1460 // Look up and classify the identifier. We don't perform any typo-correction 1461 // after a scope specifier, because in general we can't recover from typos 1462 // there (eg, after correcting 'A::tempalte B<X>::C' [sic], we would need to 1463 // jump back into scope specifier parsing). 1464 Sema::NameClassification Classification 1465 = Actions.ClassifyName(getCurScope(), SS, Name, NameLoc, Next, 1466 IsAddressOfOperand, SS.isEmpty() ? CCC : 0); 1467 1468 switch (Classification.getKind()) { 1469 case Sema::NC_Error: 1470 return ANK_Error; 1471 1472 case Sema::NC_Keyword: 1473 // The identifier was typo-corrected to a keyword. 1474 Tok.setIdentifierInfo(Name); 1475 Tok.setKind(Name->getTokenID()); 1476 PP.TypoCorrectToken(Tok); 1477 if (SS.isNotEmpty()) 1478 AnnotateScopeToken(SS, !WasScopeAnnotation); 1479 // We've "annotated" this as a keyword. 1480 return ANK_Success; 1481 1482 case Sema::NC_Unknown: 1483 // It's not something we know about. Leave it unannotated. 1484 break; 1485 1486 case Sema::NC_Type: 1487 Tok.setKind(tok::annot_typename); 1488 setTypeAnnotation(Tok, Classification.getType()); 1489 Tok.setAnnotationEndLoc(NameLoc); 1490 if (SS.isNotEmpty()) 1491 Tok.setLocation(SS.getBeginLoc()); 1492 PP.AnnotateCachedTokens(Tok); 1493 return ANK_Success; 1494 1495 case Sema::NC_Expression: 1496 Tok.setKind(tok::annot_primary_expr); 1497 setExprAnnotation(Tok, Classification.getExpression()); 1498 Tok.setAnnotationEndLoc(NameLoc); 1499 if (SS.isNotEmpty()) 1500 Tok.setLocation(SS.getBeginLoc()); 1501 PP.AnnotateCachedTokens(Tok); 1502 return ANK_Success; 1503 1504 case Sema::NC_TypeTemplate: 1505 if (Next.isNot(tok::less)) { 1506 // This may be a type template being used as a template template argument. 1507 if (SS.isNotEmpty()) 1508 AnnotateScopeToken(SS, !WasScopeAnnotation); 1509 return ANK_TemplateName; 1510 } 1511 // Fall through. 1512 case Sema::NC_VarTemplate: 1513 case Sema::NC_FunctionTemplate: { 1514 // We have a type, variable or function template followed by '<'. 1515 ConsumeToken(); 1516 UnqualifiedId Id; 1517 Id.setIdentifier(Name, NameLoc); 1518 if (AnnotateTemplateIdToken( 1519 TemplateTy::make(Classification.getTemplateName()), 1520 Classification.getTemplateNameKind(), SS, SourceLocation(), Id)) 1521 return ANK_Error; 1522 return ANK_Success; 1523 } 1524 1525 case Sema::NC_NestedNameSpecifier: 1526 llvm_unreachable("already parsed nested name specifier"); 1527 } 1528 1529 // Unable to classify the name, but maybe we can annotate a scope specifier. 1530 if (SS.isNotEmpty()) 1531 AnnotateScopeToken(SS, !WasScopeAnnotation); 1532 return ANK_Unresolved; 1533 } 1534 1535 bool Parser::TryKeywordIdentFallback(bool DisableKeyword) { 1536 assert(!Tok.is(tok::identifier) && !Tok.isAnnotation()); 1537 Diag(Tok, diag::ext_keyword_as_ident) 1538 << PP.getSpelling(Tok) 1539 << DisableKeyword; 1540 if (DisableKeyword) { 1541 IdentifierInfo *II = Tok.getIdentifierInfo(); 1542 ContextualKeywords[II] = Tok.getKind(); 1543 II->RevertTokenIDToIdentifier(); 1544 } 1545 Tok.setKind(tok::identifier); 1546 return true; 1547 } 1548 1549 bool Parser::TryIdentKeywordUpgrade() { 1550 assert(Tok.is(tok::identifier)); 1551 const IdentifierInfo *II = Tok.getIdentifierInfo(); 1552 assert(II->hasRevertedTokenIDToIdentifier()); 1553 // If we find that this is in fact the name of a type trait, 1554 // update the token kind in place and parse again to treat it as 1555 // the appropriate kind of type trait. 1556 llvm::SmallDenseMap<const IdentifierInfo *, tok::TokenKind>::iterator Known = 1557 ContextualKeywords.find(II); 1558 if (Known == ContextualKeywords.end()) 1559 return false; 1560 Tok.setKind(Known->second); 1561 return true; 1562 } 1563 1564 /// TryAnnotateTypeOrScopeToken - If the current token position is on a 1565 /// typename (possibly qualified in C++) or a C++ scope specifier not followed 1566 /// by a typename, TryAnnotateTypeOrScopeToken will replace one or more tokens 1567 /// with a single annotation token representing the typename or C++ scope 1568 /// respectively. 1569 /// This simplifies handling of C++ scope specifiers and allows efficient 1570 /// backtracking without the need to re-parse and resolve nested-names and 1571 /// typenames. 1572 /// It will mainly be called when we expect to treat identifiers as typenames 1573 /// (if they are typenames). For example, in C we do not expect identifiers 1574 /// inside expressions to be treated as typenames so it will not be called 1575 /// for expressions in C. 1576 /// The benefit for C/ObjC is that a typename will be annotated and 1577 /// Actions.getTypeName will not be needed to be called again (e.g. getTypeName 1578 /// will not be called twice, once to check whether we have a declaration 1579 /// specifier, and another one to get the actual type inside 1580 /// ParseDeclarationSpecifiers). 1581 /// 1582 /// This returns true if an error occurred. 1583 /// 1584 /// Note that this routine emits an error if you call it with ::new or ::delete 1585 /// as the current tokens, so only call it in contexts where these are invalid. 1586 bool Parser::TryAnnotateTypeOrScopeToken(bool EnteringContext, bool NeedType) { 1587 assert((Tok.is(tok::identifier) || Tok.is(tok::coloncolon) 1588 || Tok.is(tok::kw_typename) || Tok.is(tok::annot_cxxscope) 1589 || Tok.is(tok::kw_decltype) || Tok.is(tok::annot_template_id)) 1590 && "Cannot be a type or scope token!"); 1591 1592 if (Tok.is(tok::kw_typename)) { 1593 // MSVC lets you do stuff like: 1594 // typename typedef T_::D D; 1595 // 1596 // We will consume the typedef token here and put it back after we have 1597 // parsed the first identifier, transforming it into something more like: 1598 // typename T_::D typedef D; 1599 if (getLangOpts().MSVCCompat && NextToken().is(tok::kw_typedef)) { 1600 Token TypedefToken; 1601 PP.Lex(TypedefToken); 1602 bool Result = TryAnnotateTypeOrScopeToken(EnteringContext, NeedType); 1603 PP.EnterToken(Tok); 1604 Tok = TypedefToken; 1605 if (!Result) 1606 Diag(Tok.getLocation(), diag::warn_expected_qualified_after_typename); 1607 return Result; 1608 } 1609 1610 // Parse a C++ typename-specifier, e.g., "typename T::type". 1611 // 1612 // typename-specifier: 1613 // 'typename' '::' [opt] nested-name-specifier identifier 1614 // 'typename' '::' [opt] nested-name-specifier template [opt] 1615 // simple-template-id 1616 SourceLocation TypenameLoc = ConsumeToken(); 1617 CXXScopeSpec SS; 1618 if (ParseOptionalCXXScopeSpecifier(SS, /*ObjectType=*/ParsedType(), 1619 /*EnteringContext=*/false, 1620 0, /*IsTypename*/true)) 1621 return true; 1622 if (!SS.isSet()) { 1623 if (Tok.is(tok::identifier) || Tok.is(tok::annot_template_id) || 1624 Tok.is(tok::annot_decltype)) { 1625 // Attempt to recover by skipping the invalid 'typename' 1626 if (Tok.is(tok::annot_decltype) || 1627 (!TryAnnotateTypeOrScopeToken(EnteringContext, NeedType) && 1628 Tok.isAnnotation())) { 1629 unsigned DiagID = diag::err_expected_qualified_after_typename; 1630 // MS compatibility: MSVC permits using known types with typename. 1631 // e.g. "typedef typename T* pointer_type" 1632 if (getLangOpts().MicrosoftExt) 1633 DiagID = diag::warn_expected_qualified_after_typename; 1634 Diag(Tok.getLocation(), DiagID); 1635 return false; 1636 } 1637 } 1638 1639 Diag(Tok.getLocation(), diag::err_expected_qualified_after_typename); 1640 return true; 1641 } 1642 1643 TypeResult Ty; 1644 if (Tok.is(tok::identifier)) { 1645 // FIXME: check whether the next token is '<', first! 1646 Ty = Actions.ActOnTypenameType(getCurScope(), TypenameLoc, SS, 1647 *Tok.getIdentifierInfo(), 1648 Tok.getLocation()); 1649 } else if (Tok.is(tok::annot_template_id)) { 1650 TemplateIdAnnotation *TemplateId = takeTemplateIdAnnotation(Tok); 1651 if (TemplateId->Kind != TNK_Type_template && 1652 TemplateId->Kind != TNK_Dependent_template_name) { 1653 Diag(Tok, diag::err_typename_refers_to_non_type_template) 1654 << Tok.getAnnotationRange(); 1655 return true; 1656 } 1657 1658 ASTTemplateArgsPtr TemplateArgsPtr(TemplateId->getTemplateArgs(), 1659 TemplateId->NumArgs); 1660 1661 Ty = Actions.ActOnTypenameType(getCurScope(), TypenameLoc, SS, 1662 TemplateId->TemplateKWLoc, 1663 TemplateId->Template, 1664 TemplateId->TemplateNameLoc, 1665 TemplateId->LAngleLoc, 1666 TemplateArgsPtr, 1667 TemplateId->RAngleLoc); 1668 } else { 1669 Diag(Tok, diag::err_expected_type_name_after_typename) 1670 << SS.getRange(); 1671 return true; 1672 } 1673 1674 SourceLocation EndLoc = Tok.getLastLoc(); 1675 Tok.setKind(tok::annot_typename); 1676 setTypeAnnotation(Tok, Ty.isInvalid() ? ParsedType() : Ty.get()); 1677 Tok.setAnnotationEndLoc(EndLoc); 1678 Tok.setLocation(TypenameLoc); 1679 PP.AnnotateCachedTokens(Tok); 1680 return false; 1681 } 1682 1683 // Remembers whether the token was originally a scope annotation. 1684 bool WasScopeAnnotation = Tok.is(tok::annot_cxxscope); 1685 1686 CXXScopeSpec SS; 1687 if (getLangOpts().CPlusPlus) 1688 if (ParseOptionalCXXScopeSpecifier(SS, ParsedType(), EnteringContext)) 1689 return true; 1690 1691 return TryAnnotateTypeOrScopeTokenAfterScopeSpec(EnteringContext, NeedType, 1692 SS, !WasScopeAnnotation); 1693 } 1694 1695 /// \brief Try to annotate a type or scope token, having already parsed an 1696 /// optional scope specifier. \p IsNewScope should be \c true unless the scope 1697 /// specifier was extracted from an existing tok::annot_cxxscope annotation. 1698 bool Parser::TryAnnotateTypeOrScopeTokenAfterScopeSpec(bool EnteringContext, 1699 bool NeedType, 1700 CXXScopeSpec &SS, 1701 bool IsNewScope) { 1702 if (Tok.is(tok::identifier)) { 1703 IdentifierInfo *CorrectedII = 0; 1704 // Determine whether the identifier is a type name. 1705 if (ParsedType Ty = Actions.getTypeName(*Tok.getIdentifierInfo(), 1706 Tok.getLocation(), getCurScope(), 1707 &SS, false, 1708 NextToken().is(tok::period), 1709 ParsedType(), 1710 /*IsCtorOrDtorName=*/false, 1711 /*NonTrivialTypeSourceInfo*/true, 1712 NeedType ? &CorrectedII : NULL)) { 1713 // A FixIt was applied as a result of typo correction 1714 if (CorrectedII) 1715 Tok.setIdentifierInfo(CorrectedII); 1716 // This is a typename. Replace the current token in-place with an 1717 // annotation type token. 1718 Tok.setKind(tok::annot_typename); 1719 setTypeAnnotation(Tok, Ty); 1720 Tok.setAnnotationEndLoc(Tok.getLocation()); 1721 if (SS.isNotEmpty()) // it was a C++ qualified type name. 1722 Tok.setLocation(SS.getBeginLoc()); 1723 1724 // In case the tokens were cached, have Preprocessor replace 1725 // them with the annotation token. 1726 PP.AnnotateCachedTokens(Tok); 1727 return false; 1728 } 1729 1730 if (!getLangOpts().CPlusPlus) { 1731 // If we're in C, we can't have :: tokens at all (the lexer won't return 1732 // them). If the identifier is not a type, then it can't be scope either, 1733 // just early exit. 1734 return false; 1735 } 1736 1737 // If this is a template-id, annotate with a template-id or type token. 1738 if (NextToken().is(tok::less)) { 1739 TemplateTy Template; 1740 UnqualifiedId TemplateName; 1741 TemplateName.setIdentifier(Tok.getIdentifierInfo(), Tok.getLocation()); 1742 bool MemberOfUnknownSpecialization; 1743 if (TemplateNameKind TNK 1744 = Actions.isTemplateName(getCurScope(), SS, 1745 /*hasTemplateKeyword=*/false, TemplateName, 1746 /*ObjectType=*/ ParsedType(), 1747 EnteringContext, 1748 Template, MemberOfUnknownSpecialization)) { 1749 // Consume the identifier. 1750 ConsumeToken(); 1751 if (AnnotateTemplateIdToken(Template, TNK, SS, SourceLocation(), 1752 TemplateName)) { 1753 // If an unrecoverable error occurred, we need to return true here, 1754 // because the token stream is in a damaged state. We may not return 1755 // a valid identifier. 1756 return true; 1757 } 1758 } 1759 } 1760 1761 // The current token, which is either an identifier or a 1762 // template-id, is not part of the annotation. Fall through to 1763 // push that token back into the stream and complete the C++ scope 1764 // specifier annotation. 1765 } 1766 1767 if (Tok.is(tok::annot_template_id)) { 1768 TemplateIdAnnotation *TemplateId = takeTemplateIdAnnotation(Tok); 1769 if (TemplateId->Kind == TNK_Type_template) { 1770 // A template-id that refers to a type was parsed into a 1771 // template-id annotation in a context where we weren't allowed 1772 // to produce a type annotation token. Update the template-id 1773 // annotation token to a type annotation token now. 1774 AnnotateTemplateIdTokenAsType(); 1775 return false; 1776 } 1777 } 1778 1779 if (SS.isEmpty()) 1780 return false; 1781 1782 // A C++ scope specifier that isn't followed by a typename. 1783 AnnotateScopeToken(SS, IsNewScope); 1784 return false; 1785 } 1786 1787 /// TryAnnotateScopeToken - Like TryAnnotateTypeOrScopeToken but only 1788 /// annotates C++ scope specifiers and template-ids. This returns 1789 /// true if there was an error that could not be recovered from. 1790 /// 1791 /// Note that this routine emits an error if you call it with ::new or ::delete 1792 /// as the current tokens, so only call it in contexts where these are invalid. 1793 bool Parser::TryAnnotateCXXScopeToken(bool EnteringContext) { 1794 assert(getLangOpts().CPlusPlus && 1795 "Call sites of this function should be guarded by checking for C++"); 1796 assert((Tok.is(tok::identifier) || Tok.is(tok::coloncolon) || 1797 (Tok.is(tok::annot_template_id) && NextToken().is(tok::coloncolon)) || 1798 Tok.is(tok::kw_decltype)) && "Cannot be a type or scope token!"); 1799 1800 CXXScopeSpec SS; 1801 if (ParseOptionalCXXScopeSpecifier(SS, ParsedType(), EnteringContext)) 1802 return true; 1803 if (SS.isEmpty()) 1804 return false; 1805 1806 AnnotateScopeToken(SS, true); 1807 return false; 1808 } 1809 1810 bool Parser::isTokenEqualOrEqualTypo() { 1811 tok::TokenKind Kind = Tok.getKind(); 1812 switch (Kind) { 1813 default: 1814 return false; 1815 case tok::ampequal: // &= 1816 case tok::starequal: // *= 1817 case tok::plusequal: // += 1818 case tok::minusequal: // -= 1819 case tok::exclaimequal: // != 1820 case tok::slashequal: // /= 1821 case tok::percentequal: // %= 1822 case tok::lessequal: // <= 1823 case tok::lesslessequal: // <<= 1824 case tok::greaterequal: // >= 1825 case tok::greatergreaterequal: // >>= 1826 case tok::caretequal: // ^= 1827 case tok::pipeequal: // |= 1828 case tok::equalequal: // == 1829 Diag(Tok, diag::err_invalid_token_after_declarator_suggest_equal) 1830 << Kind 1831 << FixItHint::CreateReplacement(SourceRange(Tok.getLocation()), "="); 1832 case tok::equal: 1833 return true; 1834 } 1835 } 1836 1837 SourceLocation Parser::handleUnexpectedCodeCompletionToken() { 1838 assert(Tok.is(tok::code_completion)); 1839 PrevTokLocation = Tok.getLocation(); 1840 1841 for (Scope *S = getCurScope(); S; S = S->getParent()) { 1842 if (S->getFlags() & Scope::FnScope) { 1843 Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_RecoveryInFunction); 1844 cutOffParsing(); 1845 return PrevTokLocation; 1846 } 1847 1848 if (S->getFlags() & Scope::ClassScope) { 1849 Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_Class); 1850 cutOffParsing(); 1851 return PrevTokLocation; 1852 } 1853 } 1854 1855 Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_Namespace); 1856 cutOffParsing(); 1857 return PrevTokLocation; 1858 } 1859 1860 // Anchor the Parser::FieldCallback vtable to this translation unit. 1861 // We use a spurious method instead of the destructor because 1862 // destroying FieldCallbacks can actually be slightly 1863 // performance-sensitive. 1864 void Parser::FieldCallback::_anchor() { 1865 } 1866 1867 // Code-completion pass-through functions 1868 1869 void Parser::CodeCompleteDirective(bool InConditional) { 1870 Actions.CodeCompletePreprocessorDirective(InConditional); 1871 } 1872 1873 void Parser::CodeCompleteInConditionalExclusion() { 1874 Actions.CodeCompleteInPreprocessorConditionalExclusion(getCurScope()); 1875 } 1876 1877 void Parser::CodeCompleteMacroName(bool IsDefinition) { 1878 Actions.CodeCompletePreprocessorMacroName(IsDefinition); 1879 } 1880 1881 void Parser::CodeCompletePreprocessorExpression() { 1882 Actions.CodeCompletePreprocessorExpression(); 1883 } 1884 1885 void Parser::CodeCompleteMacroArgument(IdentifierInfo *Macro, 1886 MacroInfo *MacroInfo, 1887 unsigned ArgumentIndex) { 1888 Actions.CodeCompletePreprocessorMacroArgument(getCurScope(), Macro, MacroInfo, 1889 ArgumentIndex); 1890 } 1891 1892 void Parser::CodeCompleteNaturalLanguage() { 1893 Actions.CodeCompleteNaturalLanguage(); 1894 } 1895 1896 bool Parser::ParseMicrosoftIfExistsCondition(IfExistsCondition& Result) { 1897 assert((Tok.is(tok::kw___if_exists) || Tok.is(tok::kw___if_not_exists)) && 1898 "Expected '__if_exists' or '__if_not_exists'"); 1899 Result.IsIfExists = Tok.is(tok::kw___if_exists); 1900 Result.KeywordLoc = ConsumeToken(); 1901 1902 BalancedDelimiterTracker T(*this, tok::l_paren); 1903 if (T.consumeOpen()) { 1904 Diag(Tok, diag::err_expected_lparen_after) 1905 << (Result.IsIfExists? "__if_exists" : "__if_not_exists"); 1906 return true; 1907 } 1908 1909 // Parse nested-name-specifier. 1910 ParseOptionalCXXScopeSpecifier(Result.SS, ParsedType(), 1911 /*EnteringContext=*/false); 1912 1913 // Check nested-name specifier. 1914 if (Result.SS.isInvalid()) { 1915 T.skipToEnd(); 1916 return true; 1917 } 1918 1919 // Parse the unqualified-id. 1920 SourceLocation TemplateKWLoc; // FIXME: parsed, but unused. 1921 if (ParseUnqualifiedId(Result.SS, false, true, true, ParsedType(), 1922 TemplateKWLoc, Result.Name)) { 1923 T.skipToEnd(); 1924 return true; 1925 } 1926 1927 if (T.consumeClose()) 1928 return true; 1929 1930 // Check if the symbol exists. 1931 switch (Actions.CheckMicrosoftIfExistsSymbol(getCurScope(), Result.KeywordLoc, 1932 Result.IsIfExists, Result.SS, 1933 Result.Name)) { 1934 case Sema::IER_Exists: 1935 Result.Behavior = Result.IsIfExists ? IEB_Parse : IEB_Skip; 1936 break; 1937 1938 case Sema::IER_DoesNotExist: 1939 Result.Behavior = !Result.IsIfExists ? IEB_Parse : IEB_Skip; 1940 break; 1941 1942 case Sema::IER_Dependent: 1943 Result.Behavior = IEB_Dependent; 1944 break; 1945 1946 case Sema::IER_Error: 1947 return true; 1948 } 1949 1950 return false; 1951 } 1952 1953 void Parser::ParseMicrosoftIfExistsExternalDeclaration() { 1954 IfExistsCondition Result; 1955 if (ParseMicrosoftIfExistsCondition(Result)) 1956 return; 1957 1958 BalancedDelimiterTracker Braces(*this, tok::l_brace); 1959 if (Braces.consumeOpen()) { 1960 Diag(Tok, diag::err_expected) << tok::l_brace; 1961 return; 1962 } 1963 1964 switch (Result.Behavior) { 1965 case IEB_Parse: 1966 // Parse declarations below. 1967 break; 1968 1969 case IEB_Dependent: 1970 llvm_unreachable("Cannot have a dependent external declaration"); 1971 1972 case IEB_Skip: 1973 Braces.skipToEnd(); 1974 return; 1975 } 1976 1977 // Parse the declarations. 1978 // FIXME: Support module import within __if_exists? 1979 while (Tok.isNot(tok::r_brace) && !isEofOrEom()) { 1980 ParsedAttributesWithRange attrs(AttrFactory); 1981 MaybeParseCXX11Attributes(attrs); 1982 MaybeParseMicrosoftAttributes(attrs); 1983 DeclGroupPtrTy Result = ParseExternalDeclaration(attrs); 1984 if (Result && !getCurScope()->getParent()) 1985 Actions.getASTConsumer().HandleTopLevelDecl(Result.get()); 1986 } 1987 Braces.consumeClose(); 1988 } 1989 1990 Parser::DeclGroupPtrTy Parser::ParseModuleImport(SourceLocation AtLoc) { 1991 assert(Tok.isObjCAtKeyword(tok::objc_import) && 1992 "Improper start to module import"); 1993 SourceLocation ImportLoc = ConsumeToken(); 1994 1995 SmallVector<std::pair<IdentifierInfo *, SourceLocation>, 2> Path; 1996 1997 // Parse the module path. 1998 do { 1999 if (!Tok.is(tok::identifier)) { 2000 if (Tok.is(tok::code_completion)) { 2001 Actions.CodeCompleteModuleImport(ImportLoc, Path); 2002 ConsumeCodeCompletionToken(); 2003 SkipUntil(tok::semi); 2004 return DeclGroupPtrTy(); 2005 } 2006 2007 Diag(Tok, diag::err_module_expected_ident); 2008 SkipUntil(tok::semi); 2009 return DeclGroupPtrTy(); 2010 } 2011 2012 // Record this part of the module path. 2013 Path.push_back(std::make_pair(Tok.getIdentifierInfo(), Tok.getLocation())); 2014 ConsumeToken(); 2015 2016 if (Tok.is(tok::period)) { 2017 ConsumeToken(); 2018 continue; 2019 } 2020 2021 break; 2022 } while (true); 2023 2024 if (PP.hadModuleLoaderFatalFailure()) { 2025 // With a fatal failure in the module loader, we abort parsing. 2026 cutOffParsing(); 2027 return DeclGroupPtrTy(); 2028 } 2029 2030 DeclResult Import = Actions.ActOnModuleImport(AtLoc, ImportLoc, Path); 2031 ExpectAndConsumeSemi(diag::err_module_expected_semi); 2032 if (Import.isInvalid()) 2033 return DeclGroupPtrTy(); 2034 2035 return Actions.ConvertDeclToDeclGroup(Import.get()); 2036 } 2037 2038 bool BalancedDelimiterTracker::diagnoseOverflow() { 2039 P.Diag(P.Tok, diag::err_bracket_depth_exceeded) 2040 << P.getLangOpts().BracketDepth; 2041 P.Diag(P.Tok, diag::note_bracket_depth); 2042 P.cutOffParsing(); 2043 return true; 2044 } 2045 2046 bool BalancedDelimiterTracker::expectAndConsume(unsigned DiagID, 2047 const char *Msg, 2048 tok::TokenKind SkipToTok) { 2049 LOpen = P.Tok.getLocation(); 2050 if (P.ExpectAndConsume(Kind, DiagID, Msg)) { 2051 if (SkipToTok != tok::unknown) 2052 P.SkipUntil(SkipToTok, Parser::StopAtSemi); 2053 return true; 2054 } 2055 2056 if (getDepth() < MaxDepth) 2057 return false; 2058 2059 return diagnoseOverflow(); 2060 } 2061 2062 bool BalancedDelimiterTracker::diagnoseMissingClose() { 2063 assert(!P.Tok.is(Close) && "Should have consumed closing delimiter"); 2064 2065 P.Diag(P.Tok, diag::err_expected) << Close; 2066 P.Diag(LOpen, diag::note_matching) << Kind; 2067 2068 // If we're not already at some kind of closing bracket, skip to our closing 2069 // token. 2070 if (P.Tok.isNot(tok::r_paren) && P.Tok.isNot(tok::r_brace) && 2071 P.Tok.isNot(tok::r_square) && 2072 P.SkipUntil(Close, FinalToken, 2073 Parser::StopAtSemi | Parser::StopBeforeMatch) && 2074 P.Tok.is(Close)) 2075 LClose = P.ConsumeAnyToken(); 2076 return true; 2077 } 2078 2079 void BalancedDelimiterTracker::skipToEnd() { 2080 P.SkipUntil(Close, Parser::StopBeforeMatch); 2081 consumeClose(); 2082 } 2083