1 //===--- PPDirectives.cpp - Directive Handling for Preprocessor -----------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 /// 10 /// \file 11 /// \brief Implements # directive processing for the Preprocessor. 12 /// 13 //===----------------------------------------------------------------------===// 14 15 #include "clang/Lex/Preprocessor.h" 16 #include "clang/Basic/FileManager.h" 17 #include "clang/Basic/SourceManager.h" 18 #include "clang/Lex/CodeCompletionHandler.h" 19 #include "clang/Lex/HeaderSearch.h" 20 #include "clang/Lex/HeaderSearchOptions.h" 21 #include "clang/Lex/LexDiagnostic.h" 22 #include "clang/Lex/LiteralSupport.h" 23 #include "clang/Lex/MacroInfo.h" 24 #include "clang/Lex/ModuleLoader.h" 25 #include "clang/Lex/Pragma.h" 26 #include "llvm/ADT/APInt.h" 27 #include "llvm/Support/ErrorHandling.h" 28 #include "llvm/Support/Path.h" 29 #include "llvm/Support/SaveAndRestore.h" 30 using namespace clang; 31 32 //===----------------------------------------------------------------------===// 33 // Utility Methods for Preprocessor Directive Handling. 34 //===----------------------------------------------------------------------===// 35 36 MacroInfo *Preprocessor::AllocateMacroInfo() { 37 MacroInfoChain *MIChain = BP.Allocate<MacroInfoChain>(); 38 MIChain->Next = MIChainHead; 39 MIChainHead = MIChain; 40 return &MIChain->MI; 41 } 42 43 MacroInfo *Preprocessor::AllocateMacroInfo(SourceLocation L) { 44 MacroInfo *MI = AllocateMacroInfo(); 45 new (MI) MacroInfo(L); 46 return MI; 47 } 48 49 MacroInfo *Preprocessor::AllocateDeserializedMacroInfo(SourceLocation L, 50 unsigned SubModuleID) { 51 static_assert(llvm::AlignOf<MacroInfo>::Alignment >= sizeof(SubModuleID), 52 "alignment for MacroInfo is less than the ID"); 53 DeserializedMacroInfoChain *MIChain = 54 BP.Allocate<DeserializedMacroInfoChain>(); 55 MIChain->Next = DeserialMIChainHead; 56 DeserialMIChainHead = MIChain; 57 58 MacroInfo *MI = &MIChain->MI; 59 new (MI) MacroInfo(L); 60 MI->FromASTFile = true; 61 MI->setOwningModuleID(SubModuleID); 62 return MI; 63 } 64 65 DefMacroDirective * 66 Preprocessor::AllocateDefMacroDirective(MacroInfo *MI, SourceLocation Loc, 67 unsigned ImportedFromModuleID, 68 ArrayRef<unsigned> Overrides) { 69 unsigned NumExtra = (ImportedFromModuleID ? 1 : 0) + Overrides.size(); 70 return new (BP.Allocate(sizeof(DefMacroDirective) + 71 sizeof(unsigned) * NumExtra, 72 llvm::alignOf<DefMacroDirective>())) 73 DefMacroDirective(MI, Loc, ImportedFromModuleID, Overrides); 74 } 75 76 UndefMacroDirective * 77 Preprocessor::AllocateUndefMacroDirective(SourceLocation UndefLoc, 78 unsigned ImportedFromModuleID, 79 ArrayRef<unsigned> Overrides) { 80 unsigned NumExtra = (ImportedFromModuleID ? 1 : 0) + Overrides.size(); 81 return new (BP.Allocate(sizeof(UndefMacroDirective) + 82 sizeof(unsigned) * NumExtra, 83 llvm::alignOf<UndefMacroDirective>())) 84 UndefMacroDirective(UndefLoc, ImportedFromModuleID, Overrides); 85 } 86 87 VisibilityMacroDirective * 88 Preprocessor::AllocateVisibilityMacroDirective(SourceLocation Loc, 89 bool isPublic) { 90 return new (BP) VisibilityMacroDirective(Loc, isPublic); 91 } 92 93 /// \brief Read and discard all tokens remaining on the current line until 94 /// the tok::eod token is found. 95 void Preprocessor::DiscardUntilEndOfDirective() { 96 Token Tmp; 97 do { 98 LexUnexpandedToken(Tmp); 99 assert(Tmp.isNot(tok::eof) && "EOF seen while discarding directive tokens"); 100 } while (Tmp.isNot(tok::eod)); 101 } 102 103 bool Preprocessor::CheckMacroName(Token &MacroNameTok, char isDefineUndef) { 104 // Missing macro name? 105 if (MacroNameTok.is(tok::eod)) 106 return Diag(MacroNameTok, diag::err_pp_missing_macro_name); 107 108 IdentifierInfo *II = MacroNameTok.getIdentifierInfo(); 109 if (!II) { 110 bool Invalid = false; 111 std::string Spelling = getSpelling(MacroNameTok, &Invalid); 112 if (Invalid) 113 return Diag(MacroNameTok, diag::err_pp_macro_not_identifier); 114 II = getIdentifierInfo(Spelling); 115 116 if (!II->isCPlusPlusOperatorKeyword()) 117 return Diag(MacroNameTok, diag::err_pp_macro_not_identifier); 118 119 // C++ 2.5p2: Alternative tokens behave the same as its primary token 120 // except for their spellings. 121 Diag(MacroNameTok, getLangOpts().MicrosoftExt 122 ? diag::ext_pp_operator_used_as_macro_name 123 : diag::err_pp_operator_used_as_macro_name) 124 << II << MacroNameTok.getKind(); 125 126 // Allow #defining |and| and friends for Microsoft compatibility or 127 // recovery when legacy C headers are included in C++. 128 MacroNameTok.setIdentifierInfo(II); 129 } 130 131 if (isDefineUndef && II->getPPKeywordID() == tok::pp_defined) { 132 // Error if defining "defined": C99 6.10.8/4, C++ [cpp.predefined]p4. 133 return Diag(MacroNameTok, diag::err_defined_macro_name); 134 } 135 136 if (isDefineUndef == 2 && II->hasMacroDefinition() && 137 getMacroInfo(II)->isBuiltinMacro()) { 138 // Warn if undefining "__LINE__" and other builtins, per C99 6.10.8/4 139 // and C++ [cpp.predefined]p4], but allow it as an extension. 140 Diag(MacroNameTok, diag::ext_pp_undef_builtin_macro); 141 } 142 143 // Okay, we got a good identifier. 144 return false; 145 } 146 147 /// \brief Lex and validate a macro name, which occurs after a 148 /// \#define or \#undef. 149 /// 150 /// This sets the token kind to eod and discards the rest 151 /// of the macro line if the macro name is invalid. \p isDefineUndef is 1 if 152 /// this is due to a a \#define, 2 if \#undef directive, 0 if it is something 153 /// else (e.g. \#ifdef). 154 void Preprocessor::ReadMacroName(Token &MacroNameTok, char isDefineUndef) { 155 // Read the token, don't allow macro expansion on it. 156 LexUnexpandedToken(MacroNameTok); 157 158 if (MacroNameTok.is(tok::code_completion)) { 159 if (CodeComplete) 160 CodeComplete->CodeCompleteMacroName(isDefineUndef == 1); 161 setCodeCompletionReached(); 162 LexUnexpandedToken(MacroNameTok); 163 } 164 165 if (!CheckMacroName(MacroNameTok, isDefineUndef)) 166 return; 167 168 // Invalid macro name, read and discard the rest of the line and set the 169 // token kind to tok::eod if necessary. 170 if (MacroNameTok.isNot(tok::eod)) { 171 MacroNameTok.setKind(tok::eod); 172 DiscardUntilEndOfDirective(); 173 } 174 } 175 176 /// \brief Ensure that the next token is a tok::eod token. 177 /// 178 /// If not, emit a diagnostic and consume up until the eod. If EnableMacros is 179 /// true, then we consider macros that expand to zero tokens as being ok. 180 void Preprocessor::CheckEndOfDirective(const char *DirType, bool EnableMacros) { 181 Token Tmp; 182 // Lex unexpanded tokens for most directives: macros might expand to zero 183 // tokens, causing us to miss diagnosing invalid lines. Some directives (like 184 // #line) allow empty macros. 185 if (EnableMacros) 186 Lex(Tmp); 187 else 188 LexUnexpandedToken(Tmp); 189 190 // There should be no tokens after the directive, but we allow them as an 191 // extension. 192 while (Tmp.is(tok::comment)) // Skip comments in -C mode. 193 LexUnexpandedToken(Tmp); 194 195 if (Tmp.isNot(tok::eod)) { 196 // Add a fixit in GNU/C99/C++ mode. Don't offer a fixit for strict-C89, 197 // or if this is a macro-style preprocessing directive, because it is more 198 // trouble than it is worth to insert /**/ and check that there is no /**/ 199 // in the range also. 200 FixItHint Hint; 201 if ((LangOpts.GNUMode || LangOpts.C99 || LangOpts.CPlusPlus) && 202 !CurTokenLexer) 203 Hint = FixItHint::CreateInsertion(Tmp.getLocation(),"//"); 204 Diag(Tmp, diag::ext_pp_extra_tokens_at_eol) << DirType << Hint; 205 DiscardUntilEndOfDirective(); 206 } 207 } 208 209 210 211 /// SkipExcludedConditionalBlock - We just read a \#if or related directive and 212 /// decided that the subsequent tokens are in the \#if'd out portion of the 213 /// file. Lex the rest of the file, until we see an \#endif. If 214 /// FoundNonSkipPortion is true, then we have already emitted code for part of 215 /// this \#if directive, so \#else/\#elif blocks should never be entered. 216 /// If ElseOk is true, then \#else directives are ok, if not, then we have 217 /// already seen one so a \#else directive is a duplicate. When this returns, 218 /// the caller can lex the first valid token. 219 void Preprocessor::SkipExcludedConditionalBlock(SourceLocation IfTokenLoc, 220 bool FoundNonSkipPortion, 221 bool FoundElse, 222 SourceLocation ElseLoc) { 223 ++NumSkipped; 224 assert(!CurTokenLexer && CurPPLexer && "Lexing a macro, not a file?"); 225 226 CurPPLexer->pushConditionalLevel(IfTokenLoc, /*isSkipping*/false, 227 FoundNonSkipPortion, FoundElse); 228 229 if (CurPTHLexer) { 230 PTHSkipExcludedConditionalBlock(); 231 return; 232 } 233 234 // Enter raw mode to disable identifier lookup (and thus macro expansion), 235 // disabling warnings, etc. 236 CurPPLexer->LexingRawMode = true; 237 Token Tok; 238 while (1) { 239 CurLexer->Lex(Tok); 240 241 if (Tok.is(tok::code_completion)) { 242 if (CodeComplete) 243 CodeComplete->CodeCompleteInConditionalExclusion(); 244 setCodeCompletionReached(); 245 continue; 246 } 247 248 // If this is the end of the buffer, we have an error. 249 if (Tok.is(tok::eof)) { 250 // Emit errors for each unterminated conditional on the stack, including 251 // the current one. 252 while (!CurPPLexer->ConditionalStack.empty()) { 253 if (CurLexer->getFileLoc() != CodeCompletionFileLoc) 254 Diag(CurPPLexer->ConditionalStack.back().IfLoc, 255 diag::err_pp_unterminated_conditional); 256 CurPPLexer->ConditionalStack.pop_back(); 257 } 258 259 // Just return and let the caller lex after this #include. 260 break; 261 } 262 263 // If this token is not a preprocessor directive, just skip it. 264 if (Tok.isNot(tok::hash) || !Tok.isAtStartOfLine()) 265 continue; 266 267 // We just parsed a # character at the start of a line, so we're in 268 // directive mode. Tell the lexer this so any newlines we see will be 269 // converted into an EOD token (this terminates the macro). 270 CurPPLexer->ParsingPreprocessorDirective = true; 271 if (CurLexer) CurLexer->SetKeepWhitespaceMode(false); 272 273 274 // Read the next token, the directive flavor. 275 LexUnexpandedToken(Tok); 276 277 // If this isn't an identifier directive (e.g. is "# 1\n" or "#\n", or 278 // something bogus), skip it. 279 if (Tok.isNot(tok::raw_identifier)) { 280 CurPPLexer->ParsingPreprocessorDirective = false; 281 // Restore comment saving mode. 282 if (CurLexer) CurLexer->resetExtendedTokenMode(); 283 continue; 284 } 285 286 // If the first letter isn't i or e, it isn't intesting to us. We know that 287 // this is safe in the face of spelling differences, because there is no way 288 // to spell an i/e in a strange way that is another letter. Skipping this 289 // allows us to avoid looking up the identifier info for #define/#undef and 290 // other common directives. 291 StringRef RI = Tok.getRawIdentifier(); 292 293 char FirstChar = RI[0]; 294 if (FirstChar >= 'a' && FirstChar <= 'z' && 295 FirstChar != 'i' && FirstChar != 'e') { 296 CurPPLexer->ParsingPreprocessorDirective = false; 297 // Restore comment saving mode. 298 if (CurLexer) CurLexer->resetExtendedTokenMode(); 299 continue; 300 } 301 302 // Get the identifier name without trigraphs or embedded newlines. Note 303 // that we can't use Tok.getIdentifierInfo() because its lookup is disabled 304 // when skipping. 305 char DirectiveBuf[20]; 306 StringRef Directive; 307 if (!Tok.needsCleaning() && RI.size() < 20) { 308 Directive = RI; 309 } else { 310 std::string DirectiveStr = getSpelling(Tok); 311 unsigned IdLen = DirectiveStr.size(); 312 if (IdLen >= 20) { 313 CurPPLexer->ParsingPreprocessorDirective = false; 314 // Restore comment saving mode. 315 if (CurLexer) CurLexer->resetExtendedTokenMode(); 316 continue; 317 } 318 memcpy(DirectiveBuf, &DirectiveStr[0], IdLen); 319 Directive = StringRef(DirectiveBuf, IdLen); 320 } 321 322 if (Directive.startswith("if")) { 323 StringRef Sub = Directive.substr(2); 324 if (Sub.empty() || // "if" 325 Sub == "def" || // "ifdef" 326 Sub == "ndef") { // "ifndef" 327 // We know the entire #if/#ifdef/#ifndef block will be skipped, don't 328 // bother parsing the condition. 329 DiscardUntilEndOfDirective(); 330 CurPPLexer->pushConditionalLevel(Tok.getLocation(), /*wasskipping*/true, 331 /*foundnonskip*/false, 332 /*foundelse*/false); 333 } 334 } else if (Directive[0] == 'e') { 335 StringRef Sub = Directive.substr(1); 336 if (Sub == "ndif") { // "endif" 337 PPConditionalInfo CondInfo; 338 CondInfo.WasSkipping = true; // Silence bogus warning. 339 bool InCond = CurPPLexer->popConditionalLevel(CondInfo); 340 (void)InCond; // Silence warning in no-asserts mode. 341 assert(!InCond && "Can't be skipping if not in a conditional!"); 342 343 // If we popped the outermost skipping block, we're done skipping! 344 if (!CondInfo.WasSkipping) { 345 // Restore the value of LexingRawMode so that trailing comments 346 // are handled correctly, if we've reached the outermost block. 347 CurPPLexer->LexingRawMode = false; 348 CheckEndOfDirective("endif"); 349 CurPPLexer->LexingRawMode = true; 350 if (Callbacks) 351 Callbacks->Endif(Tok.getLocation(), CondInfo.IfLoc); 352 break; 353 } else { 354 DiscardUntilEndOfDirective(); 355 } 356 } else if (Sub == "lse") { // "else". 357 // #else directive in a skipping conditional. If not in some other 358 // skipping conditional, and if #else hasn't already been seen, enter it 359 // as a non-skipping conditional. 360 PPConditionalInfo &CondInfo = CurPPLexer->peekConditionalLevel(); 361 362 // If this is a #else with a #else before it, report the error. 363 if (CondInfo.FoundElse) Diag(Tok, diag::pp_err_else_after_else); 364 365 // Note that we've seen a #else in this conditional. 366 CondInfo.FoundElse = true; 367 368 // If the conditional is at the top level, and the #if block wasn't 369 // entered, enter the #else block now. 370 if (!CondInfo.WasSkipping && !CondInfo.FoundNonSkip) { 371 CondInfo.FoundNonSkip = true; 372 // Restore the value of LexingRawMode so that trailing comments 373 // are handled correctly. 374 CurPPLexer->LexingRawMode = false; 375 CheckEndOfDirective("else"); 376 CurPPLexer->LexingRawMode = true; 377 if (Callbacks) 378 Callbacks->Else(Tok.getLocation(), CondInfo.IfLoc); 379 break; 380 } else { 381 DiscardUntilEndOfDirective(); // C99 6.10p4. 382 } 383 } else if (Sub == "lif") { // "elif". 384 PPConditionalInfo &CondInfo = CurPPLexer->peekConditionalLevel(); 385 386 // If this is a #elif with a #else before it, report the error. 387 if (CondInfo.FoundElse) Diag(Tok, diag::pp_err_elif_after_else); 388 389 // If this is in a skipping block or if we're already handled this #if 390 // block, don't bother parsing the condition. 391 if (CondInfo.WasSkipping || CondInfo.FoundNonSkip) { 392 DiscardUntilEndOfDirective(); 393 } else { 394 const SourceLocation CondBegin = CurPPLexer->getSourceLocation(); 395 // Restore the value of LexingRawMode so that identifiers are 396 // looked up, etc, inside the #elif expression. 397 assert(CurPPLexer->LexingRawMode && "We have to be skipping here!"); 398 CurPPLexer->LexingRawMode = false; 399 IdentifierInfo *IfNDefMacro = nullptr; 400 const bool CondValue = EvaluateDirectiveExpression(IfNDefMacro); 401 CurPPLexer->LexingRawMode = true; 402 if (Callbacks) { 403 const SourceLocation CondEnd = CurPPLexer->getSourceLocation(); 404 Callbacks->Elif(Tok.getLocation(), 405 SourceRange(CondBegin, CondEnd), 406 (CondValue ? PPCallbacks::CVK_True : PPCallbacks::CVK_False), CondInfo.IfLoc); 407 } 408 // If this condition is true, enter it! 409 if (CondValue) { 410 CondInfo.FoundNonSkip = true; 411 break; 412 } 413 } 414 } 415 } 416 417 CurPPLexer->ParsingPreprocessorDirective = false; 418 // Restore comment saving mode. 419 if (CurLexer) CurLexer->resetExtendedTokenMode(); 420 } 421 422 // Finally, if we are out of the conditional (saw an #endif or ran off the end 423 // of the file, just stop skipping and return to lexing whatever came after 424 // the #if block. 425 CurPPLexer->LexingRawMode = false; 426 427 if (Callbacks) { 428 SourceLocation BeginLoc = ElseLoc.isValid() ? ElseLoc : IfTokenLoc; 429 Callbacks->SourceRangeSkipped(SourceRange(BeginLoc, Tok.getLocation())); 430 } 431 } 432 433 void Preprocessor::PTHSkipExcludedConditionalBlock() { 434 435 while (1) { 436 assert(CurPTHLexer); 437 assert(CurPTHLexer->LexingRawMode == false); 438 439 // Skip to the next '#else', '#elif', or #endif. 440 if (CurPTHLexer->SkipBlock()) { 441 // We have reached an #endif. Both the '#' and 'endif' tokens 442 // have been consumed by the PTHLexer. Just pop off the condition level. 443 PPConditionalInfo CondInfo; 444 bool InCond = CurPTHLexer->popConditionalLevel(CondInfo); 445 (void)InCond; // Silence warning in no-asserts mode. 446 assert(!InCond && "Can't be skipping if not in a conditional!"); 447 break; 448 } 449 450 // We have reached a '#else' or '#elif'. Lex the next token to get 451 // the directive flavor. 452 Token Tok; 453 LexUnexpandedToken(Tok); 454 455 // We can actually look up the IdentifierInfo here since we aren't in 456 // raw mode. 457 tok::PPKeywordKind K = Tok.getIdentifierInfo()->getPPKeywordID(); 458 459 if (K == tok::pp_else) { 460 // #else: Enter the else condition. We aren't in a nested condition 461 // since we skip those. We're always in the one matching the last 462 // blocked we skipped. 463 PPConditionalInfo &CondInfo = CurPTHLexer->peekConditionalLevel(); 464 // Note that we've seen a #else in this conditional. 465 CondInfo.FoundElse = true; 466 467 // If the #if block wasn't entered then enter the #else block now. 468 if (!CondInfo.FoundNonSkip) { 469 CondInfo.FoundNonSkip = true; 470 471 // Scan until the eod token. 472 CurPTHLexer->ParsingPreprocessorDirective = true; 473 DiscardUntilEndOfDirective(); 474 CurPTHLexer->ParsingPreprocessorDirective = false; 475 476 break; 477 } 478 479 // Otherwise skip this block. 480 continue; 481 } 482 483 assert(K == tok::pp_elif); 484 PPConditionalInfo &CondInfo = CurPTHLexer->peekConditionalLevel(); 485 486 // If this is a #elif with a #else before it, report the error. 487 if (CondInfo.FoundElse) 488 Diag(Tok, diag::pp_err_elif_after_else); 489 490 // If this is in a skipping block or if we're already handled this #if 491 // block, don't bother parsing the condition. We just skip this block. 492 if (CondInfo.FoundNonSkip) 493 continue; 494 495 // Evaluate the condition of the #elif. 496 IdentifierInfo *IfNDefMacro = nullptr; 497 CurPTHLexer->ParsingPreprocessorDirective = true; 498 bool ShouldEnter = EvaluateDirectiveExpression(IfNDefMacro); 499 CurPTHLexer->ParsingPreprocessorDirective = false; 500 501 // If this condition is true, enter it! 502 if (ShouldEnter) { 503 CondInfo.FoundNonSkip = true; 504 break; 505 } 506 507 // Otherwise, skip this block and go to the next one. 508 continue; 509 } 510 } 511 512 Module *Preprocessor::getModuleForLocation(SourceLocation FilenameLoc) { 513 ModuleMap &ModMap = HeaderInfo.getModuleMap(); 514 if (SourceMgr.isInMainFile(FilenameLoc)) { 515 if (Module *CurMod = getCurrentModule()) 516 return CurMod; // Compiling a module. 517 return HeaderInfo.getModuleMap().SourceModule; // Compiling a source. 518 } 519 // Try to determine the module of the include directive. 520 // FIXME: Look into directly passing the FileEntry from LookupFile instead. 521 FileID IDOfIncl = SourceMgr.getFileID(SourceMgr.getExpansionLoc(FilenameLoc)); 522 if (const FileEntry *EntryOfIncl = SourceMgr.getFileEntryForID(IDOfIncl)) { 523 // The include comes from a file. 524 return ModMap.findModuleForHeader(EntryOfIncl).getModule(); 525 } else { 526 // The include does not come from a file, 527 // so it is probably a module compilation. 528 return getCurrentModule(); 529 } 530 } 531 532 const FileEntry *Preprocessor::LookupFile( 533 SourceLocation FilenameLoc, 534 StringRef Filename, 535 bool isAngled, 536 const DirectoryLookup *FromDir, 537 const DirectoryLookup *&CurDir, 538 SmallVectorImpl<char> *SearchPath, 539 SmallVectorImpl<char> *RelativePath, 540 ModuleMap::KnownHeader *SuggestedModule, 541 bool SkipCache) { 542 // If the header lookup mechanism may be relative to the current inclusion 543 // stack, record the parent #includes. 544 SmallVector<std::pair<const FileEntry *, const DirectoryEntry *>, 16> 545 Includers; 546 if (!FromDir) { 547 FileID FID = getCurrentFileLexer()->getFileID(); 548 const FileEntry *FileEnt = SourceMgr.getFileEntryForID(FID); 549 550 // If there is no file entry associated with this file, it must be the 551 // predefines buffer. Any other file is not lexed with a normal lexer, so 552 // it won't be scanned for preprocessor directives. If we have the 553 // predefines buffer, resolve #include references (which come from the 554 // -include command line argument) from the current working directory 555 // instead of relative to the main file. 556 if (!FileEnt) { 557 FileEnt = SourceMgr.getFileEntryForID(SourceMgr.getMainFileID()); 558 if (FileEnt) 559 Includers.push_back(std::make_pair(FileEnt, FileMgr.getDirectory("."))); 560 } else { 561 Includers.push_back(std::make_pair(FileEnt, FileEnt->getDir())); 562 } 563 564 // MSVC searches the current include stack from top to bottom for 565 // headers included by quoted include directives. 566 // See: http://msdn.microsoft.com/en-us/library/36k2cdd4.aspx 567 if (LangOpts.MSVCCompat && !isAngled) { 568 for (unsigned i = 0, e = IncludeMacroStack.size(); i != e; ++i) { 569 IncludeStackInfo &ISEntry = IncludeMacroStack[e - i - 1]; 570 if (IsFileLexer(ISEntry)) 571 if ((FileEnt = SourceMgr.getFileEntryForID( 572 ISEntry.ThePPLexer->getFileID()))) 573 Includers.push_back(std::make_pair(FileEnt, FileEnt->getDir())); 574 } 575 } 576 } 577 578 // Do a standard file entry lookup. 579 CurDir = CurDirLookup; 580 const FileEntry *FE = HeaderInfo.LookupFile( 581 Filename, FilenameLoc, isAngled, FromDir, CurDir, Includers, SearchPath, 582 RelativePath, SuggestedModule, SkipCache); 583 if (FE) { 584 if (SuggestedModule && !LangOpts.AsmPreprocessor) 585 HeaderInfo.getModuleMap().diagnoseHeaderInclusion( 586 getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE); 587 return FE; 588 } 589 590 const FileEntry *CurFileEnt; 591 // Otherwise, see if this is a subframework header. If so, this is relative 592 // to one of the headers on the #include stack. Walk the list of the current 593 // headers on the #include stack and pass them to HeaderInfo. 594 if (IsFileLexer()) { 595 if ((CurFileEnt = SourceMgr.getFileEntryForID(CurPPLexer->getFileID()))) { 596 if ((FE = HeaderInfo.LookupSubframeworkHeader(Filename, CurFileEnt, 597 SearchPath, RelativePath, 598 SuggestedModule))) { 599 if (SuggestedModule && !LangOpts.AsmPreprocessor) 600 HeaderInfo.getModuleMap().diagnoseHeaderInclusion( 601 getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE); 602 return FE; 603 } 604 } 605 } 606 607 for (unsigned i = 0, e = IncludeMacroStack.size(); i != e; ++i) { 608 IncludeStackInfo &ISEntry = IncludeMacroStack[e-i-1]; 609 if (IsFileLexer(ISEntry)) { 610 if ((CurFileEnt = 611 SourceMgr.getFileEntryForID(ISEntry.ThePPLexer->getFileID()))) { 612 if ((FE = HeaderInfo.LookupSubframeworkHeader( 613 Filename, CurFileEnt, SearchPath, RelativePath, 614 SuggestedModule))) { 615 if (SuggestedModule && !LangOpts.AsmPreprocessor) 616 HeaderInfo.getModuleMap().diagnoseHeaderInclusion( 617 getModuleForLocation(FilenameLoc), FilenameLoc, Filename, FE); 618 return FE; 619 } 620 } 621 } 622 } 623 624 // Otherwise, we really couldn't find the file. 625 return nullptr; 626 } 627 628 629 //===----------------------------------------------------------------------===// 630 // Preprocessor Directive Handling. 631 //===----------------------------------------------------------------------===// 632 633 class Preprocessor::ResetMacroExpansionHelper { 634 public: 635 ResetMacroExpansionHelper(Preprocessor *pp) 636 : PP(pp), save(pp->DisableMacroExpansion) { 637 if (pp->MacroExpansionInDirectivesOverride) 638 pp->DisableMacroExpansion = false; 639 } 640 ~ResetMacroExpansionHelper() { 641 PP->DisableMacroExpansion = save; 642 } 643 private: 644 Preprocessor *PP; 645 bool save; 646 }; 647 648 /// HandleDirective - This callback is invoked when the lexer sees a # token 649 /// at the start of a line. This consumes the directive, modifies the 650 /// lexer/preprocessor state, and advances the lexer(s) so that the next token 651 /// read is the correct one. 652 void Preprocessor::HandleDirective(Token &Result) { 653 // FIXME: Traditional: # with whitespace before it not recognized by K&R? 654 655 // We just parsed a # character at the start of a line, so we're in directive 656 // mode. Tell the lexer this so any newlines we see will be converted into an 657 // EOD token (which terminates the directive). 658 CurPPLexer->ParsingPreprocessorDirective = true; 659 if (CurLexer) CurLexer->SetKeepWhitespaceMode(false); 660 661 bool ImmediatelyAfterTopLevelIfndef = 662 CurPPLexer->MIOpt.getImmediatelyAfterTopLevelIfndef(); 663 CurPPLexer->MIOpt.resetImmediatelyAfterTopLevelIfndef(); 664 665 ++NumDirectives; 666 667 // We are about to read a token. For the multiple-include optimization FA to 668 // work, we have to remember if we had read any tokens *before* this 669 // pp-directive. 670 bool ReadAnyTokensBeforeDirective =CurPPLexer->MIOpt.getHasReadAnyTokensVal(); 671 672 // Save the '#' token in case we need to return it later. 673 Token SavedHash = Result; 674 675 // Read the next token, the directive flavor. This isn't expanded due to 676 // C99 6.10.3p8. 677 LexUnexpandedToken(Result); 678 679 // C99 6.10.3p11: Is this preprocessor directive in macro invocation? e.g.: 680 // #define A(x) #x 681 // A(abc 682 // #warning blah 683 // def) 684 // If so, the user is relying on undefined behavior, emit a diagnostic. Do 685 // not support this for #include-like directives, since that can result in 686 // terrible diagnostics, and does not work in GCC. 687 if (InMacroArgs) { 688 if (IdentifierInfo *II = Result.getIdentifierInfo()) { 689 switch (II->getPPKeywordID()) { 690 case tok::pp_include: 691 case tok::pp_import: 692 case tok::pp_include_next: 693 case tok::pp___include_macros: 694 Diag(Result, diag::err_embedded_include) << II->getName(); 695 DiscardUntilEndOfDirective(); 696 return; 697 default: 698 break; 699 } 700 } 701 Diag(Result, diag::ext_embedded_directive); 702 } 703 704 // Temporarily enable macro expansion if set so 705 // and reset to previous state when returning from this function. 706 ResetMacroExpansionHelper helper(this); 707 708 switch (Result.getKind()) { 709 case tok::eod: 710 return; // null directive. 711 case tok::code_completion: 712 if (CodeComplete) 713 CodeComplete->CodeCompleteDirective( 714 CurPPLexer->getConditionalStackDepth() > 0); 715 setCodeCompletionReached(); 716 return; 717 case tok::numeric_constant: // # 7 GNU line marker directive. 718 if (getLangOpts().AsmPreprocessor) 719 break; // # 4 is not a preprocessor directive in .S files. 720 return HandleDigitDirective(Result); 721 default: 722 IdentifierInfo *II = Result.getIdentifierInfo(); 723 if (!II) break; // Not an identifier. 724 725 // Ask what the preprocessor keyword ID is. 726 switch (II->getPPKeywordID()) { 727 default: break; 728 // C99 6.10.1 - Conditional Inclusion. 729 case tok::pp_if: 730 return HandleIfDirective(Result, ReadAnyTokensBeforeDirective); 731 case tok::pp_ifdef: 732 return HandleIfdefDirective(Result, false, true/*not valid for miopt*/); 733 case tok::pp_ifndef: 734 return HandleIfdefDirective(Result, true, ReadAnyTokensBeforeDirective); 735 case tok::pp_elif: 736 return HandleElifDirective(Result); 737 case tok::pp_else: 738 return HandleElseDirective(Result); 739 case tok::pp_endif: 740 return HandleEndifDirective(Result); 741 742 // C99 6.10.2 - Source File Inclusion. 743 case tok::pp_include: 744 // Handle #include. 745 return HandleIncludeDirective(SavedHash.getLocation(), Result); 746 case tok::pp___include_macros: 747 // Handle -imacros. 748 return HandleIncludeMacrosDirective(SavedHash.getLocation(), Result); 749 750 // C99 6.10.3 - Macro Replacement. 751 case tok::pp_define: 752 return HandleDefineDirective(Result, ImmediatelyAfterTopLevelIfndef); 753 case tok::pp_undef: 754 return HandleUndefDirective(Result); 755 756 // C99 6.10.4 - Line Control. 757 case tok::pp_line: 758 return HandleLineDirective(Result); 759 760 // C99 6.10.5 - Error Directive. 761 case tok::pp_error: 762 return HandleUserDiagnosticDirective(Result, false); 763 764 // C99 6.10.6 - Pragma Directive. 765 case tok::pp_pragma: 766 return HandlePragmaDirective(SavedHash.getLocation(), PIK_HashPragma); 767 768 // GNU Extensions. 769 case tok::pp_import: 770 return HandleImportDirective(SavedHash.getLocation(), Result); 771 case tok::pp_include_next: 772 return HandleIncludeNextDirective(SavedHash.getLocation(), Result); 773 774 case tok::pp_warning: 775 Diag(Result, diag::ext_pp_warning_directive); 776 return HandleUserDiagnosticDirective(Result, true); 777 case tok::pp_ident: 778 return HandleIdentSCCSDirective(Result); 779 case tok::pp_sccs: 780 return HandleIdentSCCSDirective(Result); 781 case tok::pp_assert: 782 //isExtension = true; // FIXME: implement #assert 783 break; 784 case tok::pp_unassert: 785 //isExtension = true; // FIXME: implement #unassert 786 break; 787 788 case tok::pp___public_macro: 789 if (getLangOpts().Modules) 790 return HandleMacroPublicDirective(Result); 791 break; 792 793 case tok::pp___private_macro: 794 if (getLangOpts().Modules) 795 return HandleMacroPrivateDirective(Result); 796 break; 797 } 798 break; 799 } 800 801 // If this is a .S file, treat unknown # directives as non-preprocessor 802 // directives. This is important because # may be a comment or introduce 803 // various pseudo-ops. Just return the # token and push back the following 804 // token to be lexed next time. 805 if (getLangOpts().AsmPreprocessor) { 806 Token *Toks = new Token[2]; 807 // Return the # and the token after it. 808 Toks[0] = SavedHash; 809 Toks[1] = Result; 810 811 // If the second token is a hashhash token, then we need to translate it to 812 // unknown so the token lexer doesn't try to perform token pasting. 813 if (Result.is(tok::hashhash)) 814 Toks[1].setKind(tok::unknown); 815 816 // Enter this token stream so that we re-lex the tokens. Make sure to 817 // enable macro expansion, in case the token after the # is an identifier 818 // that is expanded. 819 EnterTokenStream(Toks, 2, false, true); 820 return; 821 } 822 823 // If we reached here, the preprocessing token is not valid! 824 Diag(Result, diag::err_pp_invalid_directive); 825 826 // Read the rest of the PP line. 827 DiscardUntilEndOfDirective(); 828 829 // Okay, we're done parsing the directive. 830 } 831 832 /// GetLineValue - Convert a numeric token into an unsigned value, emitting 833 /// Diagnostic DiagID if it is invalid, and returning the value in Val. 834 static bool GetLineValue(Token &DigitTok, unsigned &Val, 835 unsigned DiagID, Preprocessor &PP, 836 bool IsGNULineDirective=false) { 837 if (DigitTok.isNot(tok::numeric_constant)) { 838 PP.Diag(DigitTok, DiagID); 839 840 if (DigitTok.isNot(tok::eod)) 841 PP.DiscardUntilEndOfDirective(); 842 return true; 843 } 844 845 SmallString<64> IntegerBuffer; 846 IntegerBuffer.resize(DigitTok.getLength()); 847 const char *DigitTokBegin = &IntegerBuffer[0]; 848 bool Invalid = false; 849 unsigned ActualLength = PP.getSpelling(DigitTok, DigitTokBegin, &Invalid); 850 if (Invalid) 851 return true; 852 853 // Verify that we have a simple digit-sequence, and compute the value. This 854 // is always a simple digit string computed in decimal, so we do this manually 855 // here. 856 Val = 0; 857 for (unsigned i = 0; i != ActualLength; ++i) { 858 // C++1y [lex.fcon]p1: 859 // Optional separating single quotes in a digit-sequence are ignored 860 if (DigitTokBegin[i] == '\'') 861 continue; 862 863 if (!isDigit(DigitTokBegin[i])) { 864 PP.Diag(PP.AdvanceToTokenCharacter(DigitTok.getLocation(), i), 865 diag::err_pp_line_digit_sequence) << IsGNULineDirective; 866 PP.DiscardUntilEndOfDirective(); 867 return true; 868 } 869 870 unsigned NextVal = Val*10+(DigitTokBegin[i]-'0'); 871 if (NextVal < Val) { // overflow. 872 PP.Diag(DigitTok, DiagID); 873 PP.DiscardUntilEndOfDirective(); 874 return true; 875 } 876 Val = NextVal; 877 } 878 879 if (DigitTokBegin[0] == '0' && Val) 880 PP.Diag(DigitTok.getLocation(), diag::warn_pp_line_decimal) 881 << IsGNULineDirective; 882 883 return false; 884 } 885 886 /// \brief Handle a \#line directive: C99 6.10.4. 887 /// 888 /// The two acceptable forms are: 889 /// \verbatim 890 /// # line digit-sequence 891 /// # line digit-sequence "s-char-sequence" 892 /// \endverbatim 893 void Preprocessor::HandleLineDirective(Token &Tok) { 894 // Read the line # and string argument. Per C99 6.10.4p5, these tokens are 895 // expanded. 896 Token DigitTok; 897 Lex(DigitTok); 898 899 // Validate the number and convert it to an unsigned. 900 unsigned LineNo; 901 if (GetLineValue(DigitTok, LineNo, diag::err_pp_line_requires_integer,*this)) 902 return; 903 904 if (LineNo == 0) 905 Diag(DigitTok, diag::ext_pp_line_zero); 906 907 // Enforce C99 6.10.4p3: "The digit sequence shall not specify ... a 908 // number greater than 2147483647". C90 requires that the line # be <= 32767. 909 unsigned LineLimit = 32768U; 910 if (LangOpts.C99 || LangOpts.CPlusPlus11) 911 LineLimit = 2147483648U; 912 if (LineNo >= LineLimit) 913 Diag(DigitTok, diag::ext_pp_line_too_big) << LineLimit; 914 else if (LangOpts.CPlusPlus11 && LineNo >= 32768U) 915 Diag(DigitTok, diag::warn_cxx98_compat_pp_line_too_big); 916 917 int FilenameID = -1; 918 Token StrTok; 919 Lex(StrTok); 920 921 // If the StrTok is "eod", then it wasn't present. Otherwise, it must be a 922 // string followed by eod. 923 if (StrTok.is(tok::eod)) 924 ; // ok 925 else if (StrTok.isNot(tok::string_literal)) { 926 Diag(StrTok, diag::err_pp_line_invalid_filename); 927 return DiscardUntilEndOfDirective(); 928 } else if (StrTok.hasUDSuffix()) { 929 Diag(StrTok, diag::err_invalid_string_udl); 930 return DiscardUntilEndOfDirective(); 931 } else { 932 // Parse and validate the string, converting it into a unique ID. 933 StringLiteralParser Literal(StrTok, *this); 934 assert(Literal.isAscii() && "Didn't allow wide strings in"); 935 if (Literal.hadError) 936 return DiscardUntilEndOfDirective(); 937 if (Literal.Pascal) { 938 Diag(StrTok, diag::err_pp_linemarker_invalid_filename); 939 return DiscardUntilEndOfDirective(); 940 } 941 FilenameID = SourceMgr.getLineTableFilenameID(Literal.GetString()); 942 943 // Verify that there is nothing after the string, other than EOD. Because 944 // of C99 6.10.4p5, macros that expand to empty tokens are ok. 945 CheckEndOfDirective("line", true); 946 } 947 948 SourceMgr.AddLineNote(DigitTok.getLocation(), LineNo, FilenameID); 949 950 if (Callbacks) 951 Callbacks->FileChanged(CurPPLexer->getSourceLocation(), 952 PPCallbacks::RenameFile, 953 SrcMgr::C_User); 954 } 955 956 /// ReadLineMarkerFlags - Parse and validate any flags at the end of a GNU line 957 /// marker directive. 958 static bool ReadLineMarkerFlags(bool &IsFileEntry, bool &IsFileExit, 959 bool &IsSystemHeader, bool &IsExternCHeader, 960 Preprocessor &PP) { 961 unsigned FlagVal; 962 Token FlagTok; 963 PP.Lex(FlagTok); 964 if (FlagTok.is(tok::eod)) return false; 965 if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag, PP)) 966 return true; 967 968 if (FlagVal == 1) { 969 IsFileEntry = true; 970 971 PP.Lex(FlagTok); 972 if (FlagTok.is(tok::eod)) return false; 973 if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag,PP)) 974 return true; 975 } else if (FlagVal == 2) { 976 IsFileExit = true; 977 978 SourceManager &SM = PP.getSourceManager(); 979 // If we are leaving the current presumed file, check to make sure the 980 // presumed include stack isn't empty! 981 FileID CurFileID = 982 SM.getDecomposedExpansionLoc(FlagTok.getLocation()).first; 983 PresumedLoc PLoc = SM.getPresumedLoc(FlagTok.getLocation()); 984 if (PLoc.isInvalid()) 985 return true; 986 987 // If there is no include loc (main file) or if the include loc is in a 988 // different physical file, then we aren't in a "1" line marker flag region. 989 SourceLocation IncLoc = PLoc.getIncludeLoc(); 990 if (IncLoc.isInvalid() || 991 SM.getDecomposedExpansionLoc(IncLoc).first != CurFileID) { 992 PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_pop); 993 PP.DiscardUntilEndOfDirective(); 994 return true; 995 } 996 997 PP.Lex(FlagTok); 998 if (FlagTok.is(tok::eod)) return false; 999 if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag,PP)) 1000 return true; 1001 } 1002 1003 // We must have 3 if there are still flags. 1004 if (FlagVal != 3) { 1005 PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag); 1006 PP.DiscardUntilEndOfDirective(); 1007 return true; 1008 } 1009 1010 IsSystemHeader = true; 1011 1012 PP.Lex(FlagTok); 1013 if (FlagTok.is(tok::eod)) return false; 1014 if (GetLineValue(FlagTok, FlagVal, diag::err_pp_linemarker_invalid_flag, PP)) 1015 return true; 1016 1017 // We must have 4 if there is yet another flag. 1018 if (FlagVal != 4) { 1019 PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag); 1020 PP.DiscardUntilEndOfDirective(); 1021 return true; 1022 } 1023 1024 IsExternCHeader = true; 1025 1026 PP.Lex(FlagTok); 1027 if (FlagTok.is(tok::eod)) return false; 1028 1029 // There are no more valid flags here. 1030 PP.Diag(FlagTok, diag::err_pp_linemarker_invalid_flag); 1031 PP.DiscardUntilEndOfDirective(); 1032 return true; 1033 } 1034 1035 /// HandleDigitDirective - Handle a GNU line marker directive, whose syntax is 1036 /// one of the following forms: 1037 /// 1038 /// # 42 1039 /// # 42 "file" ('1' | '2')? 1040 /// # 42 "file" ('1' | '2')? '3' '4'? 1041 /// 1042 void Preprocessor::HandleDigitDirective(Token &DigitTok) { 1043 // Validate the number and convert it to an unsigned. GNU does not have a 1044 // line # limit other than it fit in 32-bits. 1045 unsigned LineNo; 1046 if (GetLineValue(DigitTok, LineNo, diag::err_pp_linemarker_requires_integer, 1047 *this, true)) 1048 return; 1049 1050 Token StrTok; 1051 Lex(StrTok); 1052 1053 bool IsFileEntry = false, IsFileExit = false; 1054 bool IsSystemHeader = false, IsExternCHeader = false; 1055 int FilenameID = -1; 1056 1057 // If the StrTok is "eod", then it wasn't present. Otherwise, it must be a 1058 // string followed by eod. 1059 if (StrTok.is(tok::eod)) 1060 ; // ok 1061 else if (StrTok.isNot(tok::string_literal)) { 1062 Diag(StrTok, diag::err_pp_linemarker_invalid_filename); 1063 return DiscardUntilEndOfDirective(); 1064 } else if (StrTok.hasUDSuffix()) { 1065 Diag(StrTok, diag::err_invalid_string_udl); 1066 return DiscardUntilEndOfDirective(); 1067 } else { 1068 // Parse and validate the string, converting it into a unique ID. 1069 StringLiteralParser Literal(StrTok, *this); 1070 assert(Literal.isAscii() && "Didn't allow wide strings in"); 1071 if (Literal.hadError) 1072 return DiscardUntilEndOfDirective(); 1073 if (Literal.Pascal) { 1074 Diag(StrTok, diag::err_pp_linemarker_invalid_filename); 1075 return DiscardUntilEndOfDirective(); 1076 } 1077 FilenameID = SourceMgr.getLineTableFilenameID(Literal.GetString()); 1078 1079 // If a filename was present, read any flags that are present. 1080 if (ReadLineMarkerFlags(IsFileEntry, IsFileExit, 1081 IsSystemHeader, IsExternCHeader, *this)) 1082 return; 1083 } 1084 1085 // Create a line note with this information. 1086 SourceMgr.AddLineNote(DigitTok.getLocation(), LineNo, FilenameID, 1087 IsFileEntry, IsFileExit, 1088 IsSystemHeader, IsExternCHeader); 1089 1090 // If the preprocessor has callbacks installed, notify them of the #line 1091 // change. This is used so that the line marker comes out in -E mode for 1092 // example. 1093 if (Callbacks) { 1094 PPCallbacks::FileChangeReason Reason = PPCallbacks::RenameFile; 1095 if (IsFileEntry) 1096 Reason = PPCallbacks::EnterFile; 1097 else if (IsFileExit) 1098 Reason = PPCallbacks::ExitFile; 1099 SrcMgr::CharacteristicKind FileKind = SrcMgr::C_User; 1100 if (IsExternCHeader) 1101 FileKind = SrcMgr::C_ExternCSystem; 1102 else if (IsSystemHeader) 1103 FileKind = SrcMgr::C_System; 1104 1105 Callbacks->FileChanged(CurPPLexer->getSourceLocation(), Reason, FileKind); 1106 } 1107 } 1108 1109 1110 /// HandleUserDiagnosticDirective - Handle a #warning or #error directive. 1111 /// 1112 void Preprocessor::HandleUserDiagnosticDirective(Token &Tok, 1113 bool isWarning) { 1114 // PTH doesn't emit #warning or #error directives. 1115 if (CurPTHLexer) 1116 return CurPTHLexer->DiscardToEndOfLine(); 1117 1118 // Read the rest of the line raw. We do this because we don't want macros 1119 // to be expanded and we don't require that the tokens be valid preprocessing 1120 // tokens. For example, this is allowed: "#warning ` 'foo". GCC does 1121 // collapse multiple consequtive white space between tokens, but this isn't 1122 // specified by the standard. 1123 SmallString<128> Message; 1124 CurLexer->ReadToEndOfLine(&Message); 1125 1126 // Find the first non-whitespace character, so that we can make the 1127 // diagnostic more succinct. 1128 StringRef Msg = Message.str().ltrim(" "); 1129 1130 if (isWarning) 1131 Diag(Tok, diag::pp_hash_warning) << Msg; 1132 else 1133 Diag(Tok, diag::err_pp_hash_error) << Msg; 1134 } 1135 1136 /// HandleIdentSCCSDirective - Handle a #ident/#sccs directive. 1137 /// 1138 void Preprocessor::HandleIdentSCCSDirective(Token &Tok) { 1139 // Yes, this directive is an extension. 1140 Diag(Tok, diag::ext_pp_ident_directive); 1141 1142 // Read the string argument. 1143 Token StrTok; 1144 Lex(StrTok); 1145 1146 // If the token kind isn't a string, it's a malformed directive. 1147 if (StrTok.isNot(tok::string_literal) && 1148 StrTok.isNot(tok::wide_string_literal)) { 1149 Diag(StrTok, diag::err_pp_malformed_ident); 1150 if (StrTok.isNot(tok::eod)) 1151 DiscardUntilEndOfDirective(); 1152 return; 1153 } 1154 1155 if (StrTok.hasUDSuffix()) { 1156 Diag(StrTok, diag::err_invalid_string_udl); 1157 return DiscardUntilEndOfDirective(); 1158 } 1159 1160 // Verify that there is nothing after the string, other than EOD. 1161 CheckEndOfDirective("ident"); 1162 1163 if (Callbacks) { 1164 bool Invalid = false; 1165 std::string Str = getSpelling(StrTok, &Invalid); 1166 if (!Invalid) 1167 Callbacks->Ident(Tok.getLocation(), Str); 1168 } 1169 } 1170 1171 /// \brief Handle a #public directive. 1172 void Preprocessor::HandleMacroPublicDirective(Token &Tok) { 1173 Token MacroNameTok; 1174 ReadMacroName(MacroNameTok, 2); 1175 1176 // Error reading macro name? If so, diagnostic already issued. 1177 if (MacroNameTok.is(tok::eod)) 1178 return; 1179 1180 // Check to see if this is the last token on the #__public_macro line. 1181 CheckEndOfDirective("__public_macro"); 1182 1183 IdentifierInfo *II = MacroNameTok.getIdentifierInfo(); 1184 // Okay, we finally have a valid identifier to undef. 1185 MacroDirective *MD = getMacroDirective(II); 1186 1187 // If the macro is not defined, this is an error. 1188 if (!MD) { 1189 Diag(MacroNameTok, diag::err_pp_visibility_non_macro) << II; 1190 return; 1191 } 1192 1193 // Note that this macro has now been exported. 1194 appendMacroDirective(II, AllocateVisibilityMacroDirective( 1195 MacroNameTok.getLocation(), /*IsPublic=*/true)); 1196 } 1197 1198 /// \brief Handle a #private directive. 1199 void Preprocessor::HandleMacroPrivateDirective(Token &Tok) { 1200 Token MacroNameTok; 1201 ReadMacroName(MacroNameTok, 2); 1202 1203 // Error reading macro name? If so, diagnostic already issued. 1204 if (MacroNameTok.is(tok::eod)) 1205 return; 1206 1207 // Check to see if this is the last token on the #__private_macro line. 1208 CheckEndOfDirective("__private_macro"); 1209 1210 IdentifierInfo *II = MacroNameTok.getIdentifierInfo(); 1211 // Okay, we finally have a valid identifier to undef. 1212 MacroDirective *MD = getMacroDirective(II); 1213 1214 // If the macro is not defined, this is an error. 1215 if (!MD) { 1216 Diag(MacroNameTok, diag::err_pp_visibility_non_macro) << II; 1217 return; 1218 } 1219 1220 // Note that this macro has now been marked private. 1221 appendMacroDirective(II, AllocateVisibilityMacroDirective( 1222 MacroNameTok.getLocation(), /*IsPublic=*/false)); 1223 } 1224 1225 //===----------------------------------------------------------------------===// 1226 // Preprocessor Include Directive Handling. 1227 //===----------------------------------------------------------------------===// 1228 1229 /// GetIncludeFilenameSpelling - Turn the specified lexer token into a fully 1230 /// checked and spelled filename, e.g. as an operand of \#include. This returns 1231 /// true if the input filename was in <>'s or false if it were in ""'s. The 1232 /// caller is expected to provide a buffer that is large enough to hold the 1233 /// spelling of the filename, but is also expected to handle the case when 1234 /// this method decides to use a different buffer. 1235 bool Preprocessor::GetIncludeFilenameSpelling(SourceLocation Loc, 1236 StringRef &Buffer) { 1237 // Get the text form of the filename. 1238 assert(!Buffer.empty() && "Can't have tokens with empty spellings!"); 1239 1240 // Make sure the filename is <x> or "x". 1241 bool isAngled; 1242 if (Buffer[0] == '<') { 1243 if (Buffer.back() != '>') { 1244 Diag(Loc, diag::err_pp_expects_filename); 1245 Buffer = StringRef(); 1246 return true; 1247 } 1248 isAngled = true; 1249 } else if (Buffer[0] == '"') { 1250 if (Buffer.back() != '"') { 1251 Diag(Loc, diag::err_pp_expects_filename); 1252 Buffer = StringRef(); 1253 return true; 1254 } 1255 isAngled = false; 1256 } else { 1257 Diag(Loc, diag::err_pp_expects_filename); 1258 Buffer = StringRef(); 1259 return true; 1260 } 1261 1262 // Diagnose #include "" as invalid. 1263 if (Buffer.size() <= 2) { 1264 Diag(Loc, diag::err_pp_empty_filename); 1265 Buffer = StringRef(); 1266 return true; 1267 } 1268 1269 // Skip the brackets. 1270 Buffer = Buffer.substr(1, Buffer.size()-2); 1271 return isAngled; 1272 } 1273 1274 // \brief Handle cases where the \#include name is expanded from a macro 1275 // as multiple tokens, which need to be glued together. 1276 // 1277 // This occurs for code like: 1278 // \code 1279 // \#define FOO <a/b.h> 1280 // \#include FOO 1281 // \endcode 1282 // because in this case, "<a/b.h>" is returned as 7 tokens, not one. 1283 // 1284 // This code concatenates and consumes tokens up to the '>' token. It returns 1285 // false if the > was found, otherwise it returns true if it finds and consumes 1286 // the EOD marker. 1287 bool Preprocessor::ConcatenateIncludeName(SmallString<128> &FilenameBuffer, 1288 SourceLocation &End) { 1289 Token CurTok; 1290 1291 Lex(CurTok); 1292 while (CurTok.isNot(tok::eod)) { 1293 End = CurTok.getLocation(); 1294 1295 // FIXME: Provide code completion for #includes. 1296 if (CurTok.is(tok::code_completion)) { 1297 setCodeCompletionReached(); 1298 Lex(CurTok); 1299 continue; 1300 } 1301 1302 // Append the spelling of this token to the buffer. If there was a space 1303 // before it, add it now. 1304 if (CurTok.hasLeadingSpace()) 1305 FilenameBuffer.push_back(' '); 1306 1307 // Get the spelling of the token, directly into FilenameBuffer if possible. 1308 unsigned PreAppendSize = FilenameBuffer.size(); 1309 FilenameBuffer.resize(PreAppendSize+CurTok.getLength()); 1310 1311 const char *BufPtr = &FilenameBuffer[PreAppendSize]; 1312 unsigned ActualLen = getSpelling(CurTok, BufPtr); 1313 1314 // If the token was spelled somewhere else, copy it into FilenameBuffer. 1315 if (BufPtr != &FilenameBuffer[PreAppendSize]) 1316 memcpy(&FilenameBuffer[PreAppendSize], BufPtr, ActualLen); 1317 1318 // Resize FilenameBuffer to the correct size. 1319 if (CurTok.getLength() != ActualLen) 1320 FilenameBuffer.resize(PreAppendSize+ActualLen); 1321 1322 // If we found the '>' marker, return success. 1323 if (CurTok.is(tok::greater)) 1324 return false; 1325 1326 Lex(CurTok); 1327 } 1328 1329 // If we hit the eod marker, emit an error and return true so that the caller 1330 // knows the EOD has been read. 1331 Diag(CurTok.getLocation(), diag::err_pp_expects_filename); 1332 return true; 1333 } 1334 1335 /// \brief Push a token onto the token stream containing an annotation. 1336 static void EnterAnnotationToken(Preprocessor &PP, 1337 SourceLocation Begin, SourceLocation End, 1338 tok::TokenKind Kind, void *AnnotationVal) { 1339 Token *Tok = new Token[1]; 1340 Tok[0].startToken(); 1341 Tok[0].setKind(Kind); 1342 Tok[0].setLocation(Begin); 1343 Tok[0].setAnnotationEndLoc(End); 1344 Tok[0].setAnnotationValue(AnnotationVal); 1345 PP.EnterTokenStream(Tok, 1, true, true); 1346 } 1347 1348 /// HandleIncludeDirective - The "\#include" tokens have just been read, read 1349 /// the file to be included from the lexer, then include it! This is a common 1350 /// routine with functionality shared between \#include, \#include_next and 1351 /// \#import. LookupFrom is set when this is a \#include_next directive, it 1352 /// specifies the file to start searching from. 1353 void Preprocessor::HandleIncludeDirective(SourceLocation HashLoc, 1354 Token &IncludeTok, 1355 const DirectoryLookup *LookupFrom, 1356 bool isImport) { 1357 1358 Token FilenameTok; 1359 CurPPLexer->LexIncludeFilename(FilenameTok); 1360 1361 // Reserve a buffer to get the spelling. 1362 SmallString<128> FilenameBuffer; 1363 StringRef Filename; 1364 SourceLocation End; 1365 SourceLocation CharEnd; // the end of this directive, in characters 1366 1367 switch (FilenameTok.getKind()) { 1368 case tok::eod: 1369 // If the token kind is EOD, the error has already been diagnosed. 1370 return; 1371 1372 case tok::angle_string_literal: 1373 case tok::string_literal: 1374 Filename = getSpelling(FilenameTok, FilenameBuffer); 1375 End = FilenameTok.getLocation(); 1376 CharEnd = End.getLocWithOffset(FilenameTok.getLength()); 1377 break; 1378 1379 case tok::less: 1380 // This could be a <foo/bar.h> file coming from a macro expansion. In this 1381 // case, glue the tokens together into FilenameBuffer and interpret those. 1382 FilenameBuffer.push_back('<'); 1383 if (ConcatenateIncludeName(FilenameBuffer, End)) 1384 return; // Found <eod> but no ">"? Diagnostic already emitted. 1385 Filename = FilenameBuffer.str(); 1386 CharEnd = End.getLocWithOffset(1); 1387 break; 1388 default: 1389 Diag(FilenameTok.getLocation(), diag::err_pp_expects_filename); 1390 DiscardUntilEndOfDirective(); 1391 return; 1392 } 1393 1394 CharSourceRange FilenameRange 1395 = CharSourceRange::getCharRange(FilenameTok.getLocation(), CharEnd); 1396 StringRef OriginalFilename = Filename; 1397 bool isAngled = 1398 GetIncludeFilenameSpelling(FilenameTok.getLocation(), Filename); 1399 // If GetIncludeFilenameSpelling set the start ptr to null, there was an 1400 // error. 1401 if (Filename.empty()) { 1402 DiscardUntilEndOfDirective(); 1403 return; 1404 } 1405 1406 // Verify that there is nothing after the filename, other than EOD. Note that 1407 // we allow macros that expand to nothing after the filename, because this 1408 // falls into the category of "#include pp-tokens new-line" specified in 1409 // C99 6.10.2p4. 1410 CheckEndOfDirective(IncludeTok.getIdentifierInfo()->getNameStart(), true); 1411 1412 // Check that we don't have infinite #include recursion. 1413 if (IncludeMacroStack.size() == MaxAllowedIncludeStackDepth-1) { 1414 Diag(FilenameTok, diag::err_pp_include_too_deep); 1415 return; 1416 } 1417 1418 // Complain about attempts to #include files in an audit pragma. 1419 if (PragmaARCCFCodeAuditedLoc.isValid()) { 1420 Diag(HashLoc, diag::err_pp_include_in_arc_cf_code_audited); 1421 Diag(PragmaARCCFCodeAuditedLoc, diag::note_pragma_entered_here); 1422 1423 // Immediately leave the pragma. 1424 PragmaARCCFCodeAuditedLoc = SourceLocation(); 1425 } 1426 1427 if (HeaderInfo.HasIncludeAliasMap()) { 1428 // Map the filename with the brackets still attached. If the name doesn't 1429 // map to anything, fall back on the filename we've already gotten the 1430 // spelling for. 1431 StringRef NewName = HeaderInfo.MapHeaderToIncludeAlias(OriginalFilename); 1432 if (!NewName.empty()) 1433 Filename = NewName; 1434 } 1435 1436 // Search include directories. 1437 const DirectoryLookup *CurDir; 1438 SmallString<1024> SearchPath; 1439 SmallString<1024> RelativePath; 1440 // We get the raw path only if we have 'Callbacks' to which we later pass 1441 // the path. 1442 ModuleMap::KnownHeader SuggestedModule; 1443 SourceLocation FilenameLoc = FilenameTok.getLocation(); 1444 SmallString<128> NormalizedPath; 1445 if (LangOpts.MSVCCompat) { 1446 NormalizedPath = Filename.str(); 1447 #ifndef LLVM_ON_WIN32 1448 llvm::sys::path::native(NormalizedPath); 1449 #endif 1450 } 1451 const FileEntry *File = LookupFile( 1452 FilenameLoc, LangOpts.MSVCCompat ? NormalizedPath.c_str() : Filename, 1453 isAngled, LookupFrom, CurDir, Callbacks ? &SearchPath : nullptr, 1454 Callbacks ? &RelativePath : nullptr, 1455 HeaderInfo.getHeaderSearchOpts().ModuleMaps ? &SuggestedModule : nullptr); 1456 1457 if (Callbacks) { 1458 if (!File) { 1459 // Give the clients a chance to recover. 1460 SmallString<128> RecoveryPath; 1461 if (Callbacks->FileNotFound(Filename, RecoveryPath)) { 1462 if (const DirectoryEntry *DE = FileMgr.getDirectory(RecoveryPath)) { 1463 // Add the recovery path to the list of search paths. 1464 DirectoryLookup DL(DE, SrcMgr::C_User, false); 1465 HeaderInfo.AddSearchPath(DL, isAngled); 1466 1467 // Try the lookup again, skipping the cache. 1468 File = LookupFile(FilenameLoc, 1469 LangOpts.MSVCCompat ? NormalizedPath.c_str() 1470 : Filename, 1471 isAngled, LookupFrom, CurDir, nullptr, nullptr, 1472 HeaderInfo.getHeaderSearchOpts().ModuleMaps 1473 ? &SuggestedModule 1474 : nullptr, 1475 /*SkipCache*/ true); 1476 } 1477 } 1478 } 1479 1480 if (!SuggestedModule || !getLangOpts().Modules) { 1481 // Notify the callback object that we've seen an inclusion directive. 1482 Callbacks->InclusionDirective(HashLoc, IncludeTok, 1483 LangOpts.MSVCCompat ? NormalizedPath.c_str() 1484 : Filename, 1485 isAngled, FilenameRange, File, SearchPath, 1486 RelativePath, /*ImportedModule=*/nullptr); 1487 } 1488 } 1489 1490 if (!File) { 1491 if (!SuppressIncludeNotFoundError) { 1492 // If the file could not be located and it was included via angle 1493 // brackets, we can attempt a lookup as though it were a quoted path to 1494 // provide the user with a possible fixit. 1495 if (isAngled) { 1496 File = LookupFile( 1497 FilenameLoc, LangOpts.MSVCCompat ? NormalizedPath.c_str() : Filename, 1498 false, LookupFrom, CurDir, Callbacks ? &SearchPath : nullptr, 1499 Callbacks ? &RelativePath : nullptr, 1500 HeaderInfo.getHeaderSearchOpts().ModuleMaps ? &SuggestedModule 1501 : nullptr); 1502 if (File) { 1503 SourceRange Range(FilenameTok.getLocation(), CharEnd); 1504 Diag(FilenameTok, diag::err_pp_file_not_found_not_fatal) << 1505 Filename << 1506 FixItHint::CreateReplacement(Range, "\"" + Filename.str() + "\""); 1507 } 1508 } 1509 // If the file is still not found, just go with the vanilla diagnostic 1510 if (!File) 1511 Diag(FilenameTok, diag::err_pp_file_not_found) << Filename; 1512 } 1513 if (!File) 1514 return; 1515 } 1516 1517 // If we are supposed to import a module rather than including the header, 1518 // do so now. 1519 if (SuggestedModule && getLangOpts().Modules && 1520 SuggestedModule.getModule()->getTopLevelModuleName() != 1521 getLangOpts().ImplementationOfModule) { 1522 // Compute the module access path corresponding to this module. 1523 // FIXME: Should we have a second loadModule() overload to avoid this 1524 // extra lookup step? 1525 SmallVector<std::pair<IdentifierInfo *, SourceLocation>, 2> Path; 1526 for (Module *Mod = SuggestedModule.getModule(); Mod; Mod = Mod->Parent) 1527 Path.push_back(std::make_pair(getIdentifierInfo(Mod->Name), 1528 FilenameTok.getLocation())); 1529 std::reverse(Path.begin(), Path.end()); 1530 1531 // Warn that we're replacing the include/import with a module import. 1532 SmallString<128> PathString; 1533 for (unsigned I = 0, N = Path.size(); I != N; ++I) { 1534 if (I) 1535 PathString += '.'; 1536 PathString += Path[I].first->getName(); 1537 } 1538 int IncludeKind = 0; 1539 1540 switch (IncludeTok.getIdentifierInfo()->getPPKeywordID()) { 1541 case tok::pp_include: 1542 IncludeKind = 0; 1543 break; 1544 1545 case tok::pp_import: 1546 IncludeKind = 1; 1547 break; 1548 1549 case tok::pp_include_next: 1550 IncludeKind = 2; 1551 break; 1552 1553 case tok::pp___include_macros: 1554 IncludeKind = 3; 1555 break; 1556 1557 default: 1558 llvm_unreachable("unknown include directive kind"); 1559 } 1560 1561 // Determine whether we are actually building the module that this 1562 // include directive maps to. 1563 bool BuildingImportedModule 1564 = Path[0].first->getName() == getLangOpts().CurrentModule; 1565 1566 if (!BuildingImportedModule && getLangOpts().ObjC2) { 1567 // If we're not building the imported module, warn that we're going 1568 // to automatically turn this inclusion directive into a module import. 1569 // We only do this in Objective-C, where we have a module-import syntax. 1570 CharSourceRange ReplaceRange(SourceRange(HashLoc, CharEnd), 1571 /*IsTokenRange=*/false); 1572 Diag(HashLoc, diag::warn_auto_module_import) 1573 << IncludeKind << PathString 1574 << FixItHint::CreateReplacement(ReplaceRange, 1575 "@import " + PathString.str().str() + ";"); 1576 } 1577 1578 // Load the module. Only make macros visible. We'll make the declarations 1579 // visible when the parser gets here. 1580 Module::NameVisibilityKind Visibility = Module::MacrosVisible; 1581 ModuleLoadResult Imported 1582 = TheModuleLoader.loadModule(IncludeTok.getLocation(), Path, Visibility, 1583 /*IsIncludeDirective=*/true); 1584 assert((Imported == nullptr || Imported == SuggestedModule.getModule()) && 1585 "the imported module is different than the suggested one"); 1586 1587 if (!Imported && hadModuleLoaderFatalFailure()) { 1588 // With a fatal failure in the module loader, we abort parsing. 1589 Token &Result = IncludeTok; 1590 if (CurLexer) { 1591 Result.startToken(); 1592 CurLexer->FormTokenWithChars(Result, CurLexer->BufferEnd, tok::eof); 1593 CurLexer->cutOffLexing(); 1594 } else { 1595 assert(CurPTHLexer && "#include but no current lexer set!"); 1596 CurPTHLexer->getEOF(Result); 1597 } 1598 return; 1599 } 1600 1601 // If this header isn't part of the module we're building, we're done. 1602 if (!BuildingImportedModule && Imported) { 1603 if (Callbacks) { 1604 Callbacks->InclusionDirective(HashLoc, IncludeTok, Filename, isAngled, 1605 FilenameRange, File, 1606 SearchPath, RelativePath, Imported); 1607 } 1608 1609 if (IncludeKind != 3) { 1610 // Let the parser know that we hit a module import, and it should 1611 // make the module visible. 1612 // FIXME: Produce this as the current token directly, rather than 1613 // allocating a new token for it. 1614 EnterAnnotationToken(*this, HashLoc, End, tok::annot_module_include, 1615 Imported); 1616 } 1617 return; 1618 } 1619 1620 // If we failed to find a submodule that we expected to find, we can 1621 // continue. Otherwise, there's an error in the included file, so we 1622 // don't want to include it. 1623 if (!BuildingImportedModule && !Imported.isMissingExpected()) { 1624 return; 1625 } 1626 } 1627 1628 if (Callbacks && SuggestedModule) { 1629 // We didn't notify the callback object that we've seen an inclusion 1630 // directive before. Now that we are parsing the include normally and not 1631 // turning it to a module import, notify the callback object. 1632 Callbacks->InclusionDirective(HashLoc, IncludeTok, Filename, isAngled, 1633 FilenameRange, File, 1634 SearchPath, RelativePath, 1635 /*ImportedModule=*/nullptr); 1636 } 1637 1638 // The #included file will be considered to be a system header if either it is 1639 // in a system include directory, or if the #includer is a system include 1640 // header. 1641 SrcMgr::CharacteristicKind FileCharacter = 1642 std::max(HeaderInfo.getFileDirFlavor(File), 1643 SourceMgr.getFileCharacteristic(FilenameTok.getLocation())); 1644 1645 // Ask HeaderInfo if we should enter this #include file. If not, #including 1646 // this file will have no effect. 1647 if (!HeaderInfo.ShouldEnterIncludeFile(File, isImport)) { 1648 if (Callbacks) 1649 Callbacks->FileSkipped(*File, FilenameTok, FileCharacter); 1650 return; 1651 } 1652 1653 // Look up the file, create a File ID for it. 1654 SourceLocation IncludePos = End; 1655 // If the filename string was the result of macro expansions, set the include 1656 // position on the file where it will be included and after the expansions. 1657 if (IncludePos.isMacroID()) 1658 IncludePos = SourceMgr.getExpansionRange(IncludePos).second; 1659 FileID FID = SourceMgr.createFileID(File, IncludePos, FileCharacter); 1660 assert(!FID.isInvalid() && "Expected valid file ID"); 1661 1662 // Determine if we're switching to building a new submodule, and which one. 1663 ModuleMap::KnownHeader BuildingModule; 1664 if (getLangOpts().Modules && !getLangOpts().CurrentModule.empty()) { 1665 Module *RequestingModule = getModuleForLocation(FilenameLoc); 1666 BuildingModule = 1667 HeaderInfo.getModuleMap().findModuleForHeader(File, RequestingModule); 1668 } 1669 1670 // If all is good, enter the new file! 1671 if (EnterSourceFile(FID, CurDir, FilenameTok.getLocation())) 1672 return; 1673 1674 // If we're walking into another part of the same module, let the parser 1675 // know that any future declarations are within that other submodule. 1676 if (BuildingModule) { 1677 assert(!CurSubmodule && "should not have marked this as a module yet"); 1678 CurSubmodule = BuildingModule.getModule(); 1679 1680 EnterAnnotationToken(*this, HashLoc, End, tok::annot_module_begin, 1681 CurSubmodule); 1682 } 1683 } 1684 1685 /// HandleIncludeNextDirective - Implements \#include_next. 1686 /// 1687 void Preprocessor::HandleIncludeNextDirective(SourceLocation HashLoc, 1688 Token &IncludeNextTok) { 1689 Diag(IncludeNextTok, diag::ext_pp_include_next_directive); 1690 1691 // #include_next is like #include, except that we start searching after 1692 // the current found directory. If we can't do this, issue a 1693 // diagnostic. 1694 const DirectoryLookup *Lookup = CurDirLookup; 1695 if (isInPrimaryFile()) { 1696 Lookup = nullptr; 1697 Diag(IncludeNextTok, diag::pp_include_next_in_primary); 1698 } else if (!Lookup) { 1699 Diag(IncludeNextTok, diag::pp_include_next_absolute_path); 1700 } else { 1701 // Start looking up in the next directory. 1702 ++Lookup; 1703 } 1704 1705 return HandleIncludeDirective(HashLoc, IncludeNextTok, Lookup); 1706 } 1707 1708 /// HandleMicrosoftImportDirective - Implements \#import for Microsoft Mode 1709 void Preprocessor::HandleMicrosoftImportDirective(Token &Tok) { 1710 // The Microsoft #import directive takes a type library and generates header 1711 // files from it, and includes those. This is beyond the scope of what clang 1712 // does, so we ignore it and error out. However, #import can optionally have 1713 // trailing attributes that span multiple lines. We're going to eat those 1714 // so we can continue processing from there. 1715 Diag(Tok, diag::err_pp_import_directive_ms ); 1716 1717 // Read tokens until we get to the end of the directive. Note that the 1718 // directive can be split over multiple lines using the backslash character. 1719 DiscardUntilEndOfDirective(); 1720 } 1721 1722 /// HandleImportDirective - Implements \#import. 1723 /// 1724 void Preprocessor::HandleImportDirective(SourceLocation HashLoc, 1725 Token &ImportTok) { 1726 if (!LangOpts.ObjC1) { // #import is standard for ObjC. 1727 if (LangOpts.MSVCCompat) 1728 return HandleMicrosoftImportDirective(ImportTok); 1729 Diag(ImportTok, diag::ext_pp_import_directive); 1730 } 1731 return HandleIncludeDirective(HashLoc, ImportTok, nullptr, true); 1732 } 1733 1734 /// HandleIncludeMacrosDirective - The -imacros command line option turns into a 1735 /// pseudo directive in the predefines buffer. This handles it by sucking all 1736 /// tokens through the preprocessor and discarding them (only keeping the side 1737 /// effects on the preprocessor). 1738 void Preprocessor::HandleIncludeMacrosDirective(SourceLocation HashLoc, 1739 Token &IncludeMacrosTok) { 1740 // This directive should only occur in the predefines buffer. If not, emit an 1741 // error and reject it. 1742 SourceLocation Loc = IncludeMacrosTok.getLocation(); 1743 if (strcmp(SourceMgr.getBufferName(Loc), "<built-in>") != 0) { 1744 Diag(IncludeMacrosTok.getLocation(), 1745 diag::pp_include_macros_out_of_predefines); 1746 DiscardUntilEndOfDirective(); 1747 return; 1748 } 1749 1750 // Treat this as a normal #include for checking purposes. If this is 1751 // successful, it will push a new lexer onto the include stack. 1752 HandleIncludeDirective(HashLoc, IncludeMacrosTok, nullptr, false); 1753 1754 Token TmpTok; 1755 do { 1756 Lex(TmpTok); 1757 assert(TmpTok.isNot(tok::eof) && "Didn't find end of -imacros!"); 1758 } while (TmpTok.isNot(tok::hashhash)); 1759 } 1760 1761 //===----------------------------------------------------------------------===// 1762 // Preprocessor Macro Directive Handling. 1763 //===----------------------------------------------------------------------===// 1764 1765 /// ReadMacroDefinitionArgList - The ( starting an argument list of a macro 1766 /// definition has just been read. Lex the rest of the arguments and the 1767 /// closing ), updating MI with what we learn. Return true if an error occurs 1768 /// parsing the arg list. 1769 bool Preprocessor::ReadMacroDefinitionArgList(MacroInfo *MI, Token &Tok) { 1770 SmallVector<IdentifierInfo*, 32> Arguments; 1771 1772 while (1) { 1773 LexUnexpandedToken(Tok); 1774 switch (Tok.getKind()) { 1775 case tok::r_paren: 1776 // Found the end of the argument list. 1777 if (Arguments.empty()) // #define FOO() 1778 return false; 1779 // Otherwise we have #define FOO(A,) 1780 Diag(Tok, diag::err_pp_expected_ident_in_arg_list); 1781 return true; 1782 case tok::ellipsis: // #define X(... -> C99 varargs 1783 if (!LangOpts.C99) 1784 Diag(Tok, LangOpts.CPlusPlus11 ? 1785 diag::warn_cxx98_compat_variadic_macro : 1786 diag::ext_variadic_macro); 1787 1788 // OpenCL v1.2 s6.9.e: variadic macros are not supported. 1789 if (LangOpts.OpenCL) { 1790 Diag(Tok, diag::err_pp_opencl_variadic_macros); 1791 return true; 1792 } 1793 1794 // Lex the token after the identifier. 1795 LexUnexpandedToken(Tok); 1796 if (Tok.isNot(tok::r_paren)) { 1797 Diag(Tok, diag::err_pp_missing_rparen_in_macro_def); 1798 return true; 1799 } 1800 // Add the __VA_ARGS__ identifier as an argument. 1801 Arguments.push_back(Ident__VA_ARGS__); 1802 MI->setIsC99Varargs(); 1803 MI->setArgumentList(&Arguments[0], Arguments.size(), BP); 1804 return false; 1805 case tok::eod: // #define X( 1806 Diag(Tok, diag::err_pp_missing_rparen_in_macro_def); 1807 return true; 1808 default: 1809 // Handle keywords and identifiers here to accept things like 1810 // #define Foo(for) for. 1811 IdentifierInfo *II = Tok.getIdentifierInfo(); 1812 if (!II) { 1813 // #define X(1 1814 Diag(Tok, diag::err_pp_invalid_tok_in_arg_list); 1815 return true; 1816 } 1817 1818 // If this is already used as an argument, it is used multiple times (e.g. 1819 // #define X(A,A. 1820 if (std::find(Arguments.begin(), Arguments.end(), II) != 1821 Arguments.end()) { // C99 6.10.3p6 1822 Diag(Tok, diag::err_pp_duplicate_name_in_arg_list) << II; 1823 return true; 1824 } 1825 1826 // Add the argument to the macro info. 1827 Arguments.push_back(II); 1828 1829 // Lex the token after the identifier. 1830 LexUnexpandedToken(Tok); 1831 1832 switch (Tok.getKind()) { 1833 default: // #define X(A B 1834 Diag(Tok, diag::err_pp_expected_comma_in_arg_list); 1835 return true; 1836 case tok::r_paren: // #define X(A) 1837 MI->setArgumentList(&Arguments[0], Arguments.size(), BP); 1838 return false; 1839 case tok::comma: // #define X(A, 1840 break; 1841 case tok::ellipsis: // #define X(A... -> GCC extension 1842 // Diagnose extension. 1843 Diag(Tok, diag::ext_named_variadic_macro); 1844 1845 // Lex the token after the identifier. 1846 LexUnexpandedToken(Tok); 1847 if (Tok.isNot(tok::r_paren)) { 1848 Diag(Tok, diag::err_pp_missing_rparen_in_macro_def); 1849 return true; 1850 } 1851 1852 MI->setIsGNUVarargs(); 1853 MI->setArgumentList(&Arguments[0], Arguments.size(), BP); 1854 return false; 1855 } 1856 } 1857 } 1858 } 1859 1860 /// HandleDefineDirective - Implements \#define. This consumes the entire macro 1861 /// line then lets the caller lex the next real token. 1862 void Preprocessor::HandleDefineDirective(Token &DefineTok, 1863 bool ImmediatelyAfterHeaderGuard) { 1864 ++NumDefined; 1865 1866 Token MacroNameTok; 1867 ReadMacroName(MacroNameTok, 1); 1868 1869 // Error reading macro name? If so, diagnostic already issued. 1870 if (MacroNameTok.is(tok::eod)) 1871 return; 1872 1873 Token LastTok = MacroNameTok; 1874 1875 // If we are supposed to keep comments in #defines, reenable comment saving 1876 // mode. 1877 if (CurLexer) CurLexer->SetCommentRetentionState(KeepMacroComments); 1878 1879 // Create the new macro. 1880 MacroInfo *MI = AllocateMacroInfo(MacroNameTok.getLocation()); 1881 1882 Token Tok; 1883 LexUnexpandedToken(Tok); 1884 1885 // If this is a function-like macro definition, parse the argument list, 1886 // marking each of the identifiers as being used as macro arguments. Also, 1887 // check other constraints on the first token of the macro body. 1888 if (Tok.is(tok::eod)) { 1889 if (ImmediatelyAfterHeaderGuard) { 1890 // Save this macro information since it may part of a header guard. 1891 CurPPLexer->MIOpt.SetDefinedMacro(MacroNameTok.getIdentifierInfo(), 1892 MacroNameTok.getLocation()); 1893 } 1894 // If there is no body to this macro, we have no special handling here. 1895 } else if (Tok.hasLeadingSpace()) { 1896 // This is a normal token with leading space. Clear the leading space 1897 // marker on the first token to get proper expansion. 1898 Tok.clearFlag(Token::LeadingSpace); 1899 } else if (Tok.is(tok::l_paren)) { 1900 // This is a function-like macro definition. Read the argument list. 1901 MI->setIsFunctionLike(); 1902 if (ReadMacroDefinitionArgList(MI, LastTok)) { 1903 // Throw away the rest of the line. 1904 if (CurPPLexer->ParsingPreprocessorDirective) 1905 DiscardUntilEndOfDirective(); 1906 return; 1907 } 1908 1909 // If this is a definition of a variadic C99 function-like macro, not using 1910 // the GNU named varargs extension, enabled __VA_ARGS__. 1911 1912 // "Poison" __VA_ARGS__, which can only appear in the expansion of a macro. 1913 // This gets unpoisoned where it is allowed. 1914 assert(Ident__VA_ARGS__->isPoisoned() && "__VA_ARGS__ should be poisoned!"); 1915 if (MI->isC99Varargs()) 1916 Ident__VA_ARGS__->setIsPoisoned(false); 1917 1918 // Read the first token after the arg list for down below. 1919 LexUnexpandedToken(Tok); 1920 } else if (LangOpts.C99 || LangOpts.CPlusPlus11) { 1921 // C99 requires whitespace between the macro definition and the body. Emit 1922 // a diagnostic for something like "#define X+". 1923 Diag(Tok, diag::ext_c99_whitespace_required_after_macro_name); 1924 } else { 1925 // C90 6.8 TC1 says: "In the definition of an object-like macro, if the 1926 // first character of a replacement list is not a character required by 1927 // subclause 5.2.1, then there shall be white-space separation between the 1928 // identifier and the replacement list.". 5.2.1 lists this set: 1929 // "A-Za-z0-9!"#%&'()*+,_./:;<=>?[\]^_{|}~" as well as whitespace, which 1930 // is irrelevant here. 1931 bool isInvalid = false; 1932 if (Tok.is(tok::at)) // @ is not in the list above. 1933 isInvalid = true; 1934 else if (Tok.is(tok::unknown)) { 1935 // If we have an unknown token, it is something strange like "`". Since 1936 // all of valid characters would have lexed into a single character 1937 // token of some sort, we know this is not a valid case. 1938 isInvalid = true; 1939 } 1940 if (isInvalid) 1941 Diag(Tok, diag::ext_missing_whitespace_after_macro_name); 1942 else 1943 Diag(Tok, diag::warn_missing_whitespace_after_macro_name); 1944 } 1945 1946 if (!Tok.is(tok::eod)) 1947 LastTok = Tok; 1948 1949 // Read the rest of the macro body. 1950 if (MI->isObjectLike()) { 1951 // Object-like macros are very simple, just read their body. 1952 while (Tok.isNot(tok::eod)) { 1953 LastTok = Tok; 1954 MI->AddTokenToBody(Tok); 1955 // Get the next token of the macro. 1956 LexUnexpandedToken(Tok); 1957 } 1958 1959 } else { 1960 // Otherwise, read the body of a function-like macro. While we are at it, 1961 // check C99 6.10.3.2p1: ensure that # operators are followed by macro 1962 // parameters in function-like macro expansions. 1963 while (Tok.isNot(tok::eod)) { 1964 LastTok = Tok; 1965 1966 if (Tok.isNot(tok::hash) && Tok.isNot(tok::hashhash)) { 1967 MI->AddTokenToBody(Tok); 1968 1969 // Get the next token of the macro. 1970 LexUnexpandedToken(Tok); 1971 continue; 1972 } 1973 1974 // If we're in -traditional mode, then we should ignore stringification 1975 // and token pasting. Mark the tokens as unknown so as not to confuse 1976 // things. 1977 if (getLangOpts().TraditionalCPP) { 1978 Tok.setKind(tok::unknown); 1979 MI->AddTokenToBody(Tok); 1980 1981 // Get the next token of the macro. 1982 LexUnexpandedToken(Tok); 1983 continue; 1984 } 1985 1986 if (Tok.is(tok::hashhash)) { 1987 1988 // If we see token pasting, check if it looks like the gcc comma 1989 // pasting extension. We'll use this information to suppress 1990 // diagnostics later on. 1991 1992 // Get the next token of the macro. 1993 LexUnexpandedToken(Tok); 1994 1995 if (Tok.is(tok::eod)) { 1996 MI->AddTokenToBody(LastTok); 1997 break; 1998 } 1999 2000 unsigned NumTokens = MI->getNumTokens(); 2001 if (NumTokens && Tok.getIdentifierInfo() == Ident__VA_ARGS__ && 2002 MI->getReplacementToken(NumTokens-1).is(tok::comma)) 2003 MI->setHasCommaPasting(); 2004 2005 // Things look ok, add the '##' token to the macro. 2006 MI->AddTokenToBody(LastTok); 2007 continue; 2008 } 2009 2010 // Get the next token of the macro. 2011 LexUnexpandedToken(Tok); 2012 2013 // Check for a valid macro arg identifier. 2014 if (Tok.getIdentifierInfo() == nullptr || 2015 MI->getArgumentNum(Tok.getIdentifierInfo()) == -1) { 2016 2017 // If this is assembler-with-cpp mode, we accept random gibberish after 2018 // the '#' because '#' is often a comment character. However, change 2019 // the kind of the token to tok::unknown so that the preprocessor isn't 2020 // confused. 2021 if (getLangOpts().AsmPreprocessor && Tok.isNot(tok::eod)) { 2022 LastTok.setKind(tok::unknown); 2023 MI->AddTokenToBody(LastTok); 2024 continue; 2025 } else { 2026 Diag(Tok, diag::err_pp_stringize_not_parameter); 2027 2028 // Disable __VA_ARGS__ again. 2029 Ident__VA_ARGS__->setIsPoisoned(true); 2030 return; 2031 } 2032 } 2033 2034 // Things look ok, add the '#' and param name tokens to the macro. 2035 MI->AddTokenToBody(LastTok); 2036 MI->AddTokenToBody(Tok); 2037 LastTok = Tok; 2038 2039 // Get the next token of the macro. 2040 LexUnexpandedToken(Tok); 2041 } 2042 } 2043 2044 2045 // Disable __VA_ARGS__ again. 2046 Ident__VA_ARGS__->setIsPoisoned(true); 2047 2048 // Check that there is no paste (##) operator at the beginning or end of the 2049 // replacement list. 2050 unsigned NumTokens = MI->getNumTokens(); 2051 if (NumTokens != 0) { 2052 if (MI->getReplacementToken(0).is(tok::hashhash)) { 2053 Diag(MI->getReplacementToken(0), diag::err_paste_at_start); 2054 return; 2055 } 2056 if (MI->getReplacementToken(NumTokens-1).is(tok::hashhash)) { 2057 Diag(MI->getReplacementToken(NumTokens-1), diag::err_paste_at_end); 2058 return; 2059 } 2060 } 2061 2062 MI->setDefinitionEndLoc(LastTok.getLocation()); 2063 2064 // Finally, if this identifier already had a macro defined for it, verify that 2065 // the macro bodies are identical, and issue diagnostics if they are not. 2066 if (const MacroInfo *OtherMI=getMacroInfo(MacroNameTok.getIdentifierInfo())) { 2067 // It is very common for system headers to have tons of macro redefinitions 2068 // and for warnings to be disabled in system headers. If this is the case, 2069 // then don't bother calling MacroInfo::isIdenticalTo. 2070 if (!getDiagnostics().getSuppressSystemWarnings() || 2071 !SourceMgr.isInSystemHeader(DefineTok.getLocation())) { 2072 if (!OtherMI->isUsed() && OtherMI->isWarnIfUnused()) 2073 Diag(OtherMI->getDefinitionLoc(), diag::pp_macro_not_used); 2074 2075 // Warn if defining "__LINE__" and other builtins, per C99 6.10.8/4 and 2076 // C++ [cpp.predefined]p4, but allow it as an extension. 2077 if (OtherMI->isBuiltinMacro()) 2078 Diag(MacroNameTok, diag::ext_pp_redef_builtin_macro); 2079 // Macros must be identical. This means all tokens and whitespace 2080 // separation must be the same. C99 6.10.3p2. 2081 else if (!OtherMI->isAllowRedefinitionsWithoutWarning() && 2082 !MI->isIdenticalTo(*OtherMI, *this, /*Syntactic=*/LangOpts.MicrosoftExt)) { 2083 Diag(MI->getDefinitionLoc(), diag::ext_pp_macro_redef) 2084 << MacroNameTok.getIdentifierInfo(); 2085 Diag(OtherMI->getDefinitionLoc(), diag::note_previous_definition); 2086 } 2087 } 2088 if (OtherMI->isWarnIfUnused()) 2089 WarnUnusedMacroLocs.erase(OtherMI->getDefinitionLoc()); 2090 } 2091 2092 DefMacroDirective *MD = 2093 appendDefMacroDirective(MacroNameTok.getIdentifierInfo(), MI); 2094 2095 assert(!MI->isUsed()); 2096 // If we need warning for not using the macro, add its location in the 2097 // warn-because-unused-macro set. If it gets used it will be removed from set. 2098 if (getSourceManager().isInMainFile(MI->getDefinitionLoc()) && 2099 !Diags->isIgnored(diag::pp_macro_not_used, MI->getDefinitionLoc())) { 2100 MI->setIsWarnIfUnused(true); 2101 WarnUnusedMacroLocs.insert(MI->getDefinitionLoc()); 2102 } 2103 2104 // If the callbacks want to know, tell them about the macro definition. 2105 if (Callbacks) 2106 Callbacks->MacroDefined(MacroNameTok, MD); 2107 } 2108 2109 /// HandleUndefDirective - Implements \#undef. 2110 /// 2111 void Preprocessor::HandleUndefDirective(Token &UndefTok) { 2112 ++NumUndefined; 2113 2114 Token MacroNameTok; 2115 ReadMacroName(MacroNameTok, 2); 2116 2117 // Error reading macro name? If so, diagnostic already issued. 2118 if (MacroNameTok.is(tok::eod)) 2119 return; 2120 2121 // Check to see if this is the last token on the #undef line. 2122 CheckEndOfDirective("undef"); 2123 2124 // Okay, we finally have a valid identifier to undef. 2125 MacroDirective *MD = getMacroDirective(MacroNameTok.getIdentifierInfo()); 2126 const MacroInfo *MI = MD ? MD->getMacroInfo() : nullptr; 2127 2128 // If the callbacks want to know, tell them about the macro #undef. 2129 // Note: no matter if the macro was defined or not. 2130 if (Callbacks) 2131 Callbacks->MacroUndefined(MacroNameTok, MD); 2132 2133 // If the macro is not defined, this is a noop undef, just return. 2134 if (!MI) 2135 return; 2136 2137 if (!MI->isUsed() && MI->isWarnIfUnused()) 2138 Diag(MI->getDefinitionLoc(), diag::pp_macro_not_used); 2139 2140 if (MI->isWarnIfUnused()) 2141 WarnUnusedMacroLocs.erase(MI->getDefinitionLoc()); 2142 2143 appendMacroDirective(MacroNameTok.getIdentifierInfo(), 2144 AllocateUndefMacroDirective(MacroNameTok.getLocation())); 2145 } 2146 2147 2148 //===----------------------------------------------------------------------===// 2149 // Preprocessor Conditional Directive Handling. 2150 //===----------------------------------------------------------------------===// 2151 2152 /// HandleIfdefDirective - Implements the \#ifdef/\#ifndef directive. isIfndef 2153 /// is true when this is a \#ifndef directive. ReadAnyTokensBeforeDirective is 2154 /// true if any tokens have been returned or pp-directives activated before this 2155 /// \#ifndef has been lexed. 2156 /// 2157 void Preprocessor::HandleIfdefDirective(Token &Result, bool isIfndef, 2158 bool ReadAnyTokensBeforeDirective) { 2159 ++NumIf; 2160 Token DirectiveTok = Result; 2161 2162 Token MacroNameTok; 2163 ReadMacroName(MacroNameTok); 2164 2165 // Error reading macro name? If so, diagnostic already issued. 2166 if (MacroNameTok.is(tok::eod)) { 2167 // Skip code until we get to #endif. This helps with recovery by not 2168 // emitting an error when the #endif is reached. 2169 SkipExcludedConditionalBlock(DirectiveTok.getLocation(), 2170 /*Foundnonskip*/false, /*FoundElse*/false); 2171 return; 2172 } 2173 2174 // Check to see if this is the last token on the #if[n]def line. 2175 CheckEndOfDirective(isIfndef ? "ifndef" : "ifdef"); 2176 2177 IdentifierInfo *MII = MacroNameTok.getIdentifierInfo(); 2178 MacroDirective *MD = getMacroDirective(MII); 2179 MacroInfo *MI = MD ? MD->getMacroInfo() : nullptr; 2180 2181 if (CurPPLexer->getConditionalStackDepth() == 0) { 2182 // If the start of a top-level #ifdef and if the macro is not defined, 2183 // inform MIOpt that this might be the start of a proper include guard. 2184 // Otherwise it is some other form of unknown conditional which we can't 2185 // handle. 2186 if (!ReadAnyTokensBeforeDirective && !MI) { 2187 assert(isIfndef && "#ifdef shouldn't reach here"); 2188 CurPPLexer->MIOpt.EnterTopLevelIfndef(MII, MacroNameTok.getLocation()); 2189 } else 2190 CurPPLexer->MIOpt.EnterTopLevelConditional(); 2191 } 2192 2193 // If there is a macro, process it. 2194 if (MI) // Mark it used. 2195 markMacroAsUsed(MI); 2196 2197 if (Callbacks) { 2198 if (isIfndef) 2199 Callbacks->Ifndef(DirectiveTok.getLocation(), MacroNameTok, MD); 2200 else 2201 Callbacks->Ifdef(DirectiveTok.getLocation(), MacroNameTok, MD); 2202 } 2203 2204 // Should we include the stuff contained by this directive? 2205 if (!MI == isIfndef) { 2206 // Yes, remember that we are inside a conditional, then lex the next token. 2207 CurPPLexer->pushConditionalLevel(DirectiveTok.getLocation(), 2208 /*wasskip*/false, /*foundnonskip*/true, 2209 /*foundelse*/false); 2210 } else { 2211 // No, skip the contents of this block. 2212 SkipExcludedConditionalBlock(DirectiveTok.getLocation(), 2213 /*Foundnonskip*/false, 2214 /*FoundElse*/false); 2215 } 2216 } 2217 2218 /// HandleIfDirective - Implements the \#if directive. 2219 /// 2220 void Preprocessor::HandleIfDirective(Token &IfToken, 2221 bool ReadAnyTokensBeforeDirective) { 2222 ++NumIf; 2223 2224 // Parse and evaluate the conditional expression. 2225 IdentifierInfo *IfNDefMacro = nullptr; 2226 const SourceLocation ConditionalBegin = CurPPLexer->getSourceLocation(); 2227 const bool ConditionalTrue = EvaluateDirectiveExpression(IfNDefMacro); 2228 const SourceLocation ConditionalEnd = CurPPLexer->getSourceLocation(); 2229 2230 // If this condition is equivalent to #ifndef X, and if this is the first 2231 // directive seen, handle it for the multiple-include optimization. 2232 if (CurPPLexer->getConditionalStackDepth() == 0) { 2233 if (!ReadAnyTokensBeforeDirective && IfNDefMacro && ConditionalTrue) 2234 // FIXME: Pass in the location of the macro name, not the 'if' token. 2235 CurPPLexer->MIOpt.EnterTopLevelIfndef(IfNDefMacro, IfToken.getLocation()); 2236 else 2237 CurPPLexer->MIOpt.EnterTopLevelConditional(); 2238 } 2239 2240 if (Callbacks) 2241 Callbacks->If(IfToken.getLocation(), 2242 SourceRange(ConditionalBegin, ConditionalEnd), 2243 (ConditionalTrue ? PPCallbacks::CVK_True : PPCallbacks::CVK_False)); 2244 2245 // Should we include the stuff contained by this directive? 2246 if (ConditionalTrue) { 2247 // Yes, remember that we are inside a conditional, then lex the next token. 2248 CurPPLexer->pushConditionalLevel(IfToken.getLocation(), /*wasskip*/false, 2249 /*foundnonskip*/true, /*foundelse*/false); 2250 } else { 2251 // No, skip the contents of this block. 2252 SkipExcludedConditionalBlock(IfToken.getLocation(), /*Foundnonskip*/false, 2253 /*FoundElse*/false); 2254 } 2255 } 2256 2257 /// HandleEndifDirective - Implements the \#endif directive. 2258 /// 2259 void Preprocessor::HandleEndifDirective(Token &EndifToken) { 2260 ++NumEndif; 2261 2262 // Check that this is the whole directive. 2263 CheckEndOfDirective("endif"); 2264 2265 PPConditionalInfo CondInfo; 2266 if (CurPPLexer->popConditionalLevel(CondInfo)) { 2267 // No conditionals on the stack: this is an #endif without an #if. 2268 Diag(EndifToken, diag::err_pp_endif_without_if); 2269 return; 2270 } 2271 2272 // If this the end of a top-level #endif, inform MIOpt. 2273 if (CurPPLexer->getConditionalStackDepth() == 0) 2274 CurPPLexer->MIOpt.ExitTopLevelConditional(); 2275 2276 assert(!CondInfo.WasSkipping && !CurPPLexer->LexingRawMode && 2277 "This code should only be reachable in the non-skipping case!"); 2278 2279 if (Callbacks) 2280 Callbacks->Endif(EndifToken.getLocation(), CondInfo.IfLoc); 2281 } 2282 2283 /// HandleElseDirective - Implements the \#else directive. 2284 /// 2285 void Preprocessor::HandleElseDirective(Token &Result) { 2286 ++NumElse; 2287 2288 // #else directive in a non-skipping conditional... start skipping. 2289 CheckEndOfDirective("else"); 2290 2291 PPConditionalInfo CI; 2292 if (CurPPLexer->popConditionalLevel(CI)) { 2293 Diag(Result, diag::pp_err_else_without_if); 2294 return; 2295 } 2296 2297 // If this is a top-level #else, inform the MIOpt. 2298 if (CurPPLexer->getConditionalStackDepth() == 0) 2299 CurPPLexer->MIOpt.EnterTopLevelConditional(); 2300 2301 // If this is a #else with a #else before it, report the error. 2302 if (CI.FoundElse) Diag(Result, diag::pp_err_else_after_else); 2303 2304 if (Callbacks) 2305 Callbacks->Else(Result.getLocation(), CI.IfLoc); 2306 2307 // Finally, skip the rest of the contents of this block. 2308 SkipExcludedConditionalBlock(CI.IfLoc, /*Foundnonskip*/true, 2309 /*FoundElse*/true, Result.getLocation()); 2310 } 2311 2312 /// HandleElifDirective - Implements the \#elif directive. 2313 /// 2314 void Preprocessor::HandleElifDirective(Token &ElifToken) { 2315 ++NumElse; 2316 2317 // #elif directive in a non-skipping conditional... start skipping. 2318 // We don't care what the condition is, because we will always skip it (since 2319 // the block immediately before it was included). 2320 const SourceLocation ConditionalBegin = CurPPLexer->getSourceLocation(); 2321 DiscardUntilEndOfDirective(); 2322 const SourceLocation ConditionalEnd = CurPPLexer->getSourceLocation(); 2323 2324 PPConditionalInfo CI; 2325 if (CurPPLexer->popConditionalLevel(CI)) { 2326 Diag(ElifToken, diag::pp_err_elif_without_if); 2327 return; 2328 } 2329 2330 // If this is a top-level #elif, inform the MIOpt. 2331 if (CurPPLexer->getConditionalStackDepth() == 0) 2332 CurPPLexer->MIOpt.EnterTopLevelConditional(); 2333 2334 // If this is a #elif with a #else before it, report the error. 2335 if (CI.FoundElse) Diag(ElifToken, diag::pp_err_elif_after_else); 2336 2337 if (Callbacks) 2338 Callbacks->Elif(ElifToken.getLocation(), 2339 SourceRange(ConditionalBegin, ConditionalEnd), 2340 PPCallbacks::CVK_NotEvaluated, CI.IfLoc); 2341 2342 // Finally, skip the rest of the contents of this block. 2343 SkipExcludedConditionalBlock(CI.IfLoc, /*Foundnonskip*/true, 2344 /*FoundElse*/CI.FoundElse, 2345 ElifToken.getLocation()); 2346 } 2347