Parser.cpp revision 3d3589db579f7695667b913c5043dd264ebe546f
15f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===--- Parser.cpp - C Language Family Parser ----------------------------===//
25f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
35f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//                     The LLVM Compiler Infrastructure
45f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
50bc735ffcfb223c0186419547abaa5c84482663eChris Lattner// This file is distributed under the University of Illinois Open Source
60bc735ffcfb223c0186419547abaa5c84482663eChris Lattner// License. See LICENSE.TXT for details.
75f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
85f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
95f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//  This file implements the Parser interfaces.
115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//
125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
145f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer#include "clang/Parse/Parser.h"
15500d3297d2a21edeac4d46cbcbe21bc2352c2a28Chris Lattner#include "clang/Parse/ParseDiagnostic.h"
1619510856727e0e14a3696b2a72c35163bff2a71fJohn McCall#include "clang/Sema/DeclSpec.h"
1719510856727e0e14a3696b2a72c35163bff2a71fJohn McCall#include "clang/Sema/Scope.h"
1819510856727e0e14a3696b2a72c35163bff2a71fJohn McCall#include "clang/Sema/ParsedTemplate.h"
190102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner#include "llvm/Support/raw_ostream.h"
20d167ca0d26e43292b8b9e8d5300d92784ae0e27dChris Lattner#include "RAIIObjectsForParser.h"
21fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar#include "ParsePragma.h"
228387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet#include "clang/AST/DeclTemplate.h"
23f986038beed360c031de8654cfba43a5d3184605Francois Pichet#include "clang/AST/ASTConsumer.h"
245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerusing namespace clang;
255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
26b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas GregorIdentifierInfo *Parser::getSEHExceptKeyword() {
27b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor  // __except is accepted as a (contextual) keyword
28b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor  if (!Ident__except && (getLang().MicrosoftExt || getLang().Borland))
29b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor    Ident__except = PP.getIdentifierInfo("__except");
30b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor
31b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor  return Ident__except;
32b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor}
33b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor
34f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCallParser::Parser(Preprocessor &pp, Sema &actions)
35614f96a7cf94805c2d336639300b62dc2f54e9e0Ted Kremenek  : PP(pp), Actions(actions), Diags(PP.getDiagnostics()),
360fbda68b50ce17d7ad36ef7a5ed77518a5cd272eDouglas Gregor    GreaterThanIsOperator(true), ColonIsSacred(false),
370fbda68b50ce17d7ad36ef7a5ed77518a5cd272eDouglas Gregor    InMessageExpression(false), TemplateParameterDepth(0) {
385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  Tok.setKind(tok::eof);
3923c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  Actions.CurScope = 0;
409e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner  NumCachedScopes = 0;
415f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  ParenCount = BracketCount = BraceCount = 0;
42d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall  ObjCImpDecl = 0;
43fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar
44fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar  // Add #pragma handlers. These are removed and destroyed in the
45fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar  // destructor.
46cbb98edd530787c2ac019e437e7c599df8004ba7Daniel Dunbar  AlignHandler.reset(new PragmaAlignHandler(actions));
47cbb98edd530787c2ac019e437e7c599df8004ba7Daniel Dunbar  PP.AddPragmaHandler(AlignHandler.get());
48cbb98edd530787c2ac019e437e7c599df8004ba7Daniel Dunbar
49aa8b0d19244a6e7e8e5798fcc6aef003c274d3e0Eli Friedman  GCCVisibilityHandler.reset(new PragmaGCCVisibilityHandler(actions));
50aa8b0d19244a6e7e8e5798fcc6aef003c274d3e0Eli Friedman  PP.AddPragmaHandler("GCC", GCCVisibilityHandler.get());
51aa8b0d19244a6e7e8e5798fcc6aef003c274d3e0Eli Friedman
529b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  OptionsHandler.reset(new PragmaOptionsHandler(actions));
539b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.AddPragmaHandler(OptionsHandler.get());
549b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis
559b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PackHandler.reset(new PragmaPackHandler(actions));
569b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.AddPragmaHandler(PackHandler.get());
5762c9258f4a71569a66d805fc7776526a2c76b34eFariborz Jahanian
5862c9258f4a71569a66d805fc7776526a2c76b34eFariborz Jahanian  MSStructHandler.reset(new PragmaMSStructHandler(actions));
5962c9258f4a71569a66d805fc7776526a2c76b34eFariborz Jahanian  PP.AddPragmaHandler(MSStructHandler.get());
609b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis
619b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  UnusedHandler.reset(new PragmaUnusedHandler(actions, *this));
629b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.AddPragmaHandler(UnusedHandler.get());
639b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis
649b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  WeakHandler.reset(new PragmaWeakHandler(actions));
659b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.AddPragmaHandler(WeakHandler.get());
66321b8179afaf803dcc56b2a19f7b0891a03c92c8Peter Collingbourne
67321b8179afaf803dcc56b2a19f7b0891a03c92c8Peter Collingbourne  FPContractHandler.reset(new PragmaFPContractHandler(actions, *this));
68321b8179afaf803dcc56b2a19f7b0891a03c92c8Peter Collingbourne  PP.AddPragmaHandler("STDC", FPContractHandler.get());
69f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne
70f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne  if (getLang().OpenCL) {
71f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    OpenCLExtensionHandler.reset(
72f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne                  new PragmaOpenCLExtensionHandler(actions, *this));
73f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    PP.AddPragmaHandler("OPENCL", OpenCLExtensionHandler.get());
74f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne
75f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    PP.AddPragmaHandler("OPENCL", FPContractHandler.get());
76f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne  }
77f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor
78f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor  PP.setCodeCompletionHandler(*this);
795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
810102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner/// If a crash happens while the parser is active, print out a line indicating
820102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner/// what the current token is.
835f9e272e632e951b1efe824cd16acb4d96077930Chris Lattnervoid PrettyStackTraceParserEntry::print(raw_ostream &OS) const {
840102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner  const Token &Tok = P.getCurToken();
85ddcbc0a72a04a5ae2493088f1437200a9ea480b1Chris Lattner  if (Tok.is(tok::eof)) {
860102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner    OS << "<eof> parser at end of file\n";
870102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner    return;
880102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner  }
891eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
90ddcbc0a72a04a5ae2493088f1437200a9ea480b1Chris Lattner  if (Tok.getLocation().isInvalid()) {
91ddcbc0a72a04a5ae2493088f1437200a9ea480b1Chris Lattner    OS << "<unknown> parser at unknown location\n";
92ddcbc0a72a04a5ae2493088f1437200a9ea480b1Chris Lattner    return;
93ddcbc0a72a04a5ae2493088f1437200a9ea480b1Chris Lattner  }
941eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
950102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner  const Preprocessor &PP = P.getPreprocessor();
960102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner  Tok.getLocation().print(OS, PP.getSourceManager());
979fa31dd71e0414e2ca905380e2f8d42710b22c82Daniel Dunbar  if (Tok.isAnnotation())
989fa31dd71e0414e2ca905380e2f8d42710b22c82Daniel Dunbar    OS << ": at annotation token \n";
999fa31dd71e0414e2ca905380e2f8d42710b22c82Daniel Dunbar  else
1009fa31dd71e0414e2ca905380e2f8d42710b22c82Daniel Dunbar    OS << ": current parser token '" << PP.getSpelling(Tok) << "'\n";
101f780abc21c39cd4731b9e38f2d2d9f7d1510bd7bDouglas Gregor}
1025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1030102c30896c83f70cf6b6519fd5c674cb981c0b5Chris Lattner
1043cbfe2c4159e0a219ae660d50625c013aa4afbd0Chris LattnerDiagnosticBuilder Parser::Diag(SourceLocation Loc, unsigned DiagID) {
10533e4e70c8c0a17e0ccb7465d96556b077a68ecb1Argyrios Kyrtzidis  return Diags.Report(Loc, DiagID);
1061ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner}
1071ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner
1083cbfe2c4159e0a219ae660d50625c013aa4afbd0Chris LattnerDiagnosticBuilder Parser::Diag(const Token &Tok, unsigned DiagID) {
1091ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner  return Diag(Tok.getLocation(), DiagID);
1105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
1115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1124b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor/// \brief Emits a diagnostic suggesting parentheses surrounding a
1134b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor/// given range.
1144b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor///
1154b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor/// \param Loc The location where we'll emit the diagnostic.
1164b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor/// \param Loc The kind of diagnostic to emit.
1174b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor/// \param ParenRange Source range enclosing code that should be parenthesized.
1184b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregorvoid Parser::SuggestParentheses(SourceLocation Loc, unsigned DK,
1194b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor                                SourceRange ParenRange) {
120b2fb6de9070fea9abc56c8e8d5469066e964cefeDouglas Gregor  SourceLocation EndLoc = PP.getLocForEndOfToken(ParenRange.getEnd());
121b2fb6de9070fea9abc56c8e8d5469066e964cefeDouglas Gregor  if (!ParenRange.getEnd().isFileID() || EndLoc.isInvalid()) {
1224b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    // We can't display the parentheses, so just dig the
1234b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    // warning/error and return.
1244b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    Diag(Loc, DK);
1254b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    return;
1264b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor  }
1271eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1281eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  Diag(Loc, DK)
129849b243d4065f56742a4677d6dc8277609a151f8Douglas Gregor    << FixItHint::CreateInsertion(ParenRange.getBegin(), "(")
130849b243d4065f56742a4677d6dc8277609a151f8Douglas Gregor    << FixItHint::CreateInsertion(EndLoc, ")");
1314b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor}
1324b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor
133837b1a37116cf4e64f8bb7db34982dee1fba7647John McCallstatic bool IsCommonTypo(tok::TokenKind ExpectedTok, const Token &Tok) {
134837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  switch (ExpectedTok) {
135837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  case tok::semi: return Tok.is(tok::colon); // : for ;
136837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  default: return false;
137837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  }
138837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall}
139837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall
1405f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ExpectAndConsume - The parser expects that 'ExpectedTok' is next in the
1415f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// input.  If so, it is consumed and false is returned.
1425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
1435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// If the input is malformed, this emits the specified diagnostic.  Next, if
1445f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// SkipToTok is specified, it calls SkipUntil(SkipToTok).  Finally, true is
1455f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// returned.
1465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerbool Parser::ExpectAndConsume(tok::TokenKind ExpectedTok, unsigned DiagID,
1475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer                              const char *Msg, tok::TokenKind SkipToTok) {
148dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor  if (Tok.is(ExpectedTok) || Tok.is(tok::code_completion)) {
1495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ConsumeAnyToken();
1505f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    return false;
1515f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
152a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
153837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  // Detect common single-character typos and resume.
154837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  if (IsCommonTypo(ExpectedTok, Tok)) {
155837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall    SourceLocation Loc = Tok.getLocation();
156837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall    Diag(Loc, DiagID)
157837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall      << Msg
158837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall      << FixItHint::CreateReplacement(SourceRange(Loc),
159837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall                                      getTokenSimpleSpelling(ExpectedTok));
160837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall    ConsumeAnyToken();
161837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall
162837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall    // Pretend there wasn't a problem.
163837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall    return false;
164837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall  }
165837b1a37116cf4e64f8bb7db34982dee1fba7647John McCall
1664b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor  const char *Spelling = 0;
167b2fb6de9070fea9abc56c8e8d5469066e964cefeDouglas Gregor  SourceLocation EndLoc = PP.getLocForEndOfToken(PrevTokLocation);
1681eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  if (EndLoc.isValid() &&
169b2fb6de9070fea9abc56c8e8d5469066e964cefeDouglas Gregor      (Spelling = tok::getTokenSimpleSpelling(ExpectedTok))) {
1704b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    // Show what code to insert to fix this problem.
1711eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    Diag(EndLoc, DiagID)
1724b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor      << Msg
173849b243d4065f56742a4677d6dc8277609a151f8Douglas Gregor      << FixItHint::CreateInsertion(EndLoc, Spelling);
1744b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor  } else
1754b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor    Diag(Tok, DiagID) << Msg;
1764b2d3f7bcc4df31157df443af1b80bcaa9b58bbaDouglas Gregor
1775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  if (SkipToTok != tok::unknown)
1785f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    SkipUntil(SkipToTok);
1795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  return true;
1805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
1815f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
1829ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregorbool Parser::ExpectAndConsumeSemi(unsigned DiagID) {
1839ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor  if (Tok.is(tok::semi) || Tok.is(tok::code_completion)) {
1849ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    ConsumeAnyToken();
1859ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    return false;
1869ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor  }
1879ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor
1889ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor  if ((Tok.is(tok::r_paren) || Tok.is(tok::r_square)) &&
1899ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor      NextToken().is(tok::semi)) {
1909ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    Diag(Tok, diag::err_extraneous_token_before_semi)
1919ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor      << PP.getSpelling(Tok)
1929ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor      << FixItHint::CreateRemoval(Tok.getLocation());
1939ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    ConsumeAnyToken(); // The ')' or ']'.
1949ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    ConsumeToken(); // The ';'.
1959ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor    return false;
1969ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor  }
1979ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor
1989ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor  return ExpectAndConsume(tok::semi, DiagID);
1999ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor}
2009ba23b4ceacd77cd264501690a7a9e94184ef71bDouglas Gregor
2015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
2025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer// Error recovery.
2035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
2045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
2055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// SkipUntil - Read tokens until we get to the specified token, then consume
206012cf464254804279efa84e21b4b493dde76c5f1Chris Lattner/// it (unless DontConsume is true).  Because we cannot guarantee that the
2075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// token will ever occur, this skips to the next token, or to some likely
2085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// good stopping point.  If StopAtSemi is true, skipping will stop at a ';'
2095f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// character.
210a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump///
2115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// If SkipUntil finds the specified token, it returns true, otherwise it
212a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump/// returns false.
2135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencerbool Parser::SkipUntil(const tok::TokenKind *Toks, unsigned NumToks,
2143437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis                       bool StopAtSemi, bool DontConsume,
2153437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis                       bool StopAtCodeCompletion) {
2165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // We always want this function to skip at least one token if the first token
2175f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // isn't T and if not at EOF.
2185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  bool isFirstTokenSkipped = true;
2195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  while (1) {
2205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // If we found one of the tokens, stop and return true.
2215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    for (unsigned i = 0; i != NumToks; ++i) {
222000732226610650837478cba97843d19b75f648eChris Lattner      if (Tok.is(Toks[i])) {
2235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        if (DontConsume) {
2245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          // Noop, don't consume the token.
2255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        } else {
2265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          ConsumeAnyToken();
2275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        }
2285f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        return true;
2295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      }
2305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
231a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
2325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    switch (Tok.getKind()) {
2335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::eof:
2345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Ran out of tokens.
2355f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      return false;
236dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor
237dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor    case tok::code_completion:
2383437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis      if (!StopAtCodeCompletion)
2393437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis        ConsumeToken();
240dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor      return false;
241dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor
2425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::l_paren:
2435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Recursively skip properly-nested parens.
2445f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeParen();
2453437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis      SkipUntil(tok::r_paren, false, false, StopAtCodeCompletion);
2465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
2475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::l_square:
2485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Recursively skip properly-nested square brackets.
2495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeBracket();
2503437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis      SkipUntil(tok::r_square, false, false, StopAtCodeCompletion);
2515f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
2525f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::l_brace:
2535f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Recursively skip properly-nested braces.
2545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeBrace();
2553437f1f1294499d4ef306c1089fcb3e29ec2aa68Argyrios Kyrtzidis      SkipUntil(tok::r_brace, false, false, StopAtCodeCompletion);
2565f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
257a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
2585f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Okay, we found a ']' or '}' or ')', which we think should be balanced.
2595f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Since the user wasn't looking for this token (if they were, it would
2605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // already be handled), this isn't balanced.  If there is a LHS token at a
2615f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // higher level, we will assume that this matches the unbalanced token
2625f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // and return it.  Otherwise, this is a spurious RHS token, which we skip.
2635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::r_paren:
2645f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      if (ParenCount && !isFirstTokenSkipped)
2655f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        return false;  // Matches something.
2665f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeParen();
2675f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
2685f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::r_square:
2695f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      if (BracketCount && !isFirstTokenSkipped)
2705f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        return false;  // Matches something.
2715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeBracket();
2725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
2735f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::r_brace:
2745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      if (BraceCount && !isFirstTokenSkipped)
2755f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        return false;  // Matches something.
2765f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeBrace();
2775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
278a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
2795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::string_literal:
2805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::wide_string_literal:
2815cee1195584fa8672253139c86e922daeda69b9eDouglas Gregor    case tok::utf8_string_literal:
2825cee1195584fa8672253139c86e922daeda69b9eDouglas Gregor    case tok::utf16_string_literal:
2835cee1195584fa8672253139c86e922daeda69b9eDouglas Gregor    case tok::utf32_string_literal:
2845f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeStringToken();
2855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
28655edca9d7d6a50cbda6f036b05a0cb8d42f5a010Fariborz Jahanian
28755edca9d7d6a50cbda6f036b05a0cb8d42f5a010Fariborz Jahanian    case tok::at:
28855edca9d7d6a50cbda6f036b05a0cb8d42f5a010Fariborz Jahanian      return false;
28955edca9d7d6a50cbda6f036b05a0cb8d42f5a010Fariborz Jahanian
2905f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    case tok::semi:
2915f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      if (StopAtSemi)
2925f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        return false;
2935f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // FALL THROUGH.
2945f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    default:
2955f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Skip this token.
2965f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeToken();
2975f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      break;
2985f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
2995f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    isFirstTokenSkipped = false;
300a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump  }
3015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
3025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
3045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer// Scope manipulation
3055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
3065f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// EnterScope - Start a new scope.
3085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencervoid Parser::EnterScope(unsigned ScopeFlags) {
3099e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner  if (NumCachedScopes) {
3109e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner    Scope *N = ScopeCache[--NumCachedScopes];
31123c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor    N->Init(getCurScope(), ScopeFlags);
31223c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor    Actions.CurScope = N;
3135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  } else {
3149c4eb1f3438370355f51dc8c62f2ca4803e3338dArgyrios Kyrtzidis    Actions.CurScope = new Scope(getCurScope(), ScopeFlags, Diags);
3155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
3165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
3175f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ExitScope - Pop a scope off the scope stack.
3195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencervoid Parser::ExitScope() {
32023c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  assert(getCurScope() && "Scope imbalance!");
3215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
32290ae68aae98f12fe1950c63e2f6bd0fabce6cb1eChris Lattner  // Inform the actions module that this scope is going away if there are any
32390ae68aae98f12fe1950c63e2f6bd0fabce6cb1eChris Lattner  // decls in it.
32423c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  if (!getCurScope()->decl_empty())
32523c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor    Actions.ActOnPopScope(Tok.getLocation(), getCurScope());
326a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
32723c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  Scope *OldScope = getCurScope();
32823c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  Actions.CurScope = OldScope->getParent();
329a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
3309e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner  if (NumCachedScopes == ScopeCacheSize)
3319e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner    delete OldScope;
3325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  else
3339e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner    ScopeCache[NumCachedScopes++] = OldScope;
3345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
3355f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3367a614d8380297fcd2bc23986241905d97222948cRichard Smith/// Set the flags for the current scope to ScopeFlags. If ManageFlags is false,
3377a614d8380297fcd2bc23986241905d97222948cRichard Smith/// this object does nothing.
3387a614d8380297fcd2bc23986241905d97222948cRichard SmithParser::ParseScopeFlags::ParseScopeFlags(Parser *Self, unsigned ScopeFlags,
3397a614d8380297fcd2bc23986241905d97222948cRichard Smith                                 bool ManageFlags)
3407a614d8380297fcd2bc23986241905d97222948cRichard Smith  : CurScope(ManageFlags ? Self->getCurScope() : 0) {
3417a614d8380297fcd2bc23986241905d97222948cRichard Smith  if (CurScope) {
3427a614d8380297fcd2bc23986241905d97222948cRichard Smith    OldFlags = CurScope->getFlags();
3437a614d8380297fcd2bc23986241905d97222948cRichard Smith    CurScope->setFlags(ScopeFlags);
3447a614d8380297fcd2bc23986241905d97222948cRichard Smith  }
3457a614d8380297fcd2bc23986241905d97222948cRichard Smith}
3465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3477a614d8380297fcd2bc23986241905d97222948cRichard Smith/// Restore the flags for the current scope to what they were before this
3487a614d8380297fcd2bc23986241905d97222948cRichard Smith/// object overrode them.
3497a614d8380297fcd2bc23986241905d97222948cRichard SmithParser::ParseScopeFlags::~ParseScopeFlags() {
3507a614d8380297fcd2bc23986241905d97222948cRichard Smith  if (CurScope)
3517a614d8380297fcd2bc23986241905d97222948cRichard Smith    CurScope->setFlags(OldFlags);
3527a614d8380297fcd2bc23986241905d97222948cRichard Smith}
3535f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3555f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
3565f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer// C99 6.9: External Definitions.
3575f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer//===----------------------------------------------------------------------===//
3585f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
3595f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid SpencerParser::~Parser() {
3605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // If we still have scopes active, delete the scope tree.
36123c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  delete getCurScope();
36223c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  Actions.CurScope = 0;
36323c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor
3645f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // Free the scope cache.
3659e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner  for (unsigned i = 0, e = NumCachedScopes; i != e; ++i)
3669e344c65b1e8b83e1d3ada507cf653526ff2c005Chris Lattner    delete ScopeCache[i];
367fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar
3688387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  // Free LateParsedTemplatedFunction nodes.
3698387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  for (LateParsedTemplateMapT::iterator it = LateParsedTemplateMap.begin();
3708387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      it != LateParsedTemplateMap.end(); ++it)
3718387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    delete it->second;
3728387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
3732fea2242fe7e7c37df1e96316616febeaf4e29ebArgyrios Kyrtzidis  clearLateParsedObjCMethods();
3742fea2242fe7e7c37df1e96316616febeaf4e29ebArgyrios Kyrtzidis
375fcdd8fe26de3eee44927600bf1853e21bd90dd84Daniel Dunbar  // Remove the pragma handlers we installed.
376cbb98edd530787c2ac019e437e7c599df8004ba7Daniel Dunbar  PP.RemovePragmaHandler(AlignHandler.get());
377cbb98edd530787c2ac019e437e7c599df8004ba7Daniel Dunbar  AlignHandler.reset();
378aa8b0d19244a6e7e8e5798fcc6aef003c274d3e0Eli Friedman  PP.RemovePragmaHandler("GCC", GCCVisibilityHandler.get());
379aa8b0d19244a6e7e8e5798fcc6aef003c274d3e0Eli Friedman  GCCVisibilityHandler.reset();
3809b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.RemovePragmaHandler(OptionsHandler.get());
381861800c676004eabed5927f0552620d06c80a40aDaniel Dunbar  OptionsHandler.reset();
3829b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.RemovePragmaHandler(PackHandler.get());
3834726d03ab3abce41911c31d1354a18f1258cae4dTed Kremenek  PackHandler.reset();
38462c9258f4a71569a66d805fc7776526a2c76b34eFariborz Jahanian  PP.RemovePragmaHandler(MSStructHandler.get());
38562c9258f4a71569a66d805fc7776526a2c76b34eFariborz Jahanian  MSStructHandler.reset();
3869b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.RemovePragmaHandler(UnusedHandler.get());
3874726d03ab3abce41911c31d1354a18f1258cae4dTed Kremenek  UnusedHandler.reset();
3889b36c3f0de0105e903130bbda3c4aea7d792c0afArgyrios Kyrtzidis  PP.RemovePragmaHandler(WeakHandler.get());
3899991479ad5dde617168cc1e4b18425cdbbfd9fa9Eli Friedman  WeakHandler.reset();
390f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne
391f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne  if (getLang().OpenCL) {
392f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    PP.RemovePragmaHandler("OPENCL", OpenCLExtensionHandler.get());
393f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    OpenCLExtensionHandler.reset();
394f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne    PP.RemovePragmaHandler("OPENCL", FPContractHandler.get());
395f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne  }
396f315fa81eef1977b3457fd7a7d4639e060fe7278Peter Collingbourne
397321b8179afaf803dcc56b2a19f7b0891a03c92c8Peter Collingbourne  PP.RemovePragmaHandler("STDC", FPContractHandler.get());
398321b8179afaf803dcc56b2a19f7b0891a03c92c8Peter Collingbourne  FPContractHandler.reset();
399f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor  PP.clearCodeCompletionHandler();
4005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
4015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
4025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// Initialize - Warm up the parser.
4035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
4045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencervoid Parser::Initialize() {
40531e057270232c1c37602579cb6461c2704175672Chris Lattner  // Create the translation unit scope.  Install it as the current scope.
40623c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  assert(getCurScope() == 0 && "A scope is already active?");
40731e057270232c1c37602579cb6461c2704175672Chris Lattner  EnterScope(Scope::DeclScope);
408c1a3e5e73859ece9f106ae9d84c78bef4111956aDouglas Gregor  Actions.ActOnTranslationUnitScope(getCurScope());
409c1a3e5e73859ece9f106ae9d84c78bef4111956aDouglas Gregor
410c1a3e5e73859ece9f106ae9d84c78bef4111956aDouglas Gregor  // Prime the lexer look-ahead.
411c1a3e5e73859ece9f106ae9d84c78bef4111956aDouglas Gregor  ConsumeToken();
412a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
413000732226610650837478cba97843d19b75f648eChris Lattner  if (Tok.is(tok::eof) &&
414f72617544287acf0281c3b1a733bcb22a02e6ca4Chris Lattner      !getLang().CPlusPlus)  // Empty source file is an extension in C
4155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Diag(Tok, diag::ext_empty_source_file);
416a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
41734870da70fa42b0391b79627ebd0cfc6eb22213bChris Lattner  // Initialization for Objective-C context sensitive keywords recognition.
418a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek  // Referenced in Parser::ParseObjCTypeQualifierList.
41934870da70fa42b0391b79627ebd0cfc6eb22213bChris Lattner  if (getLang().ObjC1) {
420a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_in] = &PP.getIdentifierTable().get("in");
421a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_out] = &PP.getIdentifierTable().get("out");
422a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_inout] = &PP.getIdentifierTable().get("inout");
423a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_oneway] = &PP.getIdentifierTable().get("oneway");
424a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_bycopy] = &PP.getIdentifierTable().get("bycopy");
425a526c5c67e5a0473c340903ee542ce570119665fTed Kremenek    ObjCTypeQuals[objc_byref] = &PP.getIdentifierTable().get("byref");
42634870da70fa42b0391b79627ebd0cfc6eb22213bChris Lattner  }
427662e8b5647adbb1bc9eeceece7b64600cfa87471Daniel Dunbar
428e97179c675b341927807c718be215c8d1aab8acbDouglas Gregor  Ident_instancetype = 0;
4297eeb4ec11043d4860361348f2b19299d957d47a9Anders Carlsson  Ident_final = 0;
4307eeb4ec11043d4860361348f2b19299d957d47a9Anders Carlsson  Ident_override = 0;
4311f3b6fdabbb10779a473d6315154d7325ce20aeaAnders Carlsson
432662e8b5647adbb1bc9eeceece7b64600cfa87471Daniel Dunbar  Ident_super = &PP.getIdentifierTable().get("super");
43382287d19ded35248c4ce6a425ce74116a13ce44eJohn Thompson
43482287d19ded35248c4ce6a425ce74116a13ce44eJohn Thompson  if (getLang().AltiVec) {
43582287d19ded35248c4ce6a425ce74116a13ce44eJohn Thompson    Ident_vector = &PP.getIdentifierTable().get("vector");
43682287d19ded35248c4ce6a425ce74116a13ce44eJohn Thompson    Ident_pixel = &PP.getIdentifierTable().get("pixel");
43782287d19ded35248c4ce6a425ce74116a13ce44eJohn Thompson  }
4380a0d2b179085a52c10402feebeb6db8b4d96a140Douglas Gregor
4390a0d2b179085a52c10402feebeb6db8b4d96a140Douglas Gregor  Ident_introduced = 0;
4400a0d2b179085a52c10402feebeb6db8b4d96a140Douglas Gregor  Ident_deprecated = 0;
4410a0d2b179085a52c10402feebeb6db8b4d96a140Douglas Gregor  Ident_obsoleted = 0;
442b53e417ba487f4193ef3b0485b420e0fdae643a2Douglas Gregor  Ident_unavailable = 0;
44328bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley
444b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor  Ident__except = 0;
445b57791e5b40afa6691063c83d0e95c416fb19fdeDouglas Gregor
44628bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  Ident__exception_code = Ident__exception_info = Ident__abnormal_termination = 0;
44728bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  Ident___exception_code = Ident___exception_info = Ident___abnormal_termination = 0;
44828bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  Ident_GetExceptionCode = Ident_GetExceptionInfo = Ident_AbnormalTermination = 0;
44928bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley
45028bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  if(getLang().Borland) {
45128bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident__exception_info        = PP.getIdentifierInfo("_exception_info");
45228bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident___exception_info       = PP.getIdentifierInfo("__exception_info");
45328bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident_GetExceptionInfo       = PP.getIdentifierInfo("GetExceptionInformation");
45428bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident__exception_code        = PP.getIdentifierInfo("_exception_code");
45528bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident___exception_code       = PP.getIdentifierInfo("__exception_code");
45628bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident_GetExceptionCode       = PP.getIdentifierInfo("GetExceptionCode");
45728bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident__abnormal_termination  = PP.getIdentifierInfo("_abnormal_termination");
45828bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident___abnormal_termination = PP.getIdentifierInfo("__abnormal_termination");
45928bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    Ident_AbnormalTermination    = PP.getIdentifierInfo("AbnormalTermination");
46028bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley
46128bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident__exception_code,diag::err_seh___except_block);
46228bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident___exception_code,diag::err_seh___except_block);
46328bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident_GetExceptionCode,diag::err_seh___except_block);
46428bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident__exception_info,diag::err_seh___except_filter);
46528bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident___exception_info,diag::err_seh___except_filter);
46628bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident_GetExceptionInfo,diag::err_seh___except_filter);
46728bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident__abnormal_termination,diag::err_seh___finally_block);
46828bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident___abnormal_termination,diag::err_seh___finally_block);
46928bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley    PP.SetPoisonReason(Ident_AbnormalTermination,diag::err_seh___finally_block);
47028bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  }
4715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
4725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
4735f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseTopLevelDecl - Parse one top-level declaration, return whatever the
4745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// action tells us to.  This returns true if the EOF was encountered.
475682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattnerbool Parser::ParseTopLevelDecl(DeclGroupPtrTy &Result) {
47625a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  DelayedCleanupPoint CleanupRAII(TopLevelDeclCleanupPool);
477b918d0f5d8f147e1e26c34e6cf42a79af2d2ec41Argyrios Kyrtzidis
478b918d0f5d8f147e1e26c34e6cf42a79af2d2ec41Argyrios Kyrtzidis  while (Tok.is(tok::annot_pragma_unused))
479b918d0f5d8f147e1e26c34e6cf42a79af2d2ec41Argyrios Kyrtzidis    HandlePragmaUnused();
480b918d0f5d8f147e1e26c34e6cf42a79af2d2ec41Argyrios Kyrtzidis
481682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  Result = DeclGroupPtrTy();
4829299f3fa85796613cc787a2062c9562d07c8613eChris Lattner  if (Tok.is(tok::eof)) {
4838387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    // Late template parsing can begin.
4848387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    if (getLang().DelayedTemplateParsing)
4858387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      Actions.SetLateTemplateParser(LateTemplateParserCallback, this);
4868387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
4879299f3fa85796613cc787a2062c9562d07c8613eChris Lattner    Actions.ActOnEndOfTranslationUnit();
4889299f3fa85796613cc787a2062c9562d07c8613eChris Lattner    return true;
4899299f3fa85796613cc787a2062c9562d07c8613eChris Lattner  }
490a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
4910b7e678a11ece4288dc01aebb5b17e5eef8f8d2dJohn McCall  ParsedAttributesWithRange attrs(AttrFactory);
4927f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall  MaybeParseCXX0XAttributes(attrs);
4937f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall  MaybeParseMicrosoftAttributes(attrs);
494334d47e92e9f241576fdeb7477b69a03136ba854Francois Pichet
4957f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall  Result = ParseExternalDeclaration(attrs);
4965f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  return false;
4975f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
4985f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
4995f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseTranslationUnit:
5005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///       translation-unit: [C99 6.9]
501a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump///         external-declaration
502a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump///         translation-unit external-declaration
5035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencervoid Parser::ParseTranslationUnit() {
5048935b8b49053122ddd3ab4cd59af0fe5eb9c23cfDouglas Gregor  Initialize();
505a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
506682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  DeclGroupPtrTy Res;
50789307ffaf8acf4d6fdffd72b607ca4fbcfdffc9dSteve Naroff  while (!ParseTopLevelDecl(Res))
5085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    /*parse them all*/;
5091eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
51006f548596beef4c0a227a45cba996497f99566c0Chris Lattner  ExitScope();
51123c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  assert(getCurScope() == 0 && "Scope imbalance!");
5125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
5135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
5145f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseExternalDeclaration:
51590b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner///
516c19923dda3d28f67aab4726cd40bb07032758383Douglas Gregor///       external-declaration: [C99 6.9], declaration: [C++ dcl.dcl]
517c3018153a11afe91849748a93d920040a571b76cChris Lattner///         function-definition
518c3018153a11afe91849748a93d920040a571b76cChris Lattner///         declaration
519a1d71aea847a50b3acbd187d2ae9e5c1ead0f4e2Douglas Gregor/// [C++0x] empty-declaration
5205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [GNU]   asm-definition
521c3018153a11afe91849748a93d920040a571b76cChris Lattner/// [GNU]   __extension__ external-declaration
5225f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  objc-class-definition
5235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  objc-class-declaration
5245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  objc-alias-declaration
5255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  objc-protocol-definition
5265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  objc-method-definition
5275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OBJC]  @end
528c19923dda3d28f67aab4726cd40bb07032758383Douglas Gregor/// [C++]   linkage-specification
5295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [GNU] asm-definition:
5305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///         simple-asm-expr ';'
5315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
532a1d71aea847a50b3acbd187d2ae9e5c1ead0f4e2Douglas Gregor/// [C++0x] empty-declaration:
533a1d71aea847a50b3acbd187d2ae9e5c1ead0f4e2Douglas Gregor///           ';'
534a1d71aea847a50b3acbd187d2ae9e5c1ead0f4e2Douglas Gregor///
53545f965581935791a018df829a14dff53c1dd8f47Douglas Gregor/// [C++0x/GNU] 'extern' 'template' declaration
5367f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCallParser::DeclGroupPtrTy
5377f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCallParser::ParseExternalDeclaration(ParsedAttributesWithRange &attrs,
5387f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall                                 ParsingDeclSpec *DS) {
53925a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  DelayedCleanupPoint CleanupRAII(TopLevelDeclCleanupPool);
54036d36806f1972f7ec1d2a3f59155187278c56508Argyrios Kyrtzidis  ParenBraceBracketBalancer BalancerRAIIObj(*this);
5417d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis
5427d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  if (PP.isCodeCompletionReached()) {
5437d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis    cutOffParsing();
5447d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis    return DeclGroupPtrTy();
5457d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  }
5467d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis
547d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall  Decl *SingleDecl = 0;
5485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  switch (Tok.getKind()) {
5495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  case tok::semi:
5507fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith    Diag(Tok, getLang().CPlusPlus0x ?
5517fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith         diag::warn_cxx98_compat_top_level_semi : diag::ext_top_level_semi)
5527fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith      << FixItHint::CreateRemoval(Tok.getLocation());
5531eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
5545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ConsumeToken();
5555f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // TODO: Invoke action for top-level semicolon.
556682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return DeclGroupPtrTy();
55790b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner  case tok::r_brace:
55890b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner    Diag(Tok, diag::err_expected_external_declaration);
55990b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner    ConsumeBrace();
560682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return DeclGroupPtrTy();
56190b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner  case tok::eof:
56290b93d6f6961edd8f17e089253d655892adc1ef7Chris Lattner    Diag(Tok, diag::err_expected_external_declaration);
563682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return DeclGroupPtrTy();
564c3018153a11afe91849748a93d920040a571b76cChris Lattner  case tok::kw___extension__: {
565c46d1a1f8af67a87689d7db9eaf96027282ccaeaChris Lattner    // __extension__ silences extension warnings in the subexpression.
566c46d1a1f8af67a87689d7db9eaf96027282ccaeaChris Lattner    ExtensionRAIIObject O(Diags);  // Use RAII to do this.
56739146d6497ad5e7ca8ef639221e7b3e15d07c888Chris Lattner    ConsumeToken();
5687f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall    return ParseExternalDeclaration(attrs);
569c3018153a11afe91849748a93d920040a571b76cChris Lattner  }
570dfab6cb59a703f2ce4d58371652ce879f4c85a09Anders Carlsson  case tok::kw_asm: {
5717f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall    ProhibitAttributes(attrs);
572bbd37c62e34db3f5a95c899723484a76c71d7757Sean Hunt
57321e006e51a7f9889f55f5bc7b3ca8b50d17571ecAbramo Bagnara    SourceLocation StartLoc = Tok.getLocation();
57421e006e51a7f9889f55f5bc7b3ca8b50d17571ecAbramo Bagnara    SourceLocation EndLoc;
57521e006e51a7f9889f55f5bc7b3ca8b50d17571ecAbramo Bagnara    ExprResult Result(ParseSimpleAsm(&EndLoc));
576a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
5773f9424f3206b834b5dd0e7c403348651ab6fafbbAnders Carlsson    ExpectAndConsume(tok::semi, diag::err_expected_semi_after,
5783f9424f3206b834b5dd0e7c403348651ab6fafbbAnders Carlsson                     "top-level asm block");
579dfab6cb59a703f2ce4d58371652ce879f4c85a09Anders Carlsson
580682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    if (Result.isInvalid())
581682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      return DeclGroupPtrTy();
58221e006e51a7f9889f55f5bc7b3ca8b50d17571ecAbramo Bagnara    SingleDecl = Actions.ActOnFileScopeAsmDecl(Result.get(), StartLoc, EndLoc);
583682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    break;
584dfab6cb59a703f2ce4d58371652ce879f4c85a09Anders Carlsson  }
5855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  case tok::at:
58695ed7784a335aca53b0c6e952cf31a4cfb633360Fariborz Jahanian    return ParseObjCAtDirectives();
587682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    break;
5885f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  case tok::minus:
5895f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  case tok::plus:
590682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    if (!getLang().ObjC1) {
591682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      Diag(Tok, diag::err_expected_external_declaration);
592682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      ConsumeToken();
593682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      return DeclGroupPtrTy();
594682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    }
595682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    SingleDecl = ParseObjCMethodDefinition();
596682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    break;
597791215b7a24666912c0b71175d2ca5ba082f666eDouglas Gregor  case tok::code_completion:
59823c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor      Actions.CodeCompleteOrdinaryName(getCurScope(),
599f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall                                   ObjCImpDecl? Sema::PCC_ObjCImplementation
600f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall                                              : Sema::PCC_Namespace);
6017d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis    cutOffParsing();
6027d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis    return DeclGroupPtrTy();
603f780abc21c39cd4731b9e38f2d2d9f7d1510bd7bDouglas Gregor  case tok::kw_using:
6048f08cb7d0b97786b17ef05e05caa55aad4d6bd39Chris Lattner  case tok::kw_namespace:
6055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  case tok::kw_typedef:
606adcac8824a9cff13f1ef61a69e38c1041cba12eeDouglas Gregor  case tok::kw_template:
607adcac8824a9cff13f1ef61a69e38c1041cba12eeDouglas Gregor  case tok::kw_export:    // As in 'export template'
608511d7aba3b12853fdb88729a0313b80a60eab8adAnders Carlsson  case tok::kw_static_assert:
609c6eb44b321c543c5bcf28727228a0cceced57e2ePeter Collingbourne  case tok::kw__Static_assert:
610bae35118fc5cea2da08567dbb9763af7f906dae2Chris Lattner    // A function definition cannot start with a these keywords.
61197144fc41a9419bf6d74fc9450e8ef3f6e11f7e0Chris Lattner    {
61297144fc41a9419bf6d74fc9450e8ef3f6e11f7e0Chris Lattner      SourceLocation DeclEnd;
613c5be7b0fc804d8e6f87298ec03c94d8cccd74f29Fariborz Jahanian      StmtVector Stmts(Actions);
6147f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs);
61597144fc41a9419bf6d74fc9450e8ef3f6e11f7e0Chris Lattner    }
616d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl
6177306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor  case tok::kw_static:
6187306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    // Parse (then ignore) 'static' prior to a template instantiation. This is
6197306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    // a GCC extension that we intentionally do not support.
6207306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    if (getLang().CPlusPlus && NextToken().is(tok::kw_template)) {
6217306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      Diag(ConsumeToken(), diag::warn_static_inline_explicit_inst_ignored)
6227306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        << 0;
623d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl      SourceLocation DeclEnd;
624c5be7b0fc804d8e6f87298ec03c94d8cccd74f29Fariborz Jahanian      StmtVector Stmts(Actions);
6257f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs);
6267306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    }
6277306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    goto dont_know;
6287306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor
6297306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor  case tok::kw_inline:
6307306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor    if (getLang().CPlusPlus) {
6317306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      tok::TokenKind NextKind = NextToken().getKind();
6327306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor
6337306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      // Inline namespaces. Allowed as an extension even in C++03.
6347306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      if (NextKind == tok::kw_namespace) {
6357306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        SourceLocation DeclEnd;
6367306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        StmtVector Stmts(Actions);
6377f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall        return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs);
6387306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      }
6397306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor
6407306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      // Parse (then ignore) 'inline' prior to a template instantiation. This is
6417306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      // a GCC extension that we intentionally do not support.
6427306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      if (NextKind == tok::kw_template) {
6437306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        Diag(ConsumeToken(), diag::warn_static_inline_explicit_inst_ignored)
6447306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor          << 1;
6457306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        SourceLocation DeclEnd;
6467306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor        StmtVector Stmts(Actions);
6477f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall        return ParseDeclaration(Stmts, Declarator::FileContext, DeclEnd, attrs);
6487306ebfacfa51ba5270fd20f162f62d2ed813485Douglas Gregor      }
649d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl    }
650d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl    goto dont_know;
651d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl
65245f965581935791a018df829a14dff53c1dd8f47Douglas Gregor  case tok::kw_extern:
65345f965581935791a018df829a14dff53c1dd8f47Douglas Gregor    if (getLang().CPlusPlus && NextToken().is(tok::kw_template)) {
65445f965581935791a018df829a14dff53c1dd8f47Douglas Gregor      // Extern templates
65545f965581935791a018df829a14dff53c1dd8f47Douglas Gregor      SourceLocation ExternLoc = ConsumeToken();
65645f965581935791a018df829a14dff53c1dd8f47Douglas Gregor      SourceLocation TemplateLoc = ConsumeToken();
6579324583ad2afd09db8c9967cd05c4fa44bac9555Richard Smith      Diag(ExternLoc, getLang().CPlusPlus0x ?
6589324583ad2afd09db8c9967cd05c4fa44bac9555Richard Smith             diag::warn_cxx98_compat_extern_template :
6599324583ad2afd09db8c9967cd05c4fa44bac9555Richard Smith             diag::ext_extern_template) << SourceRange(ExternLoc, TemplateLoc);
66045f965581935791a018df829a14dff53c1dd8f47Douglas Gregor      SourceLocation DeclEnd;
66145f965581935791a018df829a14dff53c1dd8f47Douglas Gregor      return Actions.ConvertDeclToDeclGroup(
66245f965581935791a018df829a14dff53c1dd8f47Douglas Gregor                  ParseExplicitInstantiation(ExternLoc, TemplateLoc, DeclEnd));
66345f965581935791a018df829a14dff53c1dd8f47Douglas Gregor    }
66445f965581935791a018df829a14dff53c1dd8f47Douglas Gregor    // FIXME: Detect C++ linkage specifications here?
665d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl    goto dont_know;
6661eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
667f986038beed360c031de8654cfba43a5d3184605Francois Pichet  case tok::kw___if_exists:
668f986038beed360c031de8654cfba43a5d3184605Francois Pichet  case tok::kw___if_not_exists:
669563a645de82231a55e221fe655b7188bf8369662Francois Pichet    ParseMicrosoftIfExistsExternalDeclaration();
670f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return DeclGroupPtrTy();
671f986038beed360c031de8654cfba43a5d3184605Francois Pichet
67265030af6526748ce11534e92f0ccefc44091ba13Douglas Gregor  case tok::kw___import_module__:
6736aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor    return ParseModuleImport();
6746aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor
6755f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  default:
676d078e641450bbc5a20df8d3b54f87b27e398acb3Sebastian Redl  dont_know:
6775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // We can't tell whether this is a function-definition or declaration yet.
6787f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall    if (DS) {
6797f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      DS->takeAttributesFrom(attrs);
6807f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      return ParseDeclarationOrFunctionDefinition(*DS);
6817f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall    } else {
6827f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      return ParseDeclarationOrFunctionDefinition(attrs);
6837f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall    }
6845f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
6851eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
686682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  // This routine returns a DeclGroup, if the thing we parsed only contains a
687682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  // single decl, convert it now.
688682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  return Actions.ConvertDeclToDeclGroup(SingleDecl);
6895f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
6905f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
6911426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor/// \brief Determine whether the current token, if it occurs after a
6921426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor/// declarator, continues a declaration or declaration list.
693e4246a633b13197634225971b25df0cbdcec0c5dSean Huntbool Parser::isDeclarationAfterDeclarator() {
694e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt  // Check for '= delete' or '= default'
695e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt  if (getLang().CPlusPlus && Tok.is(tok::equal)) {
696e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt    const Token &KW = NextToken();
697e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt    if (KW.is(tok::kw_default) || KW.is(tok::kw_delete))
698e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt      return false;
699e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt  }
700e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt
7011426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor  return Tok.is(tok::equal) ||      // int X()=  -> not a function def
7021426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor    Tok.is(tok::comma) ||           // int X(),  -> not a function def
7031426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor    Tok.is(tok::semi)  ||           // int X();  -> not a function def
7041426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor    Tok.is(tok::kw_asm) ||          // int X() __asm__ -> not a function def
7051426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor    Tok.is(tok::kw___attribute) ||  // int X() __attr__ -> not a function def
7061426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor    (getLang().CPlusPlus &&
7071426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor     Tok.is(tok::l_paren));         // int X(0) -> not a function def [C++]
7081426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor}
7091426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor
7101426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor/// \brief Determine whether the current token, if it occurs after a
7111426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor/// declarator, indicates the start of a function definition.
712004659a56916f2f81ede507c12516c146d6c0df3Chris Lattnerbool Parser::isStartOfFunctionDefinition(const ParsingDeclarator &Declarator) {
713075f8f1b6bed4d1b224c74f87508534cc6392ce6Abramo Bagnara  assert(Declarator.isFunctionDeclarator() && "Isn't a function declarator");
7145d1c6198cfe55f8de025902c621c0721b640ff60Chris Lattner  if (Tok.is(tok::l_brace))   // int X() {}
7155d1c6198cfe55f8de025902c621c0721b640ff60Chris Lattner    return true;
7165d1c6198cfe55f8de025902c621c0721b640ff60Chris Lattner
717004659a56916f2f81ede507c12516c146d6c0df3Chris Lattner  // Handle K&R C argument lists: int X(f) int f; {}
718004659a56916f2f81ede507c12516c146d6c0df3Chris Lattner  if (!getLang().CPlusPlus &&
719075f8f1b6bed4d1b224c74f87508534cc6392ce6Abramo Bagnara      Declarator.getFunctionTypeInfo().isKNRPrototype())
720004659a56916f2f81ede507c12516c146d6c0df3Chris Lattner    return isDeclarationSpecifier();
721e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt
722e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt  if (getLang().CPlusPlus && Tok.is(tok::equal)) {
723e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt    const Token &KW = NextToken();
724e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt    return KW.is(tok::kw_default) || KW.is(tok::kw_delete);
725e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt  }
726004659a56916f2f81ede507c12516c146d6c0df3Chris Lattner
7275d1c6198cfe55f8de025902c621c0721b640ff60Chris Lattner  return Tok.is(tok::colon) ||         // X() : Base() {} (used for ctors)
7285d1c6198cfe55f8de025902c621c0721b640ff60Chris Lattner         Tok.is(tok::kw_try);          // X() try { ... }
7291426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor}
7301426e534b4fca6a05b1120d634aae46be79ca17cDouglas Gregor
7315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseDeclarationOrFunctionDefinition - Parse either a function-definition or
7325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// a declaration.  We can't tell which we have until we read up to the
733c4b4e7b8f6ca9b036824e048af49cd2a52b57cdfDouglas Gregor/// compound-statement in function-definition. TemplateParams, if
734c4b4e7b8f6ca9b036824e048af49cd2a52b57cdfDouglas Gregor/// non-NULL, provides the template parameters when we're parsing a
7351eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump/// C++ template-declaration.
7365f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
7375f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///       function-definition: [C99 6.9.1]
738a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner///         decl-specs      declarator declaration-list[opt] compound-statement
739a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner/// [C90] function-definition: [C99 6.7.1] - implicit int result
740a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump/// [C90]   decl-specs[opt] declarator declaration-list[opt] compound-statement
741a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner///
7425f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///       declaration: [C99 6.7]
743697e15f2a028f8997cccb24ecd05099988cfb1a9Chris Lattner///         declaration-specifiers init-declarator-list[opt] ';'
744697e15f2a028f8997cccb24ecd05099988cfb1a9Chris Lattner/// [!C99]  init-declarator-list ';'                   [TODO: warn in c99 mode]
7455f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [OMP]   threadprivate-directive                              [TODO]
7465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
747682bf92db408a6cbc3d37b5496a99b6ef85041ecChris LattnerParser::DeclGroupPtrTy
7483acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz JahanianParser::ParseDeclarationOrFunctionDefinition(ParsingDeclSpec &DS,
749bbd37c62e34db3f5a95c899723484a76c71d7757Sean Hunt                                             AccessSpecifier AS) {
7505f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // Parse the common declaration-specifiers piece.
7510efc2c1716be4f1c5f1343cad3b047e74861f030Douglas Gregor  ParseDeclarationSpecifiers(DS, ParsedTemplateInfo(), AS, DSC_top_level);
752a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
7535f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // C99 6.7.2.3p6: Handle "struct-or-union identifier;", "enum { X };"
7545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // declaration-specifiers init-declarator-list[opt] ';'
755000732226610650837478cba97843d19b75f648eChris Lattner  if (Tok.is(tok::semi)) {
7565f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ConsumeToken();
757d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall    Decl *TheDecl = Actions.ParsedFreeStandingDeclSpec(getCurScope(), AS, DS);
75854abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall    DS.complete(TheDecl);
759682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return Actions.ConvertDeclToDeclGroup(TheDecl);
7605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
761a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
762246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar  // ObjC2 allows prefix attributes on class interfaces and protocols.
763246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar  // FIXME: This still needs better diagnostics. We should only accept
764246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar  // attributes here, no types, etc.
765000732226610650837478cba97843d19b75f648eChris Lattner  if (getLang().ObjC2 && Tok.is(tok::at)) {
766dac269b65eed82182fc3e96566dedd6562dfe11eSteve Naroff    SourceLocation AtLoc = ConsumeToken(); // the "@"
7671eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    if (!Tok.isObjCAtKeyword(tok::objc_interface) &&
768246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar        !Tok.isObjCAtKeyword(tok::objc_protocol)) {
769246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar      Diag(Tok, diag::err_objc_unexpected_attr);
770cb53b361bce341c8591333c6997f62e480acc0b4Chris Lattner      SkipUntil(tok::semi); // FIXME: better skip?
771682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      return DeclGroupPtrTy();
772cb53b361bce341c8591333c6997f62e480acc0b4Chris Lattner    }
773d8ac05753dc4506224d445ff98399c01da3136e5John McCall
77454abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall    DS.abort();
77554abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall
7760de2ae28c603322f05e2d9200c7d457c8b928983Fariborz Jahanian    const char *PrevSpec = 0;
777fec54013fcd0eb72642741584ca04c1bc292bef8John McCall    unsigned DiagID;
778fec54013fcd0eb72642741584ca04c1bc292bef8John McCall    if (DS.SetTypeSpecType(DeclSpec::TST_unspecified, AtLoc, PrevSpec, DiagID))
779fec54013fcd0eb72642741584ca04c1bc292bef8John McCall      Diag(AtLoc, DiagID) << PrevSpec;
7801eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
781d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall    Decl *TheDecl = 0;
782246e70f69cb8aeb67225c54690f1c6b25abd5a86Daniel Dunbar    if (Tok.isObjCAtKeyword(tok::objc_protocol))
783682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      TheDecl = ParseObjCAtProtocolDeclaration(AtLoc, DS.getAttributes());
784682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    else
785682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      TheDecl = ParseObjCAtInterfaceDeclaration(AtLoc, DS.getAttributes());
786682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return Actions.ConvertDeclToDeclGroup(TheDecl);
787dac269b65eed82182fc3e96566dedd6562dfe11eSteve Naroff  }
788a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
789c6fdc34ac0183bfa03d65f317c78b7bdac52897eChris Lattner  // If the declspec consisted only of 'extern' and we have a string
790c6fdc34ac0183bfa03d65f317c78b7bdac52897eChris Lattner  // literal following it, this must be a C++ linkage specifier like
791c6fdc34ac0183bfa03d65f317c78b7bdac52897eChris Lattner  // 'extern "C"'.
7923c6f6a7a1bb9969112617a26d2333bab2f6efd65Chris Lattner  if (Tok.is(tok::string_literal) && getLang().CPlusPlus &&
793c6fdc34ac0183bfa03d65f317c78b7bdac52897eChris Lattner      DS.getStorageClassSpec() == DeclSpec::SCS_extern &&
794682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner      DS.getParsedSpecifiers() == DeclSpec::PQ_StorageClassSpecifier) {
795d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall    Decl *TheDecl = ParseLinkage(DS, Declarator::FileContext);
796682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner    return Actions.ConvertDeclToDeclGroup(TheDecl);
797682bf92db408a6cbc3d37b5496a99b6ef85041ecChris Lattner  }
798c6fdc34ac0183bfa03d65f317c78b7bdac52897eChris Lattner
799d8ac05753dc4506224d445ff98399c01da3136e5John McCall  return ParseDeclGroup(DS, Declarator::FileContext, true);
8005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
8015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
8023acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz JahanianParser::DeclGroupPtrTy
8037f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCallParser::ParseDeclarationOrFunctionDefinition(ParsedAttributes &attrs,
8043acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz Jahanian                                             AccessSpecifier AS) {
8053acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz Jahanian  ParsingDeclSpec DS(*this);
8067f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall  DS.takeAttributesFrom(attrs);
8079735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian  // Must temporarily exit the objective-c container scope for
8089735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian  // parsing c constructs and re-enter objc container scope
8099735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian  // afterwards.
8109735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian  ObjCDeclContextSwitch ObjCDC(*this);
8119735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian
8129735c5e60027b26a809df19677ff16a4d13f1321Fariborz Jahanian  return ParseDeclarationOrFunctionDefinition(DS, AS);
8133acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz Jahanian}
8143acd9aaa4ddd14afecb4f1c02ca6f585a6d51849Fariborz Jahanian
8155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseFunctionDefinition - We parsed and verified that the specified
8165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// Declarator is well formed.  If this is a K&R-style function, read the
8175f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// parameters declaration-list, then start the compound-statement.
8185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
819a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner///       function-definition: [C99 6.9.1]
820a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner///         decl-specs      declarator declaration-list[opt] compound-statement
821a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner/// [C90] function-definition: [C99 6.7.1] - implicit int result
822a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump/// [C90]   decl-specs[opt] declarator declaration-list[opt] compound-statement
8237ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor/// [C++] function-definition: [C++ 8.4]
82423c4b1883b13dc17484b7214091b73f3ba29096eChris Lattner///         decl-specifier-seq[opt] declarator ctor-initializer[opt]
82523c4b1883b13dc17484b7214091b73f3ba29096eChris Lattner///         function-body
8267ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor/// [C++] function-definition: [C++ 8.4]
827d3a413d3b8eb39bcee5944bc545d9997c1abe492Sebastian Redl///         decl-specifier-seq[opt] declarator function-try-block
8285f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
829d226f65006733ed7f709c3174f22ce33391cb58fJohn McCallDecl *Parser::ParseFunctionDefinition(ParsingDeclarator &D,
830075f8f1b6bed4d1b224c74f87508534cc6392ce6Abramo Bagnara                                      const ParsedTemplateInfo &TemplateInfo) {
83128bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  // Poison the SEH identifiers so they are flagged as illegal in function bodies
83228bbe4b8acc338476fe0825769b41fb32b423c72John Wiegley  PoisonSEHIdentifiersRAIIObject PoisonSEHIdentifiers(*this, true);
833075f8f1b6bed4d1b224c74f87508534cc6392ce6Abramo Bagnara  const DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
834a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
835a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner  // If this is C90 and the declspecs were completely missing, fudge in an
836a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner  // implicit int.  We do this here because this is the only place where
837a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner  // declaration-specifiers are completely optional in the grammar.
8382a327d11a07dfbdf20910cebbae38910eda111fdChris Lattner  if (getLang().ImplicitInt && D.getDeclSpec().isEmpty()) {
839a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner    const char *PrevSpec;
840fec54013fcd0eb72642741584ca04c1bc292bef8John McCall    unsigned DiagID;
84131c286803c60c59d314525e047d0e72f9a1cb55bChris Lattner    D.getMutableDeclSpec().SetTypeSpecType(DeclSpec::TST_int,
84231c286803c60c59d314525e047d0e72f9a1cb55bChris Lattner                                           D.getIdentifierLoc(),
843fec54013fcd0eb72642741584ca04c1bc292bef8John McCall                                           PrevSpec, DiagID);
844ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl    D.SetRangeBegin(D.getDeclSpec().getSourceRange().getBegin());
845a798ebc82627ea9cb7a00da07d2b60f9f2114f69Chris Lattner  }
846a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
8475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // If this declaration was formed with a K&R-style identifier list for the
8485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // arguments, parse declarations for all of the args next.
8495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // int foo(a,b) int a; float b; {}
850004659a56916f2f81ede507c12516c146d6c0df3Chris Lattner  if (FTI.isKNRPrototype())
8515f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ParseKNRParamDeclarations(D);
8525f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
853e4246a633b13197634225971b25df0cbdcec0c5dSean Hunt
8547ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor  // We should have either an opening brace or, in a C++ constructor,
8557ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor  // we may have a colon.
856758afbcc86ef15f8d433f5f87db1495e50effeb3Douglas Gregor  if (Tok.isNot(tok::l_brace) &&
857758afbcc86ef15f8d433f5f87db1495e50effeb3Douglas Gregor      (!getLang().CPlusPlus ||
858cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt       (Tok.isNot(tok::colon) && Tok.isNot(tok::kw_try) &&
859cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt        Tok.isNot(tok::equal)))) {
8605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Diag(Tok, diag::err_expected_fn_body);
8615f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
8625f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Skip over garbage, until we get to '{'.  Don't eat the '{'.
8635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    SkipUntil(tok::l_brace, true, true);
864a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
8655f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // If we didn't find the '{', bail out.
866000732226610650837478cba97843d19b75f648eChris Lattner    if (Tok.isNot(tok::l_brace))
867d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall      return 0;
8685f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
869a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
8708387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  // In delayed template parsing mode, for function template we consume the
8718387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  // tokens and store them for late parsing at the end of the translation unit.
8728387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  if (getLang().DelayedTemplateParsing &&
8738387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      TemplateInfo.Kind == ParsedTemplateInfo::Template) {
8748387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    MultiTemplateParamsArg TemplateParameterLists(Actions,
8758387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet                                         TemplateInfo.TemplateParams->data(),
8768387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet                                         TemplateInfo.TemplateParams->size());
8778387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
8788387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    ParseScope BodyScope(this, Scope::FnScope|Scope::DeclScope);
8798387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    Scope *ParentScope = getCurScope()->getParent();
8808387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
88145fa560c72441069d9e4eb1e66efd87349caa552Douglas Gregor    D.setFunctionDefinitionKind(FDK_Definition);
8828387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    Decl *DP = Actions.HandleDeclarator(ParentScope, D,
8832c712f50cd56eaf3662989b556e9c6b1e8fcd11aKaelyn Uhrain                                        move(TemplateParameterLists));
8848387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    D.complete(DP);
8858387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    D.getMutableDeclSpec().abort();
8868387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
8878387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    if (DP) {
8888387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      LateParsedTemplatedFunction *LPT = new LateParsedTemplatedFunction(this, DP);
8898387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
8908387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      FunctionDecl *FnD = 0;
8918387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      if (FunctionTemplateDecl *FunTmpl = dyn_cast<FunctionTemplateDecl>(DP))
8928387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet        FnD = FunTmpl->getTemplatedDecl();
8938387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      else
8948387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet        FnD = cast<FunctionDecl>(DP);
895d4a0caf78e7c18e7aca65fbfd799a6c024ff51fbFrancois Pichet      Actions.CheckForFunctionRedefinition(FnD);
8968387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
8978387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      LateParsedTemplateMap[FnD] = LPT;
8988387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      Actions.MarkAsLateParsedTemplate(FnD);
8998387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      LexTemplateFunctionForLateParsing(LPT->Toks);
9008387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    } else {
9018387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      CachedTokens Toks;
9028387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet      LexTemplateFunctionForLateParsing(Toks);
9038387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    }
9048387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet    return DP;
9058387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet  }
9068387e2a41eef6fa17fb140a18c29b6eee9dd2b8aFrancois Pichet
907b652cea7d7b70ebe3744fb6d72c9ad9cf3c95429Chris Lattner  // Enter a scope for the function body.
9088935b8b49053122ddd3ab4cd59af0fe5eb9c23cfDouglas Gregor  ParseScope BodyScope(this, Scope::FnScope|Scope::DeclScope);
909a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
910b652cea7d7b70ebe3744fb6d72c9ad9cf3c95429Chris Lattner  // Tell the actions module that we have entered a function definition with the
911b652cea7d7b70ebe3744fb6d72c9ad9cf3c95429Chris Lattner  // specified Declarator for the function.
912d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall  Decl *Res = TemplateInfo.TemplateParams?
91323c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor      Actions.ActOnStartOfFunctionTemplateDef(getCurScope(),
914f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall                              MultiTemplateParamsArg(Actions,
91552591bf224b2c43e2b00e265bb8599a620081925Douglas Gregor                                          TemplateInfo.TemplateParams->data(),
91652591bf224b2c43e2b00e265bb8599a620081925Douglas Gregor                                         TemplateInfo.TemplateParams->size()),
91752591bf224b2c43e2b00e265bb8599a620081925Douglas Gregor                                              D)
91823c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor    : Actions.ActOnStartOfFunctionDef(getCurScope(), D);
919a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
92054abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall  // Break out of the ParsingDeclarator context before we parse the body.
92154abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall  D.complete(Res);
92254abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall
92354abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall  // Break out of the ParsingDeclSpec context, too.  This const_cast is
92454abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall  // safe because we're always the sole owner.
92554abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall  D.getMutableDeclSpec().abort();
92654abf7d4fa3123b8324c09d2a4dfb789fd818403John McCall
927cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt  if (Tok.is(tok::equal)) {
928cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    assert(getLang().CPlusPlus && "Only C++ function definitions have '='");
929cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    ConsumeToken();
930cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
931cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    Actions.ActOnFinishFunctionBody(Res, 0, false);
932cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
933cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    bool Delete = false;
934cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    SourceLocation KWLoc;
935cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    if (Tok.is(tok::kw_delete)) {
9367fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith      Diag(Tok, getLang().CPlusPlus0x ?
9377fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith           diag::warn_cxx98_compat_deleted_function :
9387fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith           diag::warn_deleted_function_accepted_as_extension);
939cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
940cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      KWLoc = ConsumeToken();
941cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      Actions.SetDeclDeleted(Res, KWLoc);
942cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      Delete = true;
943cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    } else if (Tok.is(tok::kw_default)) {
9447fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith      Diag(Tok, getLang().CPlusPlus0x ?
9457fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith           diag::warn_cxx98_compat_defaulted_function :
9467fe6208c3fa91f835813bb78236ef5c2bbf81053Richard Smith           diag::warn_defaulted_function_accepted_as_extension);
947cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
948cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      KWLoc = ConsumeToken();
949cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      Actions.SetDeclDefaulted(Res, KWLoc);
950cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    } else {
951cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      llvm_unreachable("function definition after = not 'delete' or 'default'");
952cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    }
953cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
954cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    if (Tok.is(tok::comma)) {
955cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      Diag(KWLoc, diag::err_default_delete_in_multiple_declaration)
956cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt        << Delete;
957cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      SkipUntil(tok::semi);
958cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    } else {
959cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt      ExpectAndConsume(tok::semi, diag::err_expected_semi_after,
960cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt                       Delete ? "delete" : "default", tok::semi);
961cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    }
962cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
963cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt    return Res;
964cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt  }
965cd10dec673680fd18a2e5a27646173780c059d32Sean Hunt
966d3a413d3b8eb39bcee5944bc545d9997c1abe492Sebastian Redl  if (Tok.is(tok::kw_try))
967c9977d09a2de7f7d2245973413d4caf86c736640Douglas Gregor    return ParseFunctionTryBlock(Res, BodyScope);
968d3a413d3b8eb39bcee5944bc545d9997c1abe492Sebastian Redl
9697ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor  // If we have a colon, then we're probably parsing a C++
9707ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor  // ctor-initializer.
971d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall  if (Tok.is(tok::colon)) {
9727ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor    ParseConstructorInitializer(Res);
973d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall
974d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall    // Recover from error.
975d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall    if (!Tok.is(tok::l_brace)) {
976c9977d09a2de7f7d2245973413d4caf86c736640Douglas Gregor      BodyScope.Exit();
9779ae2f076ca5ab1feb3ba95629099ec2319833701John McCall      Actions.ActOnFinishFunctionBody(Res, 0);
978d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall      return Res;
979d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall    }
980d6ca8da0f5a4115813055729faaa5128e994806dJohn McCall  } else
981393612e6c7727f1fee50039254d9f434364cc0b2Fariborz Jahanian    Actions.ActOnDefaultCtorInitializers(Res);
9827ad8390f7992ab7f19b1460c5f0b9d96f165c4e9Douglas Gregor
983c9977d09a2de7f7d2245973413d4caf86c736640Douglas Gregor  return ParseFunctionStatementBody(Res, BodyScope);
9845f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
9855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
9865f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseKNRParamDeclarations - Parse 'declaration-list[opt]' which provides
9875f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// types for a function with a K&R-style identifier list for arguments.
9885f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencervoid Parser::ParseKNRParamDeclarations(Declarator &D) {
9895f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // We know that the top-level of this declarator is a function.
990075f8f1b6bed4d1b224c74f87508534cc6392ce6Abramo Bagnara  DeclaratorChunk::FunctionTypeInfo &FTI = D.getFunctionTypeInfo();
9915f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
99204421087832a031c90bd58f128c7c0e741db8dd2Chris Lattner  // Enter function-declaration scope, limiting any declarators to the
99304421087832a031c90bd58f128c7c0e741db8dd2Chris Lattner  // function prototype scope, including parameter declarators.
9943218c4bb3b5d7250f12420de6db7ef3e3f805a75Douglas Gregor  ParseScope PrototypeScope(this, Scope::FunctionPrototypeScope|Scope::DeclScope);
99504421087832a031c90bd58f128c7c0e741db8dd2Chris Lattner
9965f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // Read all the argument declarations.
9975f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  while (isDeclarationSpecifier()) {
9985f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    SourceLocation DSStart = Tok.getLocation();
999a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Parse the common declaration-specifiers piece.
10010b7e678a11ece4288dc01aebb5b17e5eef8f8d2dJohn McCall    DeclSpec DS(AttrFactory);
10025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ParseDeclarationSpecifiers(DS);
1003a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // C99 6.9.1p6: 'each declaration in the declaration list shall have at
10055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // least one declarator'.
10065f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // NOTE: GCC just makes this an ext-warn.  It's not clear what it does with
10075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // the declarations though.  It's trivial to ignore them, really hard to do
10085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // anything else with them.
1009000732226610650837478cba97843d19b75f648eChris Lattner    if (Tok.is(tok::semi)) {
10105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      Diag(DSStart, diag::err_declaration_does_not_declare_param);
10115f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeToken();
10125f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      continue;
10135f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
1014a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // C99 6.9.1p6: Declarations shall contain no storage-class specifiers other
10165f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // than register.
10175f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    if (DS.getStorageClassSpec() != DeclSpec::SCS_unspecified &&
10185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        DS.getStorageClassSpec() != DeclSpec::SCS_register) {
10195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      Diag(DS.getStorageClassSpecLoc(),
10205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer           diag::err_invalid_storage_class_in_func_decl);
10215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      DS.ClearStorageClassSpecs();
10225f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
10235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    if (DS.isThreadSpecified()) {
10245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      Diag(DS.getThreadSpecLoc(),
10255f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer           diag::err_invalid_storage_class_in_func_decl);
10265f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      DS.ClearStorageClassSpecs();
10275f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
1028a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10295f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Parse the first declarator attached to this declspec.
10305f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Declarator ParmDeclarator(DS, Declarator::KNRTypeListContext);
10315f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    ParseDeclarator(ParmDeclarator);
10325f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
10335f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    // Handle the full declarator list.
10345f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    while (1) {
10355f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // If attributes are present, parse them.
10367f040a9d817cd1c72b565e92abff473510bf9e1dJohn McCall      MaybeParseGNUAttributes(ParmDeclarator);
1037a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10385f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Ask the actions module to compute the type for this declarator.
1039d226f65006733ed7f709c3174f22ce33391cb58fJohn McCall      Decl *Param =
104023c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor        Actions.ActOnParamDeclarator(getCurScope(), ParmDeclarator);
10412bd42fadafddc8acf744b57a970bdc96a077c617Steve Naroff
1042a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump      if (Param &&
10435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          // A missing identifier has already been diagnosed.
10445f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          ParmDeclarator.getIdentifier()) {
10455f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
10465f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        // Scan the argument list looking for the correct param to apply this
10475f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        // type.
10485f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        for (unsigned i = 0; ; ++i) {
10495f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          // C99 6.9.1p6: those declarators shall declare only identifiers from
10505f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          // the identifier list.
10515f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          if (i == FTI.NumArgs) {
10521ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner            Diag(ParmDeclarator.getIdentifierLoc(), diag::err_no_matching_param)
10536898e33d0b28346a4dbe9a666e0e4188fea80460Chris Lattner              << ParmDeclarator.getIdentifier();
10545f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer            break;
10555f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          }
1056a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10575f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          if (FTI.ArgInfo[i].Ident == ParmDeclarator.getIdentifier()) {
10585f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer            // Reject redefinitions of parameters.
105904421087832a031c90bd58f128c7c0e741db8dd2Chris Lattner            if (FTI.ArgInfo[i].Param) {
10605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer              Diag(ParmDeclarator.getIdentifierLoc(),
10611ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner                   diag::err_param_redefinition)
10626898e33d0b28346a4dbe9a666e0e4188fea80460Chris Lattner                 << ParmDeclarator.getIdentifier();
10635f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer            } else {
106404421087832a031c90bd58f128c7c0e741db8dd2Chris Lattner              FTI.ArgInfo[i].Param = Param;
10655f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer            }
10665f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer            break;
10675f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer          }
10685f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        }
10695f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      }
10705f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
10715f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // If we don't have a comma, it is either the end of the list (a ';') or
10725f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // an error, bail out.
1073000732226610650837478cba97843d19b75f648eChris Lattner      if (Tok.isNot(tok::comma))
10745f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        break;
1075a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10765f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Consume the comma.
10775f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeToken();
1078a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10795f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Parse the next declarator.
10805f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ParmDeclarator.clear();
10815f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ParseDeclarator(ParmDeclarator);
10825f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
1083a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
1084000732226610650837478cba97843d19b75f648eChris Lattner    if (Tok.is(tok::semi)) {
10855f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      ConsumeToken();
10865f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    } else {
10875f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      Diag(Tok, diag::err_parse_error);
10885f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      // Skip to end of block or statement
10895f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer      SkipUntil(tok::semi, true);
1090000732226610650837478cba97843d19b75f648eChris Lattner      if (Tok.is(tok::semi))
10915f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer        ConsumeToken();
10925f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    }
10935f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1094a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
10955f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // The actions module must verify that all arguments were declared.
109623c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  Actions.ActOnFinishKNRParamDeclarations(getCurScope(), D, Tok.getLocation());
10975f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
10985f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
10995f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
11005f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseAsmStringLiteral - This is just a normal string-literal, but is not
11015f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// allowed to be a wide string, and is not subject to character translation.
11025f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
11035f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [GNU] asm-string-literal:
11045f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///         string-literal
11055f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
110660d7b3a319d84d688752be3870615ac0f111fb16John McCallParser::ExprResult Parser::ParseAsmStringLiteral() {
11075f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  if (!isTokenStringLiteral()) {
11085f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer    Diag(Tok, diag::err_expected_string_literal);
110961364dddc33383e62cfe3b841dbc0f471280d95bSebastian Redl    return ExprError();
11105f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1111a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
111260d7b3a319d84d688752be3870615ac0f111fb16John McCall  ExprResult Res(ParseStringLiteralExpression());
1113effa8d1c97b00a3f53e972b0e61d9aade5ea1c57Sebastian Redl  if (Res.isInvalid()) return move(Res);
1114a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
11155f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  // TODO: Diagnose: wide string literal in 'asm'
1116a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
1117effa8d1c97b00a3f53e972b0e61d9aade5ea1c57Sebastian Redl  return move(Res);
11185f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
11195f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
11205f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// ParseSimpleAsm
11215f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
11225f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer/// [GNU] simple-asm-expr:
11235f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///         'asm' '(' asm-string-literal ')'
11245f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer///
112560d7b3a319d84d688752be3870615ac0f111fb16John McCallParser::ExprResult Parser::ParseSimpleAsm(SourceLocation *EndLoc) {
1126000732226610650837478cba97843d19b75f648eChris Lattner  assert(Tok.is(tok::kw_asm) && "Not an asm!");
1127dfab6cb59a703f2ce4d58371652ce879f4c85a09Anders Carlsson  SourceLocation Loc = ConsumeToken();
1128a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
11297a6ae743b2ecfdfadadf7df53b569a9a3871a8fdJohn McCall  if (Tok.is(tok::kw_volatile)) {
1130841d5e607f81bf5627e47d0c62ead29f28b5b0c2John McCall    // Remove from the end of 'asm' to the end of 'volatile'.
1131841d5e607f81bf5627e47d0c62ead29f28b5b0c2John McCall    SourceRange RemovalRange(PP.getLocForEndOfToken(Loc),
1132841d5e607f81bf5627e47d0c62ead29f28b5b0c2John McCall                             PP.getLocForEndOfToken(Tok.getLocation()));
1133841d5e607f81bf5627e47d0c62ead29f28b5b0c2John McCall
1134841d5e607f81bf5627e47d0c62ead29f28b5b0c2John McCall    Diag(Tok, diag::warn_file_asm_volatile)
1135849b243d4065f56742a4677d6dc8277609a151f8Douglas Gregor      << FixItHint::CreateRemoval(RemovalRange);
11367a6ae743b2ecfdfadadf7df53b569a9a3871a8fdJohn McCall    ConsumeToken();
11377a6ae743b2ecfdfadadf7df53b569a9a3871a8fdJohn McCall  }
11387a6ae743b2ecfdfadadf7df53b569a9a3871a8fdJohn McCall
11394a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  BalancedDelimiterTracker T(*this, tok::l_paren);
11404a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  if (T.consumeOpen()) {
11411ab3b96de160e4fbffec2a776e284a48a3bb543dChris Lattner    Diag(Tok, diag::err_expected_lparen_after) << "asm";
114261364dddc33383e62cfe3b841dbc0f471280d95bSebastian Redl    return ExprError();
11435f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer  }
1144a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
114560d7b3a319d84d688752be3870615ac0f111fb16John McCall  ExprResult Result(ParseAsmStringLiteral());
1146a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
1147ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl  if (Result.isInvalid()) {
1148ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl    SkipUntil(tok::r_paren, true, true);
1149ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl    if (EndLoc)
1150ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl      *EndLoc = Tok.getLocation();
1151ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl    ConsumeAnyToken();
1152ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl  } else {
11534a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    // Close the paren and get the location of the end bracket
11544a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    T.consumeClose();
1155ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl    if (EndLoc)
11564a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      *EndLoc = T.getCloseLocation();
1157ab197baec16bacade82325fb274cf6b992ac5d8aSebastian Redl  }
1158a6f0177a864ac478eb9890319f2e8ea03695e91dMike Stump
1159effa8d1c97b00a3f53e972b0e61d9aade5ea1c57Sebastian Redl  return move(Result);
11605f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer}
11615f016e2cb5d11daeb237544de1c5d59f20fe1a6eReid Spencer
116225a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis/// \brief Get the TemplateIdAnnotation from the token and put it in the
116325a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis/// cleanup pool so that it gets destroyed when parsing the current top level
116425a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis/// declaration is finished.
116525a767651d14db87aa03dd5fe3e011d877dd4100Argyrios KyrtzidisTemplateIdAnnotation *Parser::takeTemplateIdAnnotation(const Token &tok) {
116625a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  assert(tok.is(tok::annot_template_id) && "Expected template-id token");
116725a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  TemplateIdAnnotation *
116825a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis      Id = static_cast<TemplateIdAnnotation *>(tok.getAnnotationValue());
116925a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  TopLevelDeclCleanupPool.delayMemberFunc< TemplateIdAnnotation,
117025a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis                                          &TemplateIdAnnotation::Destroy>(Id);
117125a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis  return Id;
117225a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis}
117325a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis
1174eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// TryAnnotateTypeOrScopeToken - If the current token position is on a
1175eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// typename (possibly qualified in C++) or a C++ scope specifier not followed
1176eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// by a typename, TryAnnotateTypeOrScopeToken will replace one or more tokens
1177eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// with a single annotation token representing the typename or C++ scope
1178eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// respectively.
1179eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// This simplifies handling of C++ scope specifiers and allows efficient
1180eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// backtracking without the need to re-parse and resolve nested-names and
1181eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// typenames.
118244802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// It will mainly be called when we expect to treat identifiers as typenames
118344802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// (if they are typenames). For example, in C we do not expect identifiers
118444802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// inside expressions to be treated as typenames so it will not be called
118544802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// for expressions in C.
118644802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// The benefit for C/ObjC is that a typename will be annotated and
1187b43a50ff1b0b171ece84425b0ad83a9a31f038faSteve Naroff/// Actions.getTypeName will not be needed to be called again (e.g. getTypeName
118844802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// will not be called twice, once to check whether we have a declaration
118944802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// specifier, and another one to get the actual type inside
119044802cc435d5122701e4f1a9354381cff4b171c0Argyrios Kyrtzidis/// ParseDeclarationSpecifiers).
1191a7bc7c880f86bc180684ef032d06df51bcae7a23Chris Lattner///
11929ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall/// This returns true if an error occurred.
11931eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump///
119455a7cefc846765ac7d142a63f773747a20518d71Chris Lattner/// Note that this routine emits an error if you call it with ::new or ::delete
119555a7cefc846765ac7d142a63f773747a20518d71Chris Lattner/// as the current tokens, so only call it in contexts where these are invalid.
1196fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrainbool Parser::TryAnnotateTypeOrScopeToken(bool EnteringContext, bool NeedType) {
11971eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  assert((Tok.is(tok::identifier) || Tok.is(tok::coloncolon)
1198ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall          || Tok.is(tok::kw_typename) || Tok.is(tok::annot_cxxscope)) &&
11997452c6fc567ea1799f617395d0fa4c7ed075e5d9Chris Lattner         "Cannot be a type or scope token!");
12001eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1201d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor  if (Tok.is(tok::kw_typename)) {
1202d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    // Parse a C++ typename-specifier, e.g., "typename T::type".
1203d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    //
1204d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    //   typename-specifier:
1205d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    //     'typename' '::' [opt] nested-name-specifier identifier
12061eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    //     'typename' '::' [opt] nested-name-specifier template [opt]
12071734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    //            simple-template-id
1208d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    SourceLocation TypenameLoc = ConsumeToken();
1209d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    CXXScopeSpec SS;
1210efaa93aaa2653f4eb40e6a22e504a448da94aaf8Douglas Gregor    if (ParseOptionalCXXScopeSpecifier(SS, /*ObjectType=*/ParsedType(),
1211efaa93aaa2653f4eb40e6a22e504a448da94aaf8Douglas Gregor                                       /*EnteringContext=*/false,
12124147d307086cf024a40a080e2bf379e9725f6f41Francois Pichet                                       0, /*IsTypename*/true))
12139ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return true;
12149ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall    if (!SS.isSet()) {
121562ec1f2fd7368542bb926c04797fb07023547694Francois Pichet      if (getLang().MicrosoftExt)
1216a5d318ad4ad3a110b3abb34f765e69b76f7c0bcdFrancois Pichet        Diag(Tok.getLocation(), diag::warn_expected_qualified_after_typename);
1217a5d318ad4ad3a110b3abb34f765e69b76f7c0bcdFrancois Pichet      else
1218a5d318ad4ad3a110b3abb34f765e69b76f7c0bcdFrancois Pichet        Diag(Tok.getLocation(), diag::err_expected_qualified_after_typename);
12199ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return true;
1220d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    }
1221d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor
1222d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    TypeResult Ty;
1223d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor    if (Tok.is(tok::identifier)) {
1224d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor      // FIXME: check whether the next token is '<', first!
122523c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor      Ty = Actions.ActOnTypenameType(getCurScope(), TypenameLoc, SS,
12261a15dae8be2b28e02b6639aa92b832465c5be420Douglas Gregor                                     *Tok.getIdentifierInfo(),
1227d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor                                     Tok.getLocation());
12281734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    } else if (Tok.is(tok::annot_template_id)) {
122925a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis      TemplateIdAnnotation *TemplateId = takeTemplateIdAnnotation(Tok);
12301734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor      if (TemplateId->Kind == TNK_Function_template) {
12311734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor        Diag(Tok, diag::err_typename_refers_to_non_type_template)
12321734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor          << Tok.getAnnotationRange();
12339ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall        return true;
12341734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor      }
1235d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor
1236a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor      ASTTemplateArgsPtr TemplateArgsPtr(Actions,
1237a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                         TemplateId->getTemplateArgs(),
1238a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                         TemplateId->NumArgs);
1239a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor
1240a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor      Ty = Actions.ActOnTypenameType(getCurScope(), TypenameLoc, SS,
1241a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     /*FIXME:*/SourceLocation(),
1242a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     TemplateId->Template,
1243a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     TemplateId->TemplateNameLoc,
1244a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     TemplateId->LAngleLoc,
1245a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     TemplateArgsPtr,
1246a02411e4d58b1730bea2a990822858ecc31e8eb1Douglas Gregor                                     TemplateId->RAngleLoc);
12471734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    } else {
12481734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor      Diag(Tok, diag::err_expected_type_name_after_typename)
12491734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor        << SS.getRange();
12509ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return true;
12511734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    }
12521734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor
125339d67117f896c6e2faa727671ef64b3c04b0e3feSebastian Redl    SourceLocation EndLoc = Tok.getLastLoc();
12541734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    Tok.setKind(tok::annot_typename);
1255b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall    setTypeAnnotation(Tok, Ty.isInvalid() ? ParsedType() : Ty.get());
125639d67117f896c6e2faa727671ef64b3c04b0e3feSebastian Redl    Tok.setAnnotationEndLoc(EndLoc);
12571734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    Tok.setLocation(TypenameLoc);
12581734317845d60307d474b5da8a8d33adbaf5e723Douglas Gregor    PP.AnnotateCachedTokens(Tok);
12599ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall    return false;
1260d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor  }
1261d57959af02b4af695276f4204443afe6e5d86bd8Douglas Gregor
1262ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  // Remembers whether the token was originally a scope annotation.
1263ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  bool wasScopeAnnotation = Tok.is(tok::annot_cxxscope);
1264ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall
1265eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis  CXXScopeSpec SS;
12664bdd91c09fd59e0c154d759288beff300e31e1d0Argyrios Kyrtzidis  if (getLang().CPlusPlus)
1267b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall    if (ParseOptionalCXXScopeSpecifier(SS, ParsedType(), EnteringContext))
12689ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return true;
1269eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis
1270eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis  if (Tok.is(tok::identifier)) {
1271fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain    IdentifierInfo *CorrectedII = 0;
1272608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner    // Determine whether the identifier is a type name.
1273b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall    if (ParsedType Ty = Actions.getTypeName(*Tok.getIdentifierInfo(),
1274b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall                                            Tok.getLocation(), getCurScope(),
12751e52dfc648ce0b25ef57ae29ef1b4337d80011efFariborz Jahanian                                            &SS, false,
12769e876876afc13aa671cc11a17c19907c599b9ab9Douglas Gregor                                            NextToken().is(tok::period),
12779e876876afc13aa671cc11a17c19907c599b9ab9Douglas Gregor                                            ParsedType(),
1278fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain                                            /*NonTrivialTypeSourceInfo*/true,
1279fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain                                            NeedType ? &CorrectedII : NULL)) {
1280fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain      // A FixIt was applied as a result of typo correction
1281fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain      if (CorrectedII)
1282fac9467d1676dc05761e12e41e13e01a3a3da52bKaelyn Uhrain        Tok.setIdentifierInfo(CorrectedII);
1283608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // This is a typename. Replace the current token in-place with an
1284608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // annotation type token.
1285b31757b68afe06ba442a05775d08fe7aa0f6f889Chris Lattner      Tok.setKind(tok::annot_typename);
1286b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall      setTypeAnnotation(Tok, Ty);
1287608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      Tok.setAnnotationEndLoc(Tok.getLocation());
1288608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      if (SS.isNotEmpty()) // it was a C++ qualified type name.
1289608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner        Tok.setLocation(SS.getBeginLoc());
12901eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
1291608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // In case the tokens were cached, have Preprocessor replace
1292608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // them with the annotation token.
1293608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      PP.AnnotateCachedTokens(Tok);
12949ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return false;
12951eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump    }
129639a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor
129739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    if (!getLang().CPlusPlus) {
1298608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // If we're in C, we can't have :: tokens at all (the lexer won't return
1299608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      // them).  If the identifier is not a type, then it can't be scope either,
13001eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump      // just early exit.
1301608d1fc9c4db3e3769f03a4f989d7692aefbf073Chris Lattner      return false;
1302eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis    }
13031eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
130439a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    // If this is a template-id, annotate with a template-id or type token.
130555f6b14230c94272efbbcdd89a92224c8db9f225Douglas Gregor    if (NextToken().is(tok::less)) {
13067532dc66648cfe7432c9fe66dec5225f0ab301c6Douglas Gregor      TemplateTy Template;
1307014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor      UnqualifiedId TemplateName;
1308014e88d94ff83e3aad4e33b16413a2d1817ec208Douglas Gregor      TemplateName.setIdentifier(Tok.getIdentifierInfo(), Tok.getLocation());
13091fd6d44d7ca97631497551bbf98866263143d706Douglas Gregor      bool MemberOfUnknownSpecialization;
13101eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump      if (TemplateNameKind TNK
13117c15353ccaed24f2df932571166bf305c1b98b6dAbramo Bagnara          = Actions.isTemplateName(getCurScope(), SS,
13127c15353ccaed24f2df932571166bf305c1b98b6dAbramo Bagnara                                   /*hasTemplateKeyword=*/false, TemplateName,
1313b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall                                   /*ObjectType=*/ ParsedType(),
1314b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall                                   EnteringContext,
13157c15353ccaed24f2df932571166bf305c1b98b6dAbramo Bagnara                                   Template, MemberOfUnknownSpecialization)) {
1316ca1bdd7c269a2390d43c040a60511edd017ee130Douglas Gregor        // Consume the identifier.
1317ca1bdd7c269a2390d43c040a60511edd017ee130Douglas Gregor        ConsumeToken();
1318059101f922de6eb765601459925f4c8914420b23Douglas Gregor        if (AnnotateTemplateIdToken(Template, TNK, SS, TemplateName)) {
1319c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner          // If an unrecoverable error occurred, we need to return true here,
1320c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner          // because the token stream is in a damaged state.  We may not return
1321c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner          // a valid identifier.
13229ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall          return true;
1323c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner        }
1324ca1bdd7c269a2390d43c040a60511edd017ee130Douglas Gregor      }
132555f6b14230c94272efbbcdd89a92224c8db9f225Douglas Gregor    }
1326d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
132739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    // The current token, which is either an identifier or a
132839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    // template-id, is not part of the annotation. Fall through to
132939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    // push that token back into the stream and complete the C++ scope
133039a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    // specifier annotation.
13311eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump  }
1332eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis
133339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  if (Tok.is(tok::annot_template_id)) {
133425a767651d14db87aa03dd5fe3e011d877dd4100Argyrios Kyrtzidis    TemplateIdAnnotation *TemplateId = takeTemplateIdAnnotation(Tok);
1335c45c232440dfafedca1a3773b904fb42609b1b19Douglas Gregor    if (TemplateId->Kind == TNK_Type_template) {
133639a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor      // A template-id that refers to a type was parsed into a
133739a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor      // template-id annotation in a context where we weren't allowed
133839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor      // to produce a type annotation token. Update the template-id
133939a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor      // annotation token to a type annotation token now.
1340059101f922de6eb765601459925f4c8914420b23Douglas Gregor      AnnotateTemplateIdTokenAsType();
13419ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall      return false;
134239a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor    }
134339a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor  }
1344d6fb7ef028d9aa0b3e8943b7bc049c524437b407Douglas Gregor
13456ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  if (SS.isEmpty())
13469ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall    return false;
13471eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump
13486ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // A C++ scope specifier that isn't followed by a typename.
13496ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // Push the current token back into the token stream (or revert it if it is
13506ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // cached) and use an annotation scope token for current token.
13516ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  if (PP.isBacktrackEnabled())
13526ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner    PP.RevertCachedTokens(1);
13536ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  else
13546ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner    PP.EnterToken(Tok);
13556ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  Tok.setKind(tok::annot_cxxscope);
1356c34348a7ef1a6b3f92a644a227953800cd1f9947Douglas Gregor  Tok.setAnnotationValue(Actions.SaveNestedNameSpecifierAnnotation(SS));
13576ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  Tok.setAnnotationRange(SS.getRange());
13586ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner
1359ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  // In case the tokens were cached, have Preprocessor replace them
1360ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  // with the annotation token.  We don't need to do this if we've
1361ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  // just reverted back to the state we were in before being called.
1362ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall  if (!wasScopeAnnotation)
1363ae03cb5a84d13c7a0d4b21865bd63aabd18120d2John McCall    PP.AnnotateCachedTokens(Tok);
13649ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall  return false;
1365eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis}
1366eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis
1367eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis/// TryAnnotateScopeToken - Like TryAnnotateTypeOrScopeToken but only
136839a8de10c18365bde7062d8959b7ed525449c561Douglas Gregor/// annotates C++ scope specifiers and template-ids.  This returns
1369c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner/// true if the token was annotated or there was an error that could not be
1370c8e27cc402043ec86c1698c09e4ee9e415b16207Chris Lattner/// recovered from.
13711eb4433ac451dc16f4133a88af2d002ac26c58efMike Stump///
137255a7cefc846765ac7d142a63f773747a20518d71Chris Lattner/// Note that this routine emits an error if you call it with ::new or ::delete
137355a7cefc846765ac7d142a63f773747a20518d71Chris Lattner/// as the current tokens, so only call it in contexts where these are invalid.
1374495c35d291da48c4f5655bbb54d15128ddde0d4dDouglas Gregorbool Parser::TryAnnotateCXXScopeToken(bool EnteringContext) {
13754bdd91c09fd59e0c154d759288beff300e31e1d0Argyrios Kyrtzidis  assert(getLang().CPlusPlus &&
13766ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner         "Call sites of this function should be guarded by checking for C++");
13773b887354b1b667c97d070ddc67b5354353c4c07bDouglas Gregor  assert((Tok.is(tok::identifier) || Tok.is(tok::coloncolon) ||
13783b887354b1b667c97d070ddc67b5354353c4c07bDouglas Gregor          (Tok.is(tok::annot_template_id) && NextToken().is(tok::coloncolon)))&&
13797452c6fc567ea1799f617395d0fa4c7ed075e5d9Chris Lattner         "Cannot be a type or scope token!");
1380eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis
13814bdd91c09fd59e0c154d759288beff300e31e1d0Argyrios Kyrtzidis  CXXScopeSpec SS;
1382b3d8748e797c6c2f1dc01186c8eeb3b1b5fe970cJohn McCall  if (ParseOptionalCXXScopeSpecifier(SS, ParsedType(), EnteringContext))
13839ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall    return true;
1384edc287751a4b05e3b4d8ff2b38fa30c5b59a548bJeffrey Yasskin  if (SS.isEmpty())
13859ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall    return false;
1386eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis
13876ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // Push the current token back into the token stream (or revert it if it is
13886ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // cached) and use an annotation scope token for current token.
13896ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  if (PP.isBacktrackEnabled())
13906ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner    PP.RevertCachedTokens(1);
13916ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  else
13926ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner    PP.EnterToken(Tok);
13936ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  Tok.setKind(tok::annot_cxxscope);
1394c34348a7ef1a6b3f92a644a227953800cd1f9947Douglas Gregor  Tok.setAnnotationValue(Actions.SaveNestedNameSpecifierAnnotation(SS));
13956ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  Tok.setAnnotationRange(SS.getRange());
13966ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner
13976ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // In case the tokens were cached, have Preprocessor replace them with the
13986ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  // annotation token.
13996ec76d45bd3111013c357f16e08720407c2f9ae8Chris Lattner  PP.AnnotateCachedTokens(Tok);
14009ba6166f4a78722e7df8ffbd64eb788bfdf2764aJohn McCall  return false;
1401eb83ecde1a822b1c38cd060a85a08c1ac9f82cf8Argyrios Kyrtzidis}
14026c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall
1403a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidisbool Parser::isTokenEqualOrMistypedEqualEqual(unsigned DiagID) {
1404a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis  if (Tok.is(tok::equalequal)) {
1405a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis    // We have '==' in a context that we would expect a '='.
1406a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis    // The user probably made a typo, intending to type '='. Emit diagnostic,
1407a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis    // fixit hint to turn '==' -> '=' and continue as if the user typed '='.
1408a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis    Diag(Tok, DiagID)
1409a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis      << FixItHint::CreateReplacement(SourceRange(Tok.getLocation()),
1410a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis                                      getTokenSimpleSpelling(tok::equal));
1411a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis    return true;
1412a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis  }
1413a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis
1414a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis  return Tok.is(tok::equal);
1415a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis}
1416a6eb5f81d13bacac01faff70a947047725b4413fArgyrios Kyrtzidis
14177d100872341f233c81e1d7b72b40457e62c36862Argyrios KyrtzidisSourceLocation Parser::handleUnexpectedCodeCompletionToken() {
14187d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  assert(Tok.is(tok::code_completion));
14197d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  PrevTokLocation = Tok.getLocation();
14207d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis
142123c94dbb6631fecdb55ba401aa93722803d980c6Douglas Gregor  for (Scope *S = getCurScope(); S; S = S->getParent()) {
1422dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor    if (S->getFlags() & Scope::FnScope) {
1423f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall      Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_RecoveryInFunction);
14247d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis      cutOffParsing();
14257d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis      return PrevTokLocation;
1426dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor    }
1427dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor
1428dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor    if (S->getFlags() & Scope::ClassScope) {
1429f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall      Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_Class);
14307d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis      cutOffParsing();
14317d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis      return PrevTokLocation;
1432dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor    }
1433dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor  }
1434dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor
1435f312b1ea179f1c44371f9ee0cd0bc006f612de11John McCall  Actions.CodeCompleteOrdinaryName(getCurScope(), Sema::PCC_Namespace);
14367d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  cutOffParsing();
14377d100872341f233c81e1d7b72b40457e62c36862Argyrios Kyrtzidis  return PrevTokLocation;
1438dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor}
1439dc8453422bec3bbf70c03920e01498d75783d122Douglas Gregor
14406c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall// Anchor the Parser::FieldCallback vtable to this translation unit.
14416c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall// We use a spurious method instead of the destructor because
14426c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall// destroying FieldCallbacks can actually be slightly
14436c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall// performance-sensitive.
14446c94a6d77f456f23ecd4c2061e6413786b5e6571John McCallvoid Parser::FieldCallback::_anchor() {
14456c94a6d77f456f23ecd4c2061e6413786b5e6571John McCall}
1446f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor
1447f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor// Code-completion pass-through functions
1448f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor
1449f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregorvoid Parser::CodeCompleteDirective(bool InConditional) {
1450f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor  Actions.CodeCompletePreprocessorDirective(InConditional);
1451f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor}
1452f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor
1453f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregorvoid Parser::CodeCompleteInConditionalExclusion() {
1454f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor  Actions.CodeCompleteInPreprocessorConditionalExclusion(getCurScope());
1455f44e854ed1e3aa86d2ed6d615ccd109d50ddcff9Douglas Gregor}
14561fbb447e9d43c2c676e94081fbfee7eb6cbe933bDouglas Gregor
14571fbb447e9d43c2c676e94081fbfee7eb6cbe933bDouglas Gregorvoid Parser::CodeCompleteMacroName(bool IsDefinition) {
1458f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor  Actions.CodeCompletePreprocessorMacroName(IsDefinition);
1459f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor}
1460f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor
1461f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregorvoid Parser::CodeCompletePreprocessorExpression() {
1462f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor  Actions.CodeCompletePreprocessorExpression();
1463f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor}
1464f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor
1465f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregorvoid Parser::CodeCompleteMacroArgument(IdentifierInfo *Macro,
1466f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor                                       MacroInfo *MacroInfo,
1467f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor                                       unsigned ArgumentIndex) {
1468f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor  Actions.CodeCompletePreprocessorMacroArgument(getCurScope(), Macro, MacroInfo,
1469f29c5233085a5af795c3c01b94d319e5b3235d56Douglas Gregor                                                ArgumentIndex);
14701fbb447e9d43c2c676e94081fbfee7eb6cbe933bDouglas Gregor}
147155817afdf9d453a443262a733f6caf6692dca118Douglas Gregor
147255817afdf9d453a443262a733f6caf6692dca118Douglas Gregorvoid Parser::CodeCompleteNaturalLanguage() {
147355817afdf9d453a443262a733f6caf6692dca118Douglas Gregor  Actions.CodeCompleteNaturalLanguage();
147455817afdf9d453a443262a733f6caf6692dca118Douglas Gregor}
1475f986038beed360c031de8654cfba43a5d3184605Francois Pichet
14763896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregorbool Parser::ParseMicrosoftIfExistsCondition(IfExistsCondition& Result) {
1477f986038beed360c031de8654cfba43a5d3184605Francois Pichet  assert((Tok.is(tok::kw___if_exists) || Tok.is(tok::kw___if_not_exists)) &&
1478f986038beed360c031de8654cfba43a5d3184605Francois Pichet         "Expected '__if_exists' or '__if_not_exists'");
14793896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  Result.IsIfExists = Tok.is(tok::kw___if_exists);
14803896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  Result.KeywordLoc = ConsumeToken();
1481f986038beed360c031de8654cfba43a5d3184605Francois Pichet
14824a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  BalancedDelimiterTracker T(*this, tok::l_paren);
14834a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  if (T.consumeOpen()) {
14843896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    Diag(Tok, diag::err_expected_lparen_after)
14853896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor      << (Result.IsIfExists? "__if_exists" : "__if_not_exists");
1486f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return true;
1487f986038beed360c031de8654cfba43a5d3184605Francois Pichet  }
1488f986038beed360c031de8654cfba43a5d3184605Francois Pichet
1489f986038beed360c031de8654cfba43a5d3184605Francois Pichet  // Parse nested-name-specifier.
1490efaa93aaa2653f4eb40e6a22e504a448da94aaf8Douglas Gregor  ParseOptionalCXXScopeSpecifier(Result.SS, ParsedType(),
1491efaa93aaa2653f4eb40e6a22e504a448da94aaf8Douglas Gregor                                 /*EnteringContext=*/false);
1492f986038beed360c031de8654cfba43a5d3184605Francois Pichet
1493f986038beed360c031de8654cfba43a5d3184605Francois Pichet  // Check nested-name specifier.
14943896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  if (Result.SS.isInvalid()) {
14953896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    T.skipToEnd();
1496f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return true;
1497f986038beed360c031de8654cfba43a5d3184605Francois Pichet  }
1498f986038beed360c031de8654cfba43a5d3184605Francois Pichet
1499f986038beed360c031de8654cfba43a5d3184605Francois Pichet  // Parse the unqualified-id.
15003896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  if (ParseUnqualifiedId(Result.SS, false, true, true, ParsedType(),
15013896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor                         Result.Name)) {
15023896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    T.skipToEnd();
1503f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return true;
1504f986038beed360c031de8654cfba43a5d3184605Francois Pichet  }
1505f986038beed360c031de8654cfba43a5d3184605Francois Pichet
15063896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  if (T.consumeClose())
1507f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return true;
15083896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor
1509f986038beed360c031de8654cfba43a5d3184605Francois Pichet  // Check if the symbol exists.
151065019acfc46ffb191fac4e781ac0c4b8d0c8434eDouglas Gregor  switch (Actions.CheckMicrosoftIfExistsSymbol(getCurScope(), Result.KeywordLoc,
151165019acfc46ffb191fac4e781ac0c4b8d0c8434eDouglas Gregor                                               Result.IsIfExists, Result.SS,
15123896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor                                               Result.Name)) {
15133896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case Sema::IER_Exists:
15143896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    Result.Behavior = Result.IsIfExists ? IEB_Parse : IEB_Skip;
15153896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    break;
1516f986038beed360c031de8654cfba43a5d3184605Francois Pichet
15173896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case Sema::IER_DoesNotExist:
15183896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    Result.Behavior = !Result.IsIfExists ? IEB_Parse : IEB_Skip;
15193896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    break;
15203896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor
15213896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case Sema::IER_Dependent:
15223896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    Result.Behavior = IEB_Dependent;
15233896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    break;
152465019acfc46ffb191fac4e781ac0c4b8d0c8434eDouglas Gregor
152565019acfc46ffb191fac4e781ac0c4b8d0c8434eDouglas Gregor  case Sema::IER_Error:
152665019acfc46ffb191fac4e781ac0c4b8d0c8434eDouglas Gregor    return true;
15273896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  }
1528f986038beed360c031de8654cfba43a5d3184605Francois Pichet
1529f986038beed360c031de8654cfba43a5d3184605Francois Pichet  return false;
1530f986038beed360c031de8654cfba43a5d3184605Francois Pichet}
1531f986038beed360c031de8654cfba43a5d3184605Francois Pichet
1532563a645de82231a55e221fe655b7188bf8369662Francois Pichetvoid Parser::ParseMicrosoftIfExistsExternalDeclaration() {
15333896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  IfExistsCondition Result;
1534f986038beed360c031de8654cfba43a5d3184605Francois Pichet  if (ParseMicrosoftIfExistsCondition(Result))
1535f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return;
1536f986038beed360c031de8654cfba43a5d3184605Francois Pichet
15373896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  BalancedDelimiterTracker Braces(*this, tok::l_brace);
15383896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  if (Braces.consumeOpen()) {
1539f986038beed360c031de8654cfba43a5d3184605Francois Pichet    Diag(Tok, diag::err_expected_lbrace);
1540f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return;
1541f986038beed360c031de8654cfba43a5d3184605Francois Pichet  }
1542f986038beed360c031de8654cfba43a5d3184605Francois Pichet
15433896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  switch (Result.Behavior) {
15443896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case IEB_Parse:
15453896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    // Parse declarations below.
15463896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    break;
15473896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor
15483896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case IEB_Dependent:
15493896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    llvm_unreachable("Cannot have a dependent external declaration");
15503896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor
15513896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  case IEB_Skip:
15523896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor    Braces.skipToEnd();
1553f986038beed360c031de8654cfba43a5d3184605Francois Pichet    return;
1554f986038beed360c031de8654cfba43a5d3184605Francois Pichet  }
1555f986038beed360c031de8654cfba43a5d3184605Francois Pichet
15563896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  // Parse the declarations.
15573896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  while (Tok.isNot(tok::r_brace) && Tok.isNot(tok::eof)) {
1558f986038beed360c031de8654cfba43a5d3184605Francois Pichet    ParsedAttributesWithRange attrs(AttrFactory);
1559f986038beed360c031de8654cfba43a5d3184605Francois Pichet    MaybeParseCXX0XAttributes(attrs);
1560f986038beed360c031de8654cfba43a5d3184605Francois Pichet    MaybeParseMicrosoftAttributes(attrs);
1561f986038beed360c031de8654cfba43a5d3184605Francois Pichet    DeclGroupPtrTy Result = ParseExternalDeclaration(attrs);
1562f986038beed360c031de8654cfba43a5d3184605Francois Pichet    if (Result && !getCurScope()->getParent())
1563f986038beed360c031de8654cfba43a5d3184605Francois Pichet      Actions.getASTConsumer().HandleTopLevelDecl(Result.get());
15643896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  }
15653896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  Braces.consumeClose();
1566f986038beed360c031de8654cfba43a5d3184605Francois Pichet}
15676aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor
15686aa52ec6b969faabf3764baf79d89810b8249a7eDouglas GregorParser::DeclGroupPtrTy Parser::ParseModuleImport() {
156965030af6526748ce11534e92f0ccefc44091ba13Douglas Gregor  assert(Tok.is(tok::kw___import_module__) &&
157065030af6526748ce11534e92f0ccefc44091ba13Douglas Gregor         "Improper start to module import");
15716aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor  SourceLocation ImportLoc = ConsumeToken();
15726aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor
15733d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor  llvm::SmallVector<std::pair<IdentifierInfo *, SourceLocation>, 2> Path;
15743d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor
15753d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor  // Parse the module path.
15763d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor  do {
15773d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    if (!Tok.is(tok::identifier)) {
15783d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor      Diag(Tok, diag::err_module_expected_ident);
15793d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor      SkipUntil(tok::semi);
15803d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor      return DeclGroupPtrTy();
15813d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    }
15823d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor
15833d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    // Record this part of the module path.
15843d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    Path.push_back(std::make_pair(Tok.getIdentifierInfo(), Tok.getLocation()));
15853d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    ConsumeToken();
15863d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor
15873d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    if (Tok.is(tok::period)) {
15883d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor      ConsumeToken();
15893d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor      continue;
15903d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    }
15913d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor
15923d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor    break;
15933d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor  } while (true);
15946aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor
15953d3589db579f7695667b913c5043dd264ebe546fDouglas Gregor  DeclResult Import = Actions.ActOnModuleImport(ImportLoc, Path);
15966aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor  ExpectAndConsumeSemi(diag::err_module_expected_semi);
15976aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor  if (Import.isInvalid())
15986aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor    return DeclGroupPtrTy();
15996aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor
16006aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor  return Actions.ConvertDeclToDeclGroup(Import.get());
16016aa52ec6b969faabf3764baf79d89810b8249a7eDouglas Gregor}
16024a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor
16034a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregorbool Parser::BalancedDelimiterTracker::consumeOpen() {
16044a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  // Try to consume the token we are holding
16054a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  if (P.Tok.is(Kind)) {
16064a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    P.QuantityTracker.push(Kind);
16074a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    Cleanup = true;
16084a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    if (P.QuantityTracker.getDepth(Kind) < MaxDepth) {
16094a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      LOpen = P.ConsumeAnyToken();
16104a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      return false;
16114a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    } else {
16124a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      P.Diag(P.Tok, diag::err_parser_impl_limit_overflow);
16134a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      P.SkipUntil(tok::eof);
16144a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    }
16154a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  }
16164a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  return true;
16174a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor}
16184a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor
16194a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregorbool Parser::BalancedDelimiterTracker::expectAndConsume(unsigned DiagID,
16204a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor                                            const char *Msg,
16214a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor                                            tok::TokenKind SkipToToc ) {
16224a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  LOpen = P.Tok.getLocation();
16234a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  if (!P.ExpectAndConsume(Kind, DiagID, Msg, SkipToToc)) {
16244a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    P.QuantityTracker.push(Kind);
16254a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    Cleanup = true;
16264a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    if (P.QuantityTracker.getDepth(Kind) < MaxDepth) {
16274a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      return false;
16284a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    } else {
16294a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      P.Diag(P.Tok, diag::err_parser_impl_limit_overflow);
16304a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      P.SkipUntil(tok::eof);
16314a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    }
16324a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  }
16334a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  return true;
16344a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor}
16354a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor
16364a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregorbool Parser::BalancedDelimiterTracker::consumeClose() {
16374a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  if (P.Tok.is(Close)) {
16384a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    LClose = P.ConsumeAnyToken();
16394a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    if (Cleanup)
16404a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      P.QuantityTracker.pop(Kind);
16414a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor
16424a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    Cleanup = false;
16434a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    return false;
16444a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  } else {
16454a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    const char *LHSName = "unknown";
16464a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    diag::kind DID = diag::err_parse_error;
16474a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    switch (Close) {
16484a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    default: break;
16494a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    case tok::r_paren : LHSName = "("; DID = diag::err_expected_rparen; break;
16504a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    case tok::r_brace : LHSName = "{"; DID = diag::err_expected_rbrace; break;
16514a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    case tok::r_square: LHSName = "["; DID = diag::err_expected_rsquare; break;
16524a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    case tok::greater:  LHSName = "<"; DID = diag::err_expected_greater; break;
16534a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    case tok::greatergreatergreater:
16544a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor                        LHSName = "<<<"; DID = diag::err_expected_ggg; break;
16554a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    }
16564a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    P.Diag(P.Tok, DID);
16574a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    P.Diag(LOpen, diag::note_matching) << LHSName;
16584a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor    if (P.SkipUntil(Close))
16594a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor      LClose = P.Tok.getLocation();
16604a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  }
16614a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor  return true;
16624a8dfb511e8f84b2e38b7a86d8ddf05ac1e1a41bDouglas Gregor}
16633896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor
16643896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregorvoid Parser::BalancedDelimiterTracker::skipToEnd() {
16653896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  P.SkipUntil(Close, false);
16663896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor  Cleanup = false;
16673896fc5d4daaf003e451e797e37de57dd8cf9cd5Douglas Gregor}
1668