1 //===--- MacroExpansion.cpp - Top level Macro Expansion -------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file implements the top level handling of macro expansion for the 11 // preprocessor. 12 // 13 //===----------------------------------------------------------------------===// 14 15 #include "clang/Basic/Attributes.h" 16 #include "clang/Basic/FileManager.h" 17 #include "clang/Basic/IdentifierTable.h" 18 #include "clang/Basic/LLVM.h" 19 #include "clang/Basic/LangOptions.h" 20 #include "clang/Basic/ObjCRuntime.h" 21 #include "clang/Basic/SourceLocation.h" 22 #include "clang/Basic/TargetInfo.h" 23 #include "clang/Lex/CodeCompletionHandler.h" 24 #include "clang/Lex/DirectoryLookup.h" 25 #include "clang/Lex/ExternalPreprocessorSource.h" 26 #include "clang/Lex/LexDiagnostic.h" 27 #include "clang/Lex/MacroArgs.h" 28 #include "clang/Lex/MacroInfo.h" 29 #include "clang/Lex/Preprocessor.h" 30 #include "clang/Lex/PreprocessorLexer.h" 31 #include "clang/Lex/PTHLexer.h" 32 #include "clang/Lex/Token.h" 33 #include "llvm/ADT/ArrayRef.h" 34 #include "llvm/ADT/DenseMap.h" 35 #include "llvm/ADT/DenseSet.h" 36 #include "llvm/ADT/FoldingSet.h" 37 #include "llvm/ADT/None.h" 38 #include "llvm/ADT/Optional.h" 39 #include "llvm/ADT/SmallString.h" 40 #include "llvm/ADT/SmallVector.h" 41 #include "llvm/ADT/STLExtras.h" 42 #include "llvm/ADT/StringRef.h" 43 #include "llvm/ADT/StringSwitch.h" 44 #include "llvm/Support/Casting.h" 45 #include "llvm/Support/ErrorHandling.h" 46 #include "llvm/Support/Format.h" 47 #include "llvm/Support/raw_ostream.h" 48 #include <algorithm> 49 #include <cassert> 50 #include <cstddef> 51 #include <cstring> 52 #include <ctime> 53 #include <string> 54 #include <tuple> 55 #include <utility> 56 57 using namespace clang; 58 59 MacroDirective * 60 Preprocessor::getLocalMacroDirectiveHistory(const IdentifierInfo *II) const { 61 if (!II->hadMacroDefinition()) 62 return nullptr; 63 auto Pos = CurSubmoduleState->Macros.find(II); 64 return Pos == CurSubmoduleState->Macros.end() ? nullptr 65 : Pos->second.getLatest(); 66 } 67 68 void Preprocessor::appendMacroDirective(IdentifierInfo *II, MacroDirective *MD){ 69 assert(MD && "MacroDirective should be non-zero!"); 70 assert(!MD->getPrevious() && "Already attached to a MacroDirective history."); 71 72 MacroState &StoredMD = CurSubmoduleState->Macros[II]; 73 auto *OldMD = StoredMD.getLatest(); 74 MD->setPrevious(OldMD); 75 StoredMD.setLatest(MD); 76 StoredMD.overrideActiveModuleMacros(*this, II); 77 78 if (needModuleMacros()) { 79 // Track that we created a new macro directive, so we know we should 80 // consider building a ModuleMacro for it when we get to the end of 81 // the module. 82 PendingModuleMacroNames.push_back(II); 83 } 84 85 // Set up the identifier as having associated macro history. 86 II->setHasMacroDefinition(true); 87 if (!MD->isDefined() && LeafModuleMacros.find(II) == LeafModuleMacros.end()) 88 II->setHasMacroDefinition(false); 89 if (II->isFromAST()) 90 II->setChangedSinceDeserialization(); 91 } 92 93 void Preprocessor::setLoadedMacroDirective(IdentifierInfo *II, 94 MacroDirective *ED, 95 MacroDirective *MD) { 96 // Normally, when a macro is defined, it goes through appendMacroDirective() 97 // above, which chains a macro to previous defines, undefs, etc. 98 // However, in a pch, the whole macro history up to the end of the pch is 99 // stored, so ASTReader goes through this function instead. 100 // However, built-in macros are already registered in the Preprocessor 101 // ctor, and ASTWriter stops writing the macro chain at built-in macros, 102 // so in that case the chain from the pch needs to be spliced to the existing 103 // built-in. 104 105 assert(II && MD); 106 MacroState &StoredMD = CurSubmoduleState->Macros[II]; 107 108 if (auto *OldMD = StoredMD.getLatest()) { 109 // shouldIgnoreMacro() in ASTWriter also stops at macros from the 110 // predefines buffer in module builds. However, in module builds, modules 111 // are loaded completely before predefines are processed, so StoredMD 112 // will be nullptr for them when they're loaded. StoredMD should only be 113 // non-nullptr for builtins read from a pch file. 114 assert(OldMD->getMacroInfo()->isBuiltinMacro() && 115 "only built-ins should have an entry here"); 116 assert(!OldMD->getPrevious() && "builtin should only have a single entry"); 117 ED->setPrevious(OldMD); 118 StoredMD.setLatest(MD); 119 } else { 120 StoredMD = MD; 121 } 122 123 // Setup the identifier as having associated macro history. 124 II->setHasMacroDefinition(true); 125 if (!MD->isDefined() && LeafModuleMacros.find(II) == LeafModuleMacros.end()) 126 II->setHasMacroDefinition(false); 127 } 128 129 ModuleMacro *Preprocessor::addModuleMacro(Module *Mod, IdentifierInfo *II, 130 MacroInfo *Macro, 131 ArrayRef<ModuleMacro *> Overrides, 132 bool &New) { 133 llvm::FoldingSetNodeID ID; 134 ModuleMacro::Profile(ID, Mod, II); 135 136 void *InsertPos; 137 if (auto *MM = ModuleMacros.FindNodeOrInsertPos(ID, InsertPos)) { 138 New = false; 139 return MM; 140 } 141 142 auto *MM = ModuleMacro::create(*this, Mod, II, Macro, Overrides); 143 ModuleMacros.InsertNode(MM, InsertPos); 144 145 // Each overridden macro is now overridden by one more macro. 146 bool HidAny = false; 147 for (auto *O : Overrides) { 148 HidAny |= (O->NumOverriddenBy == 0); 149 ++O->NumOverriddenBy; 150 } 151 152 // If we were the first overrider for any macro, it's no longer a leaf. 153 auto &LeafMacros = LeafModuleMacros[II]; 154 if (HidAny) { 155 LeafMacros.erase(std::remove_if(LeafMacros.begin(), LeafMacros.end(), 156 [](ModuleMacro *MM) { 157 return MM->NumOverriddenBy != 0; 158 }), 159 LeafMacros.end()); 160 } 161 162 // The new macro is always a leaf macro. 163 LeafMacros.push_back(MM); 164 // The identifier now has defined macros (that may or may not be visible). 165 II->setHasMacroDefinition(true); 166 167 New = true; 168 return MM; 169 } 170 171 ModuleMacro *Preprocessor::getModuleMacro(Module *Mod, IdentifierInfo *II) { 172 llvm::FoldingSetNodeID ID; 173 ModuleMacro::Profile(ID, Mod, II); 174 175 void *InsertPos; 176 return ModuleMacros.FindNodeOrInsertPos(ID, InsertPos); 177 } 178 179 void Preprocessor::updateModuleMacroInfo(const IdentifierInfo *II, 180 ModuleMacroInfo &Info) { 181 assert(Info.ActiveModuleMacrosGeneration != 182 CurSubmoduleState->VisibleModules.getGeneration() && 183 "don't need to update this macro name info"); 184 Info.ActiveModuleMacrosGeneration = 185 CurSubmoduleState->VisibleModules.getGeneration(); 186 187 auto Leaf = LeafModuleMacros.find(II); 188 if (Leaf == LeafModuleMacros.end()) { 189 // No imported macros at all: nothing to do. 190 return; 191 } 192 193 Info.ActiveModuleMacros.clear(); 194 195 // Every macro that's locally overridden is overridden by a visible macro. 196 llvm::DenseMap<ModuleMacro *, int> NumHiddenOverrides; 197 for (auto *O : Info.OverriddenMacros) 198 NumHiddenOverrides[O] = -1; 199 200 // Collect all macros that are not overridden by a visible macro. 201 llvm::SmallVector<ModuleMacro *, 16> Worklist; 202 for (auto *LeafMM : Leaf->second) { 203 assert(LeafMM->getNumOverridingMacros() == 0 && "leaf macro overridden"); 204 if (NumHiddenOverrides.lookup(LeafMM) == 0) 205 Worklist.push_back(LeafMM); 206 } 207 while (!Worklist.empty()) { 208 auto *MM = Worklist.pop_back_val(); 209 if (CurSubmoduleState->VisibleModules.isVisible(MM->getOwningModule())) { 210 // We only care about collecting definitions; undefinitions only act 211 // to override other definitions. 212 if (MM->getMacroInfo()) 213 Info.ActiveModuleMacros.push_back(MM); 214 } else { 215 for (auto *O : MM->overrides()) 216 if ((unsigned)++NumHiddenOverrides[O] == O->getNumOverridingMacros()) 217 Worklist.push_back(O); 218 } 219 } 220 // Our reverse postorder walk found the macros in reverse order. 221 std::reverse(Info.ActiveModuleMacros.begin(), Info.ActiveModuleMacros.end()); 222 223 // Determine whether the macro name is ambiguous. 224 MacroInfo *MI = nullptr; 225 bool IsSystemMacro = true; 226 bool IsAmbiguous = false; 227 if (auto *MD = Info.MD) { 228 while (MD && isa<VisibilityMacroDirective>(MD)) 229 MD = MD->getPrevious(); 230 if (auto *DMD = dyn_cast_or_null<DefMacroDirective>(MD)) { 231 MI = DMD->getInfo(); 232 IsSystemMacro &= SourceMgr.isInSystemHeader(DMD->getLocation()); 233 } 234 } 235 for (auto *Active : Info.ActiveModuleMacros) { 236 auto *NewMI = Active->getMacroInfo(); 237 238 // Before marking the macro as ambiguous, check if this is a case where 239 // both macros are in system headers. If so, we trust that the system 240 // did not get it wrong. This also handles cases where Clang's own 241 // headers have a different spelling of certain system macros: 242 // #define LONG_MAX __LONG_MAX__ (clang's limits.h) 243 // #define LONG_MAX 0x7fffffffffffffffL (system's limits.h) 244 // 245 // FIXME: Remove the defined-in-system-headers check. clang's limits.h 246 // overrides the system limits.h's macros, so there's no conflict here. 247 if (MI && NewMI != MI && 248 !MI->isIdenticalTo(*NewMI, *this, /*Syntactically=*/true)) 249 IsAmbiguous = true; 250 IsSystemMacro &= Active->getOwningModule()->IsSystem || 251 SourceMgr.isInSystemHeader(NewMI->getDefinitionLoc()); 252 MI = NewMI; 253 } 254 Info.IsAmbiguous = IsAmbiguous && !IsSystemMacro; 255 } 256 257 void Preprocessor::dumpMacroInfo(const IdentifierInfo *II) { 258 ArrayRef<ModuleMacro*> Leaf; 259 auto LeafIt = LeafModuleMacros.find(II); 260 if (LeafIt != LeafModuleMacros.end()) 261 Leaf = LeafIt->second; 262 const MacroState *State = nullptr; 263 auto Pos = CurSubmoduleState->Macros.find(II); 264 if (Pos != CurSubmoduleState->Macros.end()) 265 State = &Pos->second; 266 267 llvm::errs() << "MacroState " << State << " " << II->getNameStart(); 268 if (State && State->isAmbiguous(*this, II)) 269 llvm::errs() << " ambiguous"; 270 if (State && !State->getOverriddenMacros().empty()) { 271 llvm::errs() << " overrides"; 272 for (auto *O : State->getOverriddenMacros()) 273 llvm::errs() << " " << O->getOwningModule()->getFullModuleName(); 274 } 275 llvm::errs() << "\n"; 276 277 // Dump local macro directives. 278 for (auto *MD = State ? State->getLatest() : nullptr; MD; 279 MD = MD->getPrevious()) { 280 llvm::errs() << " "; 281 MD->dump(); 282 } 283 284 // Dump module macros. 285 llvm::DenseSet<ModuleMacro*> Active; 286 for (auto *MM : State ? State->getActiveModuleMacros(*this, II) : None) 287 Active.insert(MM); 288 llvm::DenseSet<ModuleMacro*> Visited; 289 llvm::SmallVector<ModuleMacro *, 16> Worklist(Leaf.begin(), Leaf.end()); 290 while (!Worklist.empty()) { 291 auto *MM = Worklist.pop_back_val(); 292 llvm::errs() << " ModuleMacro " << MM << " " 293 << MM->getOwningModule()->getFullModuleName(); 294 if (!MM->getMacroInfo()) 295 llvm::errs() << " undef"; 296 297 if (Active.count(MM)) 298 llvm::errs() << " active"; 299 else if (!CurSubmoduleState->VisibleModules.isVisible( 300 MM->getOwningModule())) 301 llvm::errs() << " hidden"; 302 else if (MM->getMacroInfo()) 303 llvm::errs() << " overridden"; 304 305 if (!MM->overrides().empty()) { 306 llvm::errs() << " overrides"; 307 for (auto *O : MM->overrides()) { 308 llvm::errs() << " " << O->getOwningModule()->getFullModuleName(); 309 if (Visited.insert(O).second) 310 Worklist.push_back(O); 311 } 312 } 313 llvm::errs() << "\n"; 314 if (auto *MI = MM->getMacroInfo()) { 315 llvm::errs() << " "; 316 MI->dump(); 317 llvm::errs() << "\n"; 318 } 319 } 320 } 321 322 /// RegisterBuiltinMacro - Register the specified identifier in the identifier 323 /// table and mark it as a builtin macro to be expanded. 324 static IdentifierInfo *RegisterBuiltinMacro(Preprocessor &PP, const char *Name){ 325 // Get the identifier. 326 IdentifierInfo *Id = PP.getIdentifierInfo(Name); 327 328 // Mark it as being a macro that is builtin. 329 MacroInfo *MI = PP.AllocateMacroInfo(SourceLocation()); 330 MI->setIsBuiltinMacro(); 331 PP.appendDefMacroDirective(Id, MI); 332 return Id; 333 } 334 335 /// RegisterBuiltinMacros - Register builtin macros, such as __LINE__ with the 336 /// identifier table. 337 void Preprocessor::RegisterBuiltinMacros() { 338 Ident__LINE__ = RegisterBuiltinMacro(*this, "__LINE__"); 339 Ident__FILE__ = RegisterBuiltinMacro(*this, "__FILE__"); 340 Ident__DATE__ = RegisterBuiltinMacro(*this, "__DATE__"); 341 Ident__TIME__ = RegisterBuiltinMacro(*this, "__TIME__"); 342 Ident__COUNTER__ = RegisterBuiltinMacro(*this, "__COUNTER__"); 343 Ident_Pragma = RegisterBuiltinMacro(*this, "_Pragma"); 344 345 // C++ Standing Document Extensions. 346 if (LangOpts.CPlusPlus) 347 Ident__has_cpp_attribute = 348 RegisterBuiltinMacro(*this, "__has_cpp_attribute"); 349 else 350 Ident__has_cpp_attribute = nullptr; 351 352 // GCC Extensions. 353 Ident__BASE_FILE__ = RegisterBuiltinMacro(*this, "__BASE_FILE__"); 354 Ident__INCLUDE_LEVEL__ = RegisterBuiltinMacro(*this, "__INCLUDE_LEVEL__"); 355 Ident__TIMESTAMP__ = RegisterBuiltinMacro(*this, "__TIMESTAMP__"); 356 357 // Microsoft Extensions. 358 if (LangOpts.MicrosoftExt) { 359 Ident__identifier = RegisterBuiltinMacro(*this, "__identifier"); 360 Ident__pragma = RegisterBuiltinMacro(*this, "__pragma"); 361 } else { 362 Ident__identifier = nullptr; 363 Ident__pragma = nullptr; 364 } 365 366 // Clang Extensions. 367 Ident__has_feature = RegisterBuiltinMacro(*this, "__has_feature"); 368 Ident__has_extension = RegisterBuiltinMacro(*this, "__has_extension"); 369 Ident__has_builtin = RegisterBuiltinMacro(*this, "__has_builtin"); 370 Ident__has_attribute = RegisterBuiltinMacro(*this, "__has_attribute"); 371 Ident__has_c_attribute = RegisterBuiltinMacro(*this, "__has_c_attribute"); 372 Ident__has_declspec = RegisterBuiltinMacro(*this, "__has_declspec_attribute"); 373 Ident__has_include = RegisterBuiltinMacro(*this, "__has_include"); 374 Ident__has_include_next = RegisterBuiltinMacro(*this, "__has_include_next"); 375 Ident__has_warning = RegisterBuiltinMacro(*this, "__has_warning"); 376 Ident__is_identifier = RegisterBuiltinMacro(*this, "__is_identifier"); 377 Ident__is_target_arch = RegisterBuiltinMacro(*this, "__is_target_arch"); 378 Ident__is_target_vendor = RegisterBuiltinMacro(*this, "__is_target_vendor"); 379 Ident__is_target_os = RegisterBuiltinMacro(*this, "__is_target_os"); 380 Ident__is_target_environment = 381 RegisterBuiltinMacro(*this, "__is_target_environment"); 382 383 // Modules. 384 Ident__building_module = RegisterBuiltinMacro(*this, "__building_module"); 385 if (!LangOpts.CurrentModule.empty()) 386 Ident__MODULE__ = RegisterBuiltinMacro(*this, "__MODULE__"); 387 else 388 Ident__MODULE__ = nullptr; 389 } 390 391 /// isTrivialSingleTokenExpansion - Return true if MI, which has a single token 392 /// in its expansion, currently expands to that token literally. 393 static bool isTrivialSingleTokenExpansion(const MacroInfo *MI, 394 const IdentifierInfo *MacroIdent, 395 Preprocessor &PP) { 396 IdentifierInfo *II = MI->getReplacementToken(0).getIdentifierInfo(); 397 398 // If the token isn't an identifier, it's always literally expanded. 399 if (!II) return true; 400 401 // If the information about this identifier is out of date, update it from 402 // the external source. 403 if (II->isOutOfDate()) 404 PP.getExternalSource()->updateOutOfDateIdentifier(*II); 405 406 // If the identifier is a macro, and if that macro is enabled, it may be 407 // expanded so it's not a trivial expansion. 408 if (auto *ExpansionMI = PP.getMacroInfo(II)) 409 if (ExpansionMI->isEnabled() && 410 // Fast expanding "#define X X" is ok, because X would be disabled. 411 II != MacroIdent) 412 return false; 413 414 // If this is an object-like macro invocation, it is safe to trivially expand 415 // it. 416 if (MI->isObjectLike()) return true; 417 418 // If this is a function-like macro invocation, it's safe to trivially expand 419 // as long as the identifier is not a macro argument. 420 return std::find(MI->param_begin(), MI->param_end(), II) == MI->param_end(); 421 } 422 423 /// isNextPPTokenLParen - Determine whether the next preprocessor token to be 424 /// lexed is a '('. If so, consume the token and return true, if not, this 425 /// method should have no observable side-effect on the lexed tokens. 426 bool Preprocessor::isNextPPTokenLParen() { 427 // Do some quick tests for rejection cases. 428 unsigned Val; 429 if (CurLexer) 430 Val = CurLexer->isNextPPTokenLParen(); 431 else if (CurPTHLexer) 432 Val = CurPTHLexer->isNextPPTokenLParen(); 433 else 434 Val = CurTokenLexer->isNextTokenLParen(); 435 436 if (Val == 2) { 437 // We have run off the end. If it's a source file we don't 438 // examine enclosing ones (C99 5.1.1.2p4). Otherwise walk up the 439 // macro stack. 440 if (CurPPLexer) 441 return false; 442 for (const IncludeStackInfo &Entry : llvm::reverse(IncludeMacroStack)) { 443 if (Entry.TheLexer) 444 Val = Entry.TheLexer->isNextPPTokenLParen(); 445 else if (Entry.ThePTHLexer) 446 Val = Entry.ThePTHLexer->isNextPPTokenLParen(); 447 else 448 Val = Entry.TheTokenLexer->isNextTokenLParen(); 449 450 if (Val != 2) 451 break; 452 453 // Ran off the end of a source file? 454 if (Entry.ThePPLexer) 455 return false; 456 } 457 } 458 459 // Okay, if we know that the token is a '(', lex it and return. Otherwise we 460 // have found something that isn't a '(' or we found the end of the 461 // translation unit. In either case, return false. 462 return Val == 1; 463 } 464 465 /// HandleMacroExpandedIdentifier - If an identifier token is read that is to be 466 /// expanded as a macro, handle it and return the next token as 'Identifier'. 467 bool Preprocessor::HandleMacroExpandedIdentifier(Token &Identifier, 468 const MacroDefinition &M) { 469 MacroInfo *MI = M.getMacroInfo(); 470 471 // If this is a macro expansion in the "#if !defined(x)" line for the file, 472 // then the macro could expand to different things in other contexts, we need 473 // to disable the optimization in this case. 474 if (CurPPLexer) CurPPLexer->MIOpt.ExpandedMacro(); 475 476 // If this is a builtin macro, like __LINE__ or _Pragma, handle it specially. 477 if (MI->isBuiltinMacro()) { 478 if (Callbacks) 479 Callbacks->MacroExpands(Identifier, M, Identifier.getLocation(), 480 /*Args=*/nullptr); 481 ExpandBuiltinMacro(Identifier); 482 return true; 483 } 484 485 /// Args - If this is a function-like macro expansion, this contains, 486 /// for each macro argument, the list of tokens that were provided to the 487 /// invocation. 488 MacroArgs *Args = nullptr; 489 490 // Remember where the end of the expansion occurred. For an object-like 491 // macro, this is the identifier. For a function-like macro, this is the ')'. 492 SourceLocation ExpansionEnd = Identifier.getLocation(); 493 494 // If this is a function-like macro, read the arguments. 495 if (MI->isFunctionLike()) { 496 // Remember that we are now parsing the arguments to a macro invocation. 497 // Preprocessor directives used inside macro arguments are not portable, and 498 // this enables the warning. 499 InMacroArgs = true; 500 Args = ReadMacroCallArgumentList(Identifier, MI, ExpansionEnd); 501 502 // Finished parsing args. 503 InMacroArgs = false; 504 505 // If there was an error parsing the arguments, bail out. 506 if (!Args) return true; 507 508 ++NumFnMacroExpanded; 509 } else { 510 ++NumMacroExpanded; 511 } 512 513 // Notice that this macro has been used. 514 markMacroAsUsed(MI); 515 516 // Remember where the token is expanded. 517 SourceLocation ExpandLoc = Identifier.getLocation(); 518 SourceRange ExpansionRange(ExpandLoc, ExpansionEnd); 519 520 if (Callbacks) { 521 if (InMacroArgs) { 522 // We can have macro expansion inside a conditional directive while 523 // reading the function macro arguments. To ensure, in that case, that 524 // MacroExpands callbacks still happen in source order, queue this 525 // callback to have it happen after the function macro callback. 526 DelayedMacroExpandsCallbacks.push_back( 527 MacroExpandsInfo(Identifier, M, ExpansionRange)); 528 } else { 529 Callbacks->MacroExpands(Identifier, M, ExpansionRange, Args); 530 if (!DelayedMacroExpandsCallbacks.empty()) { 531 for (const MacroExpandsInfo &Info : DelayedMacroExpandsCallbacks) { 532 // FIXME: We lose macro args info with delayed callback. 533 Callbacks->MacroExpands(Info.Tok, Info.MD, Info.Range, 534 /*Args=*/nullptr); 535 } 536 DelayedMacroExpandsCallbacks.clear(); 537 } 538 } 539 } 540 541 // If the macro definition is ambiguous, complain. 542 if (M.isAmbiguous()) { 543 Diag(Identifier, diag::warn_pp_ambiguous_macro) 544 << Identifier.getIdentifierInfo(); 545 Diag(MI->getDefinitionLoc(), diag::note_pp_ambiguous_macro_chosen) 546 << Identifier.getIdentifierInfo(); 547 M.forAllDefinitions([&](const MacroInfo *OtherMI) { 548 if (OtherMI != MI) 549 Diag(OtherMI->getDefinitionLoc(), diag::note_pp_ambiguous_macro_other) 550 << Identifier.getIdentifierInfo(); 551 }); 552 } 553 554 // If we started lexing a macro, enter the macro expansion body. 555 556 // If this macro expands to no tokens, don't bother to push it onto the 557 // expansion stack, only to take it right back off. 558 if (MI->getNumTokens() == 0) { 559 // No need for arg info. 560 if (Args) Args->destroy(*this); 561 562 // Propagate whitespace info as if we had pushed, then popped, 563 // a macro context. 564 Identifier.setFlag(Token::LeadingEmptyMacro); 565 PropagateLineStartLeadingSpaceInfo(Identifier); 566 ++NumFastMacroExpanded; 567 return false; 568 } else if (MI->getNumTokens() == 1 && 569 isTrivialSingleTokenExpansion(MI, Identifier.getIdentifierInfo(), 570 *this)) { 571 // Otherwise, if this macro expands into a single trivially-expanded 572 // token: expand it now. This handles common cases like 573 // "#define VAL 42". 574 575 // No need for arg info. 576 if (Args) Args->destroy(*this); 577 578 // Propagate the isAtStartOfLine/hasLeadingSpace markers of the macro 579 // identifier to the expanded token. 580 bool isAtStartOfLine = Identifier.isAtStartOfLine(); 581 bool hasLeadingSpace = Identifier.hasLeadingSpace(); 582 583 // Replace the result token. 584 Identifier = MI->getReplacementToken(0); 585 586 // Restore the StartOfLine/LeadingSpace markers. 587 Identifier.setFlagValue(Token::StartOfLine , isAtStartOfLine); 588 Identifier.setFlagValue(Token::LeadingSpace, hasLeadingSpace); 589 590 // Update the tokens location to include both its expansion and physical 591 // locations. 592 SourceLocation Loc = 593 SourceMgr.createExpansionLoc(Identifier.getLocation(), ExpandLoc, 594 ExpansionEnd,Identifier.getLength()); 595 Identifier.setLocation(Loc); 596 597 // If this is a disabled macro or #define X X, we must mark the result as 598 // unexpandable. 599 if (IdentifierInfo *NewII = Identifier.getIdentifierInfo()) { 600 if (MacroInfo *NewMI = getMacroInfo(NewII)) 601 if (!NewMI->isEnabled() || NewMI == MI) { 602 Identifier.setFlag(Token::DisableExpand); 603 // Don't warn for "#define X X" like "#define bool bool" from 604 // stdbool.h. 605 if (NewMI != MI || MI->isFunctionLike()) 606 Diag(Identifier, diag::pp_disabled_macro_expansion); 607 } 608 } 609 610 // Since this is not an identifier token, it can't be macro expanded, so 611 // we're done. 612 ++NumFastMacroExpanded; 613 return true; 614 } 615 616 // Start expanding the macro. 617 EnterMacro(Identifier, ExpansionEnd, MI, Args); 618 return false; 619 } 620 621 enum Bracket { 622 Brace, 623 Paren 624 }; 625 626 /// CheckMatchedBrackets - Returns true if the braces and parentheses in the 627 /// token vector are properly nested. 628 static bool CheckMatchedBrackets(const SmallVectorImpl<Token> &Tokens) { 629 SmallVector<Bracket, 8> Brackets; 630 for (SmallVectorImpl<Token>::const_iterator I = Tokens.begin(), 631 E = Tokens.end(); 632 I != E; ++I) { 633 if (I->is(tok::l_paren)) { 634 Brackets.push_back(Paren); 635 } else if (I->is(tok::r_paren)) { 636 if (Brackets.empty() || Brackets.back() == Brace) 637 return false; 638 Brackets.pop_back(); 639 } else if (I->is(tok::l_brace)) { 640 Brackets.push_back(Brace); 641 } else if (I->is(tok::r_brace)) { 642 if (Brackets.empty() || Brackets.back() == Paren) 643 return false; 644 Brackets.pop_back(); 645 } 646 } 647 return Brackets.empty(); 648 } 649 650 /// GenerateNewArgTokens - Returns true if OldTokens can be converted to a new 651 /// vector of tokens in NewTokens. The new number of arguments will be placed 652 /// in NumArgs and the ranges which need to surrounded in parentheses will be 653 /// in ParenHints. 654 /// Returns false if the token stream cannot be changed. If this is because 655 /// of an initializer list starting a macro argument, the range of those 656 /// initializer lists will be place in InitLists. 657 static bool GenerateNewArgTokens(Preprocessor &PP, 658 SmallVectorImpl<Token> &OldTokens, 659 SmallVectorImpl<Token> &NewTokens, 660 unsigned &NumArgs, 661 SmallVectorImpl<SourceRange> &ParenHints, 662 SmallVectorImpl<SourceRange> &InitLists) { 663 if (!CheckMatchedBrackets(OldTokens)) 664 return false; 665 666 // Once it is known that the brackets are matched, only a simple count of the 667 // braces is needed. 668 unsigned Braces = 0; 669 670 // First token of a new macro argument. 671 SmallVectorImpl<Token>::iterator ArgStartIterator = OldTokens.begin(); 672 673 // First closing brace in a new macro argument. Used to generate 674 // SourceRanges for InitLists. 675 SmallVectorImpl<Token>::iterator ClosingBrace = OldTokens.end(); 676 NumArgs = 0; 677 Token TempToken; 678 // Set to true when a macro separator token is found inside a braced list. 679 // If true, the fixed argument spans multiple old arguments and ParenHints 680 // will be updated. 681 bool FoundSeparatorToken = false; 682 for (SmallVectorImpl<Token>::iterator I = OldTokens.begin(), 683 E = OldTokens.end(); 684 I != E; ++I) { 685 if (I->is(tok::l_brace)) { 686 ++Braces; 687 } else if (I->is(tok::r_brace)) { 688 --Braces; 689 if (Braces == 0 && ClosingBrace == E && FoundSeparatorToken) 690 ClosingBrace = I; 691 } else if (I->is(tok::eof)) { 692 // EOF token is used to separate macro arguments 693 if (Braces != 0) { 694 // Assume comma separator is actually braced list separator and change 695 // it back to a comma. 696 FoundSeparatorToken = true; 697 I->setKind(tok::comma); 698 I->setLength(1); 699 } else { // Braces == 0 700 // Separator token still separates arguments. 701 ++NumArgs; 702 703 // If the argument starts with a brace, it can't be fixed with 704 // parentheses. A different diagnostic will be given. 705 if (FoundSeparatorToken && ArgStartIterator->is(tok::l_brace)) { 706 InitLists.push_back( 707 SourceRange(ArgStartIterator->getLocation(), 708 PP.getLocForEndOfToken(ClosingBrace->getLocation()))); 709 ClosingBrace = E; 710 } 711 712 // Add left paren 713 if (FoundSeparatorToken) { 714 TempToken.startToken(); 715 TempToken.setKind(tok::l_paren); 716 TempToken.setLocation(ArgStartIterator->getLocation()); 717 TempToken.setLength(0); 718 NewTokens.push_back(TempToken); 719 } 720 721 // Copy over argument tokens 722 NewTokens.insert(NewTokens.end(), ArgStartIterator, I); 723 724 // Add right paren and store the paren locations in ParenHints 725 if (FoundSeparatorToken) { 726 SourceLocation Loc = PP.getLocForEndOfToken((I - 1)->getLocation()); 727 TempToken.startToken(); 728 TempToken.setKind(tok::r_paren); 729 TempToken.setLocation(Loc); 730 TempToken.setLength(0); 731 NewTokens.push_back(TempToken); 732 ParenHints.push_back(SourceRange(ArgStartIterator->getLocation(), 733 Loc)); 734 } 735 736 // Copy separator token 737 NewTokens.push_back(*I); 738 739 // Reset values 740 ArgStartIterator = I + 1; 741 FoundSeparatorToken = false; 742 } 743 } 744 } 745 746 return !ParenHints.empty() && InitLists.empty(); 747 } 748 749 /// ReadFunctionLikeMacroArgs - After reading "MACRO" and knowing that the next 750 /// token is the '(' of the macro, this method is invoked to read all of the 751 /// actual arguments specified for the macro invocation. This returns null on 752 /// error. 753 MacroArgs *Preprocessor::ReadMacroCallArgumentList(Token &MacroName, 754 MacroInfo *MI, 755 SourceLocation &MacroEnd) { 756 // The number of fixed arguments to parse. 757 unsigned NumFixedArgsLeft = MI->getNumParams(); 758 bool isVariadic = MI->isVariadic(); 759 760 // Outer loop, while there are more arguments, keep reading them. 761 Token Tok; 762 763 // Read arguments as unexpanded tokens. This avoids issues, e.g., where 764 // an argument value in a macro could expand to ',' or '(' or ')'. 765 LexUnexpandedToken(Tok); 766 assert(Tok.is(tok::l_paren) && "Error computing l-paren-ness?"); 767 768 // ArgTokens - Build up a list of tokens that make up each argument. Each 769 // argument is separated by an EOF token. Use a SmallVector so we can avoid 770 // heap allocations in the common case. 771 SmallVector<Token, 64> ArgTokens; 772 bool ContainsCodeCompletionTok = false; 773 bool FoundElidedComma = false; 774 775 SourceLocation TooManyArgsLoc; 776 777 unsigned NumActuals = 0; 778 while (Tok.isNot(tok::r_paren)) { 779 if (ContainsCodeCompletionTok && Tok.isOneOf(tok::eof, tok::eod)) 780 break; 781 782 assert(Tok.isOneOf(tok::l_paren, tok::comma) && 783 "only expect argument separators here"); 784 785 size_t ArgTokenStart = ArgTokens.size(); 786 SourceLocation ArgStartLoc = Tok.getLocation(); 787 788 // C99 6.10.3p11: Keep track of the number of l_parens we have seen. Note 789 // that we already consumed the first one. 790 unsigned NumParens = 0; 791 792 while (true) { 793 // Read arguments as unexpanded tokens. This avoids issues, e.g., where 794 // an argument value in a macro could expand to ',' or '(' or ')'. 795 LexUnexpandedToken(Tok); 796 797 if (Tok.isOneOf(tok::eof, tok::eod)) { // "#if f(<eof>" & "#if f(\n" 798 if (!ContainsCodeCompletionTok) { 799 Diag(MacroName, diag::err_unterm_macro_invoc); 800 Diag(MI->getDefinitionLoc(), diag::note_macro_here) 801 << MacroName.getIdentifierInfo(); 802 // Do not lose the EOF/EOD. Return it to the client. 803 MacroName = Tok; 804 return nullptr; 805 } 806 // Do not lose the EOF/EOD. 807 auto Toks = llvm::make_unique<Token[]>(1); 808 Toks[0] = Tok; 809 EnterTokenStream(std::move(Toks), 1, true); 810 break; 811 } else if (Tok.is(tok::r_paren)) { 812 // If we found the ) token, the macro arg list is done. 813 if (NumParens-- == 0) { 814 MacroEnd = Tok.getLocation(); 815 if (!ArgTokens.empty() && 816 ArgTokens.back().commaAfterElided()) { 817 FoundElidedComma = true; 818 } 819 break; 820 } 821 } else if (Tok.is(tok::l_paren)) { 822 ++NumParens; 823 } else if (Tok.is(tok::comma) && NumParens == 0 && 824 !(Tok.getFlags() & Token::IgnoredComma)) { 825 // In Microsoft-compatibility mode, single commas from nested macro 826 // expansions should not be considered as argument separators. We test 827 // for this with the IgnoredComma token flag above. 828 829 // Comma ends this argument if there are more fixed arguments expected. 830 // However, if this is a variadic macro, and this is part of the 831 // variadic part, then the comma is just an argument token. 832 if (!isVariadic) break; 833 if (NumFixedArgsLeft > 1) 834 break; 835 } else if (Tok.is(tok::comment) && !KeepMacroComments) { 836 // If this is a comment token in the argument list and we're just in 837 // -C mode (not -CC mode), discard the comment. 838 continue; 839 } else if (!Tok.isAnnotation() && Tok.getIdentifierInfo() != nullptr) { 840 // Reading macro arguments can cause macros that we are currently 841 // expanding from to be popped off the expansion stack. Doing so causes 842 // them to be reenabled for expansion. Here we record whether any 843 // identifiers we lex as macro arguments correspond to disabled macros. 844 // If so, we mark the token as noexpand. This is a subtle aspect of 845 // C99 6.10.3.4p2. 846 if (MacroInfo *MI = getMacroInfo(Tok.getIdentifierInfo())) 847 if (!MI->isEnabled()) 848 Tok.setFlag(Token::DisableExpand); 849 } else if (Tok.is(tok::code_completion)) { 850 ContainsCodeCompletionTok = true; 851 if (CodeComplete) 852 CodeComplete->CodeCompleteMacroArgument(MacroName.getIdentifierInfo(), 853 MI, NumActuals); 854 // Don't mark that we reached the code-completion point because the 855 // parser is going to handle the token and there will be another 856 // code-completion callback. 857 } 858 859 ArgTokens.push_back(Tok); 860 } 861 862 // If this was an empty argument list foo(), don't add this as an empty 863 // argument. 864 if (ArgTokens.empty() && Tok.getKind() == tok::r_paren) 865 break; 866 867 // If this is not a variadic macro, and too many args were specified, emit 868 // an error. 869 if (!isVariadic && NumFixedArgsLeft == 0 && TooManyArgsLoc.isInvalid()) { 870 if (ArgTokens.size() != ArgTokenStart) 871 TooManyArgsLoc = ArgTokens[ArgTokenStart].getLocation(); 872 else 873 TooManyArgsLoc = ArgStartLoc; 874 } 875 876 // Empty arguments are standard in C99 and C++0x, and are supported as an 877 // extension in other modes. 878 if (ArgTokens.size() == ArgTokenStart && !LangOpts.C99) 879 Diag(Tok, LangOpts.CPlusPlus11 ? 880 diag::warn_cxx98_compat_empty_fnmacro_arg : 881 diag::ext_empty_fnmacro_arg); 882 883 // Add a marker EOF token to the end of the token list for this argument. 884 Token EOFTok; 885 EOFTok.startToken(); 886 EOFTok.setKind(tok::eof); 887 EOFTok.setLocation(Tok.getLocation()); 888 EOFTok.setLength(0); 889 ArgTokens.push_back(EOFTok); 890 ++NumActuals; 891 if (!ContainsCodeCompletionTok && NumFixedArgsLeft != 0) 892 --NumFixedArgsLeft; 893 } 894 895 // Okay, we either found the r_paren. Check to see if we parsed too few 896 // arguments. 897 unsigned MinArgsExpected = MI->getNumParams(); 898 899 // If this is not a variadic macro, and too many args were specified, emit 900 // an error. 901 if (!isVariadic && NumActuals > MinArgsExpected && 902 !ContainsCodeCompletionTok) { 903 // Emit the diagnostic at the macro name in case there is a missing ). 904 // Emitting it at the , could be far away from the macro name. 905 Diag(TooManyArgsLoc, diag::err_too_many_args_in_macro_invoc); 906 Diag(MI->getDefinitionLoc(), diag::note_macro_here) 907 << MacroName.getIdentifierInfo(); 908 909 // Commas from braced initializer lists will be treated as argument 910 // separators inside macros. Attempt to correct for this with parentheses. 911 // TODO: See if this can be generalized to angle brackets for templates 912 // inside macro arguments. 913 914 SmallVector<Token, 4> FixedArgTokens; 915 unsigned FixedNumArgs = 0; 916 SmallVector<SourceRange, 4> ParenHints, InitLists; 917 if (!GenerateNewArgTokens(*this, ArgTokens, FixedArgTokens, FixedNumArgs, 918 ParenHints, InitLists)) { 919 if (!InitLists.empty()) { 920 DiagnosticBuilder DB = 921 Diag(MacroName, 922 diag::note_init_list_at_beginning_of_macro_argument); 923 for (SourceRange Range : InitLists) 924 DB << Range; 925 } 926 return nullptr; 927 } 928 if (FixedNumArgs != MinArgsExpected) 929 return nullptr; 930 931 DiagnosticBuilder DB = Diag(MacroName, diag::note_suggest_parens_for_macro); 932 for (SourceRange ParenLocation : ParenHints) { 933 DB << FixItHint::CreateInsertion(ParenLocation.getBegin(), "("); 934 DB << FixItHint::CreateInsertion(ParenLocation.getEnd(), ")"); 935 } 936 ArgTokens.swap(FixedArgTokens); 937 NumActuals = FixedNumArgs; 938 } 939 940 // See MacroArgs instance var for description of this. 941 bool isVarargsElided = false; 942 943 if (ContainsCodeCompletionTok) { 944 // Recover from not-fully-formed macro invocation during code-completion. 945 Token EOFTok; 946 EOFTok.startToken(); 947 EOFTok.setKind(tok::eof); 948 EOFTok.setLocation(Tok.getLocation()); 949 EOFTok.setLength(0); 950 for (; NumActuals < MinArgsExpected; ++NumActuals) 951 ArgTokens.push_back(EOFTok); 952 } 953 954 if (NumActuals < MinArgsExpected) { 955 // There are several cases where too few arguments is ok, handle them now. 956 if (NumActuals == 0 && MinArgsExpected == 1) { 957 // #define A(X) or #define A(...) ---> A() 958 959 // If there is exactly one argument, and that argument is missing, 960 // then we have an empty "()" argument empty list. This is fine, even if 961 // the macro expects one argument (the argument is just empty). 962 isVarargsElided = MI->isVariadic(); 963 } else if ((FoundElidedComma || MI->isVariadic()) && 964 (NumActuals+1 == MinArgsExpected || // A(x, ...) -> A(X) 965 (NumActuals == 0 && MinArgsExpected == 2))) {// A(x,...) -> A() 966 // Varargs where the named vararg parameter is missing: OK as extension. 967 // #define A(x, ...) 968 // A("blah") 969 // 970 // If the macro contains the comma pasting extension, the diagnostic 971 // is suppressed; we know we'll get another diagnostic later. 972 if (!MI->hasCommaPasting()) { 973 Diag(Tok, diag::ext_missing_varargs_arg); 974 Diag(MI->getDefinitionLoc(), diag::note_macro_here) 975 << MacroName.getIdentifierInfo(); 976 } 977 978 // Remember this occurred, allowing us to elide the comma when used for 979 // cases like: 980 // #define A(x, foo...) blah(a, ## foo) 981 // #define B(x, ...) blah(a, ## __VA_ARGS__) 982 // #define C(...) blah(a, ## __VA_ARGS__) 983 // A(x) B(x) C() 984 isVarargsElided = true; 985 } else if (!ContainsCodeCompletionTok) { 986 // Otherwise, emit the error. 987 Diag(Tok, diag::err_too_few_args_in_macro_invoc); 988 Diag(MI->getDefinitionLoc(), diag::note_macro_here) 989 << MacroName.getIdentifierInfo(); 990 return nullptr; 991 } 992 993 // Add a marker EOF token to the end of the token list for this argument. 994 SourceLocation EndLoc = Tok.getLocation(); 995 Tok.startToken(); 996 Tok.setKind(tok::eof); 997 Tok.setLocation(EndLoc); 998 Tok.setLength(0); 999 ArgTokens.push_back(Tok); 1000 1001 // If we expect two arguments, add both as empty. 1002 if (NumActuals == 0 && MinArgsExpected == 2) 1003 ArgTokens.push_back(Tok); 1004 1005 } else if (NumActuals > MinArgsExpected && !MI->isVariadic() && 1006 !ContainsCodeCompletionTok) { 1007 // Emit the diagnostic at the macro name in case there is a missing ). 1008 // Emitting it at the , could be far away from the macro name. 1009 Diag(MacroName, diag::err_too_many_args_in_macro_invoc); 1010 Diag(MI->getDefinitionLoc(), diag::note_macro_here) 1011 << MacroName.getIdentifierInfo(); 1012 return nullptr; 1013 } 1014 1015 return MacroArgs::create(MI, ArgTokens, isVarargsElided, *this); 1016 } 1017 1018 /// Keeps macro expanded tokens for TokenLexers. 1019 // 1020 /// Works like a stack; a TokenLexer adds the macro expanded tokens that is 1021 /// going to lex in the cache and when it finishes the tokens are removed 1022 /// from the end of the cache. 1023 Token *Preprocessor::cacheMacroExpandedTokens(TokenLexer *tokLexer, 1024 ArrayRef<Token> tokens) { 1025 assert(tokLexer); 1026 if (tokens.empty()) 1027 return nullptr; 1028 1029 size_t newIndex = MacroExpandedTokens.size(); 1030 bool cacheNeedsToGrow = tokens.size() > 1031 MacroExpandedTokens.capacity()-MacroExpandedTokens.size(); 1032 MacroExpandedTokens.append(tokens.begin(), tokens.end()); 1033 1034 if (cacheNeedsToGrow) { 1035 // Go through all the TokenLexers whose 'Tokens' pointer points in the 1036 // buffer and update the pointers to the (potential) new buffer array. 1037 for (const auto &Lexer : MacroExpandingLexersStack) { 1038 TokenLexer *prevLexer; 1039 size_t tokIndex; 1040 std::tie(prevLexer, tokIndex) = Lexer; 1041 prevLexer->Tokens = MacroExpandedTokens.data() + tokIndex; 1042 } 1043 } 1044 1045 MacroExpandingLexersStack.push_back(std::make_pair(tokLexer, newIndex)); 1046 return MacroExpandedTokens.data() + newIndex; 1047 } 1048 1049 void Preprocessor::removeCachedMacroExpandedTokensOfLastLexer() { 1050 assert(!MacroExpandingLexersStack.empty()); 1051 size_t tokIndex = MacroExpandingLexersStack.back().second; 1052 assert(tokIndex < MacroExpandedTokens.size()); 1053 // Pop the cached macro expanded tokens from the end. 1054 MacroExpandedTokens.resize(tokIndex); 1055 MacroExpandingLexersStack.pop_back(); 1056 } 1057 1058 /// ComputeDATE_TIME - Compute the current time, enter it into the specified 1059 /// scratch buffer, then return DATELoc/TIMELoc locations with the position of 1060 /// the identifier tokens inserted. 1061 static void ComputeDATE_TIME(SourceLocation &DATELoc, SourceLocation &TIMELoc, 1062 Preprocessor &PP) { 1063 time_t TT = time(nullptr); 1064 struct tm *TM = localtime(&TT); 1065 1066 static const char * const Months[] = { 1067 "Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec" 1068 }; 1069 1070 { 1071 SmallString<32> TmpBuffer; 1072 llvm::raw_svector_ostream TmpStream(TmpBuffer); 1073 TmpStream << llvm::format("\"%s %2d %4d\"", Months[TM->tm_mon], 1074 TM->tm_mday, TM->tm_year + 1900); 1075 Token TmpTok; 1076 TmpTok.startToken(); 1077 PP.CreateString(TmpStream.str(), TmpTok); 1078 DATELoc = TmpTok.getLocation(); 1079 } 1080 1081 { 1082 SmallString<32> TmpBuffer; 1083 llvm::raw_svector_ostream TmpStream(TmpBuffer); 1084 TmpStream << llvm::format("\"%02d:%02d:%02d\"", 1085 TM->tm_hour, TM->tm_min, TM->tm_sec); 1086 Token TmpTok; 1087 TmpTok.startToken(); 1088 PP.CreateString(TmpStream.str(), TmpTok); 1089 TIMELoc = TmpTok.getLocation(); 1090 } 1091 } 1092 1093 /// HasFeature - Return true if we recognize and implement the feature 1094 /// specified by the identifier as a standard language feature. 1095 static bool HasFeature(const Preprocessor &PP, StringRef Feature) { 1096 const LangOptions &LangOpts = PP.getLangOpts(); 1097 1098 // Normalize the feature name, __foo__ becomes foo. 1099 if (Feature.startswith("__") && Feature.endswith("__") && Feature.size() >= 4) 1100 Feature = Feature.substr(2, Feature.size() - 4); 1101 1102 #define FEATURE(Name, Predicate) .Case(#Name, Predicate) 1103 return llvm::StringSwitch<bool>(Feature) 1104 #include "clang/Basic/Features.def" 1105 .Default(false); 1106 #undef FEATURE 1107 } 1108 1109 /// HasExtension - Return true if we recognize and implement the feature 1110 /// specified by the identifier, either as an extension or a standard language 1111 /// feature. 1112 static bool HasExtension(const Preprocessor &PP, StringRef Extension) { 1113 if (HasFeature(PP, Extension)) 1114 return true; 1115 1116 // If the use of an extension results in an error diagnostic, extensions are 1117 // effectively unavailable, so just return false here. 1118 if (PP.getDiagnostics().getExtensionHandlingBehavior() >= 1119 diag::Severity::Error) 1120 return false; 1121 1122 const LangOptions &LangOpts = PP.getLangOpts(); 1123 1124 // Normalize the extension name, __foo__ becomes foo. 1125 if (Extension.startswith("__") && Extension.endswith("__") && 1126 Extension.size() >= 4) 1127 Extension = Extension.substr(2, Extension.size() - 4); 1128 1129 // Because we inherit the feature list from HasFeature, this string switch 1130 // must be less restrictive than HasFeature's. 1131 #define EXTENSION(Name, Predicate) .Case(#Name, Predicate) 1132 return llvm::StringSwitch<bool>(Extension) 1133 #include "clang/Basic/Features.def" 1134 .Default(false); 1135 #undef EXTENSION 1136 } 1137 1138 /// EvaluateHasIncludeCommon - Process a '__has_include("path")' 1139 /// or '__has_include_next("path")' expression. 1140 /// Returns true if successful. 1141 static bool EvaluateHasIncludeCommon(Token &Tok, 1142 IdentifierInfo *II, Preprocessor &PP, 1143 const DirectoryLookup *LookupFrom, 1144 const FileEntry *LookupFromFile) { 1145 // Save the location of the current token. If a '(' is later found, use 1146 // that location. If not, use the end of this location instead. 1147 SourceLocation LParenLoc = Tok.getLocation(); 1148 1149 // These expressions are only allowed within a preprocessor directive. 1150 if (!PP.isParsingIfOrElifDirective()) { 1151 PP.Diag(LParenLoc, diag::err_pp_directive_required) << II; 1152 // Return a valid identifier token. 1153 assert(Tok.is(tok::identifier)); 1154 Tok.setIdentifierInfo(II); 1155 return false; 1156 } 1157 1158 // Get '('. 1159 PP.LexNonComment(Tok); 1160 1161 // Ensure we have a '('. 1162 if (Tok.isNot(tok::l_paren)) { 1163 // No '(', use end of last token. 1164 LParenLoc = PP.getLocForEndOfToken(LParenLoc); 1165 PP.Diag(LParenLoc, diag::err_pp_expected_after) << II << tok::l_paren; 1166 // If the next token looks like a filename or the start of one, 1167 // assume it is and process it as such. 1168 if (!Tok.is(tok::angle_string_literal) && !Tok.is(tok::string_literal) && 1169 !Tok.is(tok::less)) 1170 return false; 1171 } else { 1172 // Save '(' location for possible missing ')' message. 1173 LParenLoc = Tok.getLocation(); 1174 1175 if (PP.getCurrentLexer()) { 1176 // Get the file name. 1177 PP.getCurrentLexer()->LexIncludeFilename(Tok); 1178 } else { 1179 // We're in a macro, so we can't use LexIncludeFilename; just 1180 // grab the next token. 1181 PP.Lex(Tok); 1182 } 1183 } 1184 1185 // Reserve a buffer to get the spelling. 1186 SmallString<128> FilenameBuffer; 1187 StringRef Filename; 1188 SourceLocation EndLoc; 1189 1190 switch (Tok.getKind()) { 1191 case tok::eod: 1192 // If the token kind is EOD, the error has already been diagnosed. 1193 return false; 1194 1195 case tok::angle_string_literal: 1196 case tok::string_literal: { 1197 bool Invalid = false; 1198 Filename = PP.getSpelling(Tok, FilenameBuffer, &Invalid); 1199 if (Invalid) 1200 return false; 1201 break; 1202 } 1203 1204 case tok::less: 1205 // This could be a <foo/bar.h> file coming from a macro expansion. In this 1206 // case, glue the tokens together into FilenameBuffer and interpret those. 1207 FilenameBuffer.push_back('<'); 1208 if (PP.ConcatenateIncludeName(FilenameBuffer, EndLoc)) { 1209 // Let the caller know a <eod> was found by changing the Token kind. 1210 Tok.setKind(tok::eod); 1211 return false; // Found <eod> but no ">"? Diagnostic already emitted. 1212 } 1213 Filename = FilenameBuffer; 1214 break; 1215 default: 1216 PP.Diag(Tok.getLocation(), diag::err_pp_expects_filename); 1217 return false; 1218 } 1219 1220 SourceLocation FilenameLoc = Tok.getLocation(); 1221 1222 // Get ')'. 1223 PP.LexNonComment(Tok); 1224 1225 // Ensure we have a trailing ). 1226 if (Tok.isNot(tok::r_paren)) { 1227 PP.Diag(PP.getLocForEndOfToken(FilenameLoc), diag::err_pp_expected_after) 1228 << II << tok::r_paren; 1229 PP.Diag(LParenLoc, diag::note_matching) << tok::l_paren; 1230 return false; 1231 } 1232 1233 bool isAngled = PP.GetIncludeFilenameSpelling(Tok.getLocation(), Filename); 1234 // If GetIncludeFilenameSpelling set the start ptr to null, there was an 1235 // error. 1236 if (Filename.empty()) 1237 return false; 1238 1239 // Search include directories. 1240 const DirectoryLookup *CurDir; 1241 const FileEntry *File = 1242 PP.LookupFile(FilenameLoc, Filename, isAngled, LookupFrom, LookupFromFile, 1243 CurDir, nullptr, nullptr, nullptr, nullptr); 1244 1245 // Get the result value. A result of true means the file exists. 1246 return File != nullptr; 1247 } 1248 1249 /// EvaluateHasInclude - Process a '__has_include("path")' expression. 1250 /// Returns true if successful. 1251 static bool EvaluateHasInclude(Token &Tok, IdentifierInfo *II, 1252 Preprocessor &PP) { 1253 return EvaluateHasIncludeCommon(Tok, II, PP, nullptr, nullptr); 1254 } 1255 1256 /// EvaluateHasIncludeNext - Process '__has_include_next("path")' expression. 1257 /// Returns true if successful. 1258 static bool EvaluateHasIncludeNext(Token &Tok, 1259 IdentifierInfo *II, Preprocessor &PP) { 1260 // __has_include_next is like __has_include, except that we start 1261 // searching after the current found directory. If we can't do this, 1262 // issue a diagnostic. 1263 // FIXME: Factor out duplication with 1264 // Preprocessor::HandleIncludeNextDirective. 1265 const DirectoryLookup *Lookup = PP.GetCurDirLookup(); 1266 const FileEntry *LookupFromFile = nullptr; 1267 if (PP.isInPrimaryFile() && PP.getLangOpts().IsHeaderFile) { 1268 // If the main file is a header, then it's either for PCH/AST generation, 1269 // or libclang opened it. Either way, handle it as a normal include below 1270 // and do not complain about __has_include_next. 1271 } else if (PP.isInPrimaryFile()) { 1272 Lookup = nullptr; 1273 PP.Diag(Tok, diag::pp_include_next_in_primary); 1274 } else if (PP.getCurrentLexerSubmodule()) { 1275 // Start looking up in the directory *after* the one in which the current 1276 // file would be found, if any. 1277 assert(PP.getCurrentLexer() && "#include_next directive in macro?"); 1278 LookupFromFile = PP.getCurrentLexer()->getFileEntry(); 1279 Lookup = nullptr; 1280 } else if (!Lookup) { 1281 PP.Diag(Tok, diag::pp_include_next_absolute_path); 1282 } else { 1283 // Start looking up in the next directory. 1284 ++Lookup; 1285 } 1286 1287 return EvaluateHasIncludeCommon(Tok, II, PP, Lookup, LookupFromFile); 1288 } 1289 1290 /// Process single-argument builtin feature-like macros that return 1291 /// integer values. 1292 static void EvaluateFeatureLikeBuiltinMacro(llvm::raw_svector_ostream& OS, 1293 Token &Tok, IdentifierInfo *II, 1294 Preprocessor &PP, 1295 llvm::function_ref< 1296 int(Token &Tok, 1297 bool &HasLexedNextTok)> Op) { 1298 // Parse the initial '('. 1299 PP.LexUnexpandedToken(Tok); 1300 if (Tok.isNot(tok::l_paren)) { 1301 PP.Diag(Tok.getLocation(), diag::err_pp_expected_after) << II 1302 << tok::l_paren; 1303 1304 // Provide a dummy '0' value on output stream to elide further errors. 1305 if (!Tok.isOneOf(tok::eof, tok::eod)) { 1306 OS << 0; 1307 Tok.setKind(tok::numeric_constant); 1308 } 1309 return; 1310 } 1311 1312 unsigned ParenDepth = 1; 1313 SourceLocation LParenLoc = Tok.getLocation(); 1314 llvm::Optional<int> Result; 1315 1316 Token ResultTok; 1317 bool SuppressDiagnostic = false; 1318 while (true) { 1319 // Parse next token. 1320 PP.LexUnexpandedToken(Tok); 1321 1322 already_lexed: 1323 switch (Tok.getKind()) { 1324 case tok::eof: 1325 case tok::eod: 1326 // Don't provide even a dummy value if the eod or eof marker is 1327 // reached. Simply provide a diagnostic. 1328 PP.Diag(Tok.getLocation(), diag::err_unterm_macro_invoc); 1329 return; 1330 1331 case tok::comma: 1332 if (!SuppressDiagnostic) { 1333 PP.Diag(Tok.getLocation(), diag::err_too_many_args_in_macro_invoc); 1334 SuppressDiagnostic = true; 1335 } 1336 continue; 1337 1338 case tok::l_paren: 1339 ++ParenDepth; 1340 if (Result.hasValue()) 1341 break; 1342 if (!SuppressDiagnostic) { 1343 PP.Diag(Tok.getLocation(), diag::err_pp_nested_paren) << II; 1344 SuppressDiagnostic = true; 1345 } 1346 continue; 1347 1348 case tok::r_paren: 1349 if (--ParenDepth > 0) 1350 continue; 1351 1352 // The last ')' has been reached; return the value if one found or 1353 // a diagnostic and a dummy value. 1354 if (Result.hasValue()) 1355 OS << Result.getValue(); 1356 else { 1357 OS << 0; 1358 if (!SuppressDiagnostic) 1359 PP.Diag(Tok.getLocation(), diag::err_too_few_args_in_macro_invoc); 1360 } 1361 Tok.setKind(tok::numeric_constant); 1362 return; 1363 1364 default: { 1365 // Parse the macro argument, if one not found so far. 1366 if (Result.hasValue()) 1367 break; 1368 1369 bool HasLexedNextToken = false; 1370 Result = Op(Tok, HasLexedNextToken); 1371 ResultTok = Tok; 1372 if (HasLexedNextToken) 1373 goto already_lexed; 1374 continue; 1375 } 1376 } 1377 1378 // Diagnose missing ')'. 1379 if (!SuppressDiagnostic) { 1380 if (auto Diag = PP.Diag(Tok.getLocation(), diag::err_pp_expected_after)) { 1381 if (IdentifierInfo *LastII = ResultTok.getIdentifierInfo()) 1382 Diag << LastII; 1383 else 1384 Diag << ResultTok.getKind(); 1385 Diag << tok::r_paren << ResultTok.getLocation(); 1386 } 1387 PP.Diag(LParenLoc, diag::note_matching) << tok::l_paren; 1388 SuppressDiagnostic = true; 1389 } 1390 } 1391 } 1392 1393 /// Helper function to return the IdentifierInfo structure of a Token 1394 /// or generate a diagnostic if none available. 1395 static IdentifierInfo *ExpectFeatureIdentifierInfo(Token &Tok, 1396 Preprocessor &PP, 1397 signed DiagID) { 1398 IdentifierInfo *II; 1399 if (!Tok.isAnnotation() && (II = Tok.getIdentifierInfo())) 1400 return II; 1401 1402 PP.Diag(Tok.getLocation(), DiagID); 1403 return nullptr; 1404 } 1405 1406 /// Implements the __is_target_arch builtin macro. 1407 static bool isTargetArch(const TargetInfo &TI, const IdentifierInfo *II) { 1408 std::string ArchName = II->getName().lower() + "--"; 1409 llvm::Triple Arch(ArchName); 1410 const llvm::Triple &TT = TI.getTriple(); 1411 if (TT.isThumb()) { 1412 // arm matches thumb or thumbv7. armv7 matches thumbv7. 1413 if ((Arch.getSubArch() == llvm::Triple::NoSubArch || 1414 Arch.getSubArch() == TT.getSubArch()) && 1415 ((TT.getArch() == llvm::Triple::thumb && 1416 Arch.getArch() == llvm::Triple::arm) || 1417 (TT.getArch() == llvm::Triple::thumbeb && 1418 Arch.getArch() == llvm::Triple::armeb))) 1419 return true; 1420 } 1421 // Check the parsed arch when it has no sub arch to allow Clang to 1422 // match thumb to thumbv7 but to prohibit matching thumbv6 to thumbv7. 1423 return (Arch.getSubArch() == llvm::Triple::NoSubArch || 1424 Arch.getSubArch() == TT.getSubArch()) && 1425 Arch.getArch() == TT.getArch(); 1426 } 1427 1428 /// Implements the __is_target_vendor builtin macro. 1429 static bool isTargetVendor(const TargetInfo &TI, const IdentifierInfo *II) { 1430 StringRef VendorName = TI.getTriple().getVendorName(); 1431 if (VendorName.empty()) 1432 VendorName = "unknown"; 1433 return VendorName.equals_lower(II->getName()); 1434 } 1435 1436 /// Implements the __is_target_os builtin macro. 1437 static bool isTargetOS(const TargetInfo &TI, const IdentifierInfo *II) { 1438 std::string OSName = 1439 (llvm::Twine("unknown-unknown-") + II->getName().lower()).str(); 1440 llvm::Triple OS(OSName); 1441 if (OS.getOS() == llvm::Triple::Darwin) { 1442 // Darwin matches macos, ios, etc. 1443 return TI.getTriple().isOSDarwin(); 1444 } 1445 return TI.getTriple().getOS() == OS.getOS(); 1446 } 1447 1448 /// Implements the __is_target_environment builtin macro. 1449 static bool isTargetEnvironment(const TargetInfo &TI, 1450 const IdentifierInfo *II) { 1451 std::string EnvName = (llvm::Twine("---") + II->getName().lower()).str(); 1452 llvm::Triple Env(EnvName); 1453 return TI.getTriple().getEnvironment() == Env.getEnvironment(); 1454 } 1455 1456 /// ExpandBuiltinMacro - If an identifier token is read that is to be expanded 1457 /// as a builtin macro, handle it and return the next token as 'Tok'. 1458 void Preprocessor::ExpandBuiltinMacro(Token &Tok) { 1459 // Figure out which token this is. 1460 IdentifierInfo *II = Tok.getIdentifierInfo(); 1461 assert(II && "Can't be a macro without id info!"); 1462 1463 // If this is an _Pragma or Microsoft __pragma directive, expand it, 1464 // invoke the pragma handler, then lex the token after it. 1465 if (II == Ident_Pragma) 1466 return Handle_Pragma(Tok); 1467 else if (II == Ident__pragma) // in non-MS mode this is null 1468 return HandleMicrosoft__pragma(Tok); 1469 1470 ++NumBuiltinMacroExpanded; 1471 1472 SmallString<128> TmpBuffer; 1473 llvm::raw_svector_ostream OS(TmpBuffer); 1474 1475 // Set up the return result. 1476 Tok.setIdentifierInfo(nullptr); 1477 Tok.clearFlag(Token::NeedsCleaning); 1478 1479 if (II == Ident__LINE__) { 1480 // C99 6.10.8: "__LINE__: The presumed line number (within the current 1481 // source file) of the current source line (an integer constant)". This can 1482 // be affected by #line. 1483 SourceLocation Loc = Tok.getLocation(); 1484 1485 // Advance to the location of the first _, this might not be the first byte 1486 // of the token if it starts with an escaped newline. 1487 Loc = AdvanceToTokenCharacter(Loc, 0); 1488 1489 // One wrinkle here is that GCC expands __LINE__ to location of the *end* of 1490 // a macro expansion. This doesn't matter for object-like macros, but 1491 // can matter for a function-like macro that expands to contain __LINE__. 1492 // Skip down through expansion points until we find a file loc for the 1493 // end of the expansion history. 1494 Loc = SourceMgr.getExpansionRange(Loc).getEnd(); 1495 PresumedLoc PLoc = SourceMgr.getPresumedLoc(Loc); 1496 1497 // __LINE__ expands to a simple numeric value. 1498 OS << (PLoc.isValid()? PLoc.getLine() : 1); 1499 Tok.setKind(tok::numeric_constant); 1500 } else if (II == Ident__FILE__ || II == Ident__BASE_FILE__) { 1501 // C99 6.10.8: "__FILE__: The presumed name of the current source file (a 1502 // character string literal)". This can be affected by #line. 1503 PresumedLoc PLoc = SourceMgr.getPresumedLoc(Tok.getLocation()); 1504 1505 // __BASE_FILE__ is a GNU extension that returns the top of the presumed 1506 // #include stack instead of the current file. 1507 if (II == Ident__BASE_FILE__ && PLoc.isValid()) { 1508 SourceLocation NextLoc = PLoc.getIncludeLoc(); 1509 while (NextLoc.isValid()) { 1510 PLoc = SourceMgr.getPresumedLoc(NextLoc); 1511 if (PLoc.isInvalid()) 1512 break; 1513 1514 NextLoc = PLoc.getIncludeLoc(); 1515 } 1516 } 1517 1518 // Escape this filename. Turn '\' -> '\\' '"' -> '\"' 1519 SmallString<128> FN; 1520 if (PLoc.isValid()) { 1521 FN += PLoc.getFilename(); 1522 Lexer::Stringify(FN); 1523 OS << '"' << FN << '"'; 1524 } 1525 Tok.setKind(tok::string_literal); 1526 } else if (II == Ident__DATE__) { 1527 Diag(Tok.getLocation(), diag::warn_pp_date_time); 1528 if (!DATELoc.isValid()) 1529 ComputeDATE_TIME(DATELoc, TIMELoc, *this); 1530 Tok.setKind(tok::string_literal); 1531 Tok.setLength(strlen("\"Mmm dd yyyy\"")); 1532 Tok.setLocation(SourceMgr.createExpansionLoc(DATELoc, Tok.getLocation(), 1533 Tok.getLocation(), 1534 Tok.getLength())); 1535 return; 1536 } else if (II == Ident__TIME__) { 1537 Diag(Tok.getLocation(), diag::warn_pp_date_time); 1538 if (!TIMELoc.isValid()) 1539 ComputeDATE_TIME(DATELoc, TIMELoc, *this); 1540 Tok.setKind(tok::string_literal); 1541 Tok.setLength(strlen("\"hh:mm:ss\"")); 1542 Tok.setLocation(SourceMgr.createExpansionLoc(TIMELoc, Tok.getLocation(), 1543 Tok.getLocation(), 1544 Tok.getLength())); 1545 return; 1546 } else if (II == Ident__INCLUDE_LEVEL__) { 1547 // Compute the presumed include depth of this token. This can be affected 1548 // by GNU line markers. 1549 unsigned Depth = 0; 1550 1551 PresumedLoc PLoc = SourceMgr.getPresumedLoc(Tok.getLocation()); 1552 if (PLoc.isValid()) { 1553 PLoc = SourceMgr.getPresumedLoc(PLoc.getIncludeLoc()); 1554 for (; PLoc.isValid(); ++Depth) 1555 PLoc = SourceMgr.getPresumedLoc(PLoc.getIncludeLoc()); 1556 } 1557 1558 // __INCLUDE_LEVEL__ expands to a simple numeric value. 1559 OS << Depth; 1560 Tok.setKind(tok::numeric_constant); 1561 } else if (II == Ident__TIMESTAMP__) { 1562 Diag(Tok.getLocation(), diag::warn_pp_date_time); 1563 // MSVC, ICC, GCC, VisualAge C++ extension. The generated string should be 1564 // of the form "Ddd Mmm dd hh::mm::ss yyyy", which is returned by asctime. 1565 1566 // Get the file that we are lexing out of. If we're currently lexing from 1567 // a macro, dig into the include stack. 1568 const FileEntry *CurFile = nullptr; 1569 PreprocessorLexer *TheLexer = getCurrentFileLexer(); 1570 1571 if (TheLexer) 1572 CurFile = SourceMgr.getFileEntryForID(TheLexer->getFileID()); 1573 1574 const char *Result; 1575 if (CurFile) { 1576 time_t TT = CurFile->getModificationTime(); 1577 struct tm *TM = localtime(&TT); 1578 Result = asctime(TM); 1579 } else { 1580 Result = "??? ??? ?? ??:??:?? ????\n"; 1581 } 1582 // Surround the string with " and strip the trailing newline. 1583 OS << '"' << StringRef(Result).drop_back() << '"'; 1584 Tok.setKind(tok::string_literal); 1585 } else if (II == Ident__COUNTER__) { 1586 // __COUNTER__ expands to a simple numeric value. 1587 OS << CounterValue++; 1588 Tok.setKind(tok::numeric_constant); 1589 } else if (II == Ident__has_feature) { 1590 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1591 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1592 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1593 diag::err_feature_check_malformed); 1594 return II && HasFeature(*this, II->getName()); 1595 }); 1596 } else if (II == Ident__has_extension) { 1597 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1598 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1599 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1600 diag::err_feature_check_malformed); 1601 return II && HasExtension(*this, II->getName()); 1602 }); 1603 } else if (II == Ident__has_builtin) { 1604 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1605 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1606 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1607 diag::err_feature_check_malformed); 1608 const LangOptions &LangOpts = getLangOpts(); 1609 if (!II) 1610 return false; 1611 else if (II->getBuiltinID() != 0) { 1612 switch (II->getBuiltinID()) { 1613 case Builtin::BI__builtin_operator_new: 1614 case Builtin::BI__builtin_operator_delete: 1615 // denotes date of behavior change to support calling arbitrary 1616 // usual allocation and deallocation functions. Required by libc++ 1617 return 201802; 1618 default: 1619 return true; 1620 } 1621 return true; 1622 } else { 1623 return llvm::StringSwitch<bool>(II->getName()) 1624 .Case("__make_integer_seq", LangOpts.CPlusPlus) 1625 .Case("__type_pack_element", LangOpts.CPlusPlus) 1626 .Case("__builtin_available", true) 1627 .Case("__is_target_arch", true) 1628 .Case("__is_target_vendor", true) 1629 .Case("__is_target_os", true) 1630 .Case("__is_target_environment", true) 1631 .Default(false); 1632 } 1633 }); 1634 } else if (II == Ident__is_identifier) { 1635 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1636 [](Token &Tok, bool &HasLexedNextToken) -> int { 1637 return Tok.is(tok::identifier); 1638 }); 1639 } else if (II == Ident__has_attribute) { 1640 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1641 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1642 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1643 diag::err_feature_check_malformed); 1644 return II ? hasAttribute(AttrSyntax::GNU, nullptr, II, 1645 getTargetInfo(), getLangOpts()) : 0; 1646 }); 1647 } else if (II == Ident__has_declspec) { 1648 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1649 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1650 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1651 diag::err_feature_check_malformed); 1652 return II ? hasAttribute(AttrSyntax::Declspec, nullptr, II, 1653 getTargetInfo(), getLangOpts()) : 0; 1654 }); 1655 } else if (II == Ident__has_cpp_attribute || 1656 II == Ident__has_c_attribute) { 1657 bool IsCXX = II == Ident__has_cpp_attribute; 1658 EvaluateFeatureLikeBuiltinMacro( 1659 OS, Tok, II, *this, [&](Token &Tok, bool &HasLexedNextToken) -> int { 1660 IdentifierInfo *ScopeII = nullptr; 1661 IdentifierInfo *II = ExpectFeatureIdentifierInfo( 1662 Tok, *this, diag::err_feature_check_malformed); 1663 if (!II) 1664 return false; 1665 1666 // It is possible to receive a scope token. Read the "::", if it is 1667 // available, and the subsequent identifier. 1668 LexUnexpandedToken(Tok); 1669 if (Tok.isNot(tok::coloncolon)) 1670 HasLexedNextToken = true; 1671 else { 1672 ScopeII = II; 1673 LexUnexpandedToken(Tok); 1674 II = ExpectFeatureIdentifierInfo(Tok, *this, 1675 diag::err_feature_check_malformed); 1676 } 1677 1678 AttrSyntax Syntax = IsCXX ? AttrSyntax::CXX : AttrSyntax::C; 1679 return II ? hasAttribute(Syntax, ScopeII, II, getTargetInfo(), 1680 getLangOpts()) 1681 : 0; 1682 }); 1683 } else if (II == Ident__has_include || 1684 II == Ident__has_include_next) { 1685 // The argument to these two builtins should be a parenthesized 1686 // file name string literal using angle brackets (<>) or 1687 // double-quotes (""). 1688 bool Value; 1689 if (II == Ident__has_include) 1690 Value = EvaluateHasInclude(Tok, II, *this); 1691 else 1692 Value = EvaluateHasIncludeNext(Tok, II, *this); 1693 1694 if (Tok.isNot(tok::r_paren)) 1695 return; 1696 OS << (int)Value; 1697 Tok.setKind(tok::numeric_constant); 1698 } else if (II == Ident__has_warning) { 1699 // The argument should be a parenthesized string literal. 1700 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1701 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1702 std::string WarningName; 1703 SourceLocation StrStartLoc = Tok.getLocation(); 1704 1705 HasLexedNextToken = Tok.is(tok::string_literal); 1706 if (!FinishLexStringLiteral(Tok, WarningName, "'__has_warning'", 1707 /*MacroExpansion=*/false)) 1708 return false; 1709 1710 // FIXME: Should we accept "-R..." flags here, or should that be 1711 // handled by a separate __has_remark? 1712 if (WarningName.size() < 3 || WarningName[0] != '-' || 1713 WarningName[1] != 'W') { 1714 Diag(StrStartLoc, diag::warn_has_warning_invalid_option); 1715 return false; 1716 } 1717 1718 // Finally, check if the warning flags maps to a diagnostic group. 1719 // We construct a SmallVector here to talk to getDiagnosticIDs(). 1720 // Although we don't use the result, this isn't a hot path, and not 1721 // worth special casing. 1722 SmallVector<diag::kind, 10> Diags; 1723 return !getDiagnostics().getDiagnosticIDs()-> 1724 getDiagnosticsInGroup(diag::Flavor::WarningOrError, 1725 WarningName.substr(2), Diags); 1726 }); 1727 } else if (II == Ident__building_module) { 1728 // The argument to this builtin should be an identifier. The 1729 // builtin evaluates to 1 when that identifier names the module we are 1730 // currently building. 1731 EvaluateFeatureLikeBuiltinMacro(OS, Tok, II, *this, 1732 [this](Token &Tok, bool &HasLexedNextToken) -> int { 1733 IdentifierInfo *II = ExpectFeatureIdentifierInfo(Tok, *this, 1734 diag::err_expected_id_building_module); 1735 return getLangOpts().isCompilingModule() && II && 1736 (II->getName() == getLangOpts().CurrentModule); 1737 }); 1738 } else if (II == Ident__MODULE__) { 1739 // The current module as an identifier. 1740 OS << getLangOpts().CurrentModule; 1741 IdentifierInfo *ModuleII = getIdentifierInfo(getLangOpts().CurrentModule); 1742 Tok.setIdentifierInfo(ModuleII); 1743 Tok.setKind(ModuleII->getTokenID()); 1744 } else if (II == Ident__identifier) { 1745 SourceLocation Loc = Tok.getLocation(); 1746 1747 // We're expecting '__identifier' '(' identifier ')'. Try to recover 1748 // if the parens are missing. 1749 LexNonComment(Tok); 1750 if (Tok.isNot(tok::l_paren)) { 1751 // No '(', use end of last token. 1752 Diag(getLocForEndOfToken(Loc), diag::err_pp_expected_after) 1753 << II << tok::l_paren; 1754 // If the next token isn't valid as our argument, we can't recover. 1755 if (!Tok.isAnnotation() && Tok.getIdentifierInfo()) 1756 Tok.setKind(tok::identifier); 1757 return; 1758 } 1759 1760 SourceLocation LParenLoc = Tok.getLocation(); 1761 LexNonComment(Tok); 1762 1763 if (!Tok.isAnnotation() && Tok.getIdentifierInfo()) 1764 Tok.setKind(tok::identifier); 1765 else { 1766 Diag(Tok.getLocation(), diag::err_pp_identifier_arg_not_identifier) 1767 << Tok.getKind(); 1768 // Don't walk past anything that's not a real token. 1769 if (Tok.isOneOf(tok::eof, tok::eod) || Tok.isAnnotation()) 1770 return; 1771 } 1772 1773 // Discard the ')', preserving 'Tok' as our result. 1774 Token RParen; 1775 LexNonComment(RParen); 1776 if (RParen.isNot(tok::r_paren)) { 1777 Diag(getLocForEndOfToken(Tok.getLocation()), diag::err_pp_expected_after) 1778 << Tok.getKind() << tok::r_paren; 1779 Diag(LParenLoc, diag::note_matching) << tok::l_paren; 1780 } 1781 return; 1782 } else if (II == Ident__is_target_arch) { 1783 EvaluateFeatureLikeBuiltinMacro( 1784 OS, Tok, II, *this, [this](Token &Tok, bool &HasLexedNextToken) -> int { 1785 IdentifierInfo *II = ExpectFeatureIdentifierInfo( 1786 Tok, *this, diag::err_feature_check_malformed); 1787 return II && isTargetArch(getTargetInfo(), II); 1788 }); 1789 } else if (II == Ident__is_target_vendor) { 1790 EvaluateFeatureLikeBuiltinMacro( 1791 OS, Tok, II, *this, [this](Token &Tok, bool &HasLexedNextToken) -> int { 1792 IdentifierInfo *II = ExpectFeatureIdentifierInfo( 1793 Tok, *this, diag::err_feature_check_malformed); 1794 return II && isTargetVendor(getTargetInfo(), II); 1795 }); 1796 } else if (II == Ident__is_target_os) { 1797 EvaluateFeatureLikeBuiltinMacro( 1798 OS, Tok, II, *this, [this](Token &Tok, bool &HasLexedNextToken) -> int { 1799 IdentifierInfo *II = ExpectFeatureIdentifierInfo( 1800 Tok, *this, diag::err_feature_check_malformed); 1801 return II && isTargetOS(getTargetInfo(), II); 1802 }); 1803 } else if (II == Ident__is_target_environment) { 1804 EvaluateFeatureLikeBuiltinMacro( 1805 OS, Tok, II, *this, [this](Token &Tok, bool &HasLexedNextToken) -> int { 1806 IdentifierInfo *II = ExpectFeatureIdentifierInfo( 1807 Tok, *this, diag::err_feature_check_malformed); 1808 return II && isTargetEnvironment(getTargetInfo(), II); 1809 }); 1810 } else { 1811 llvm_unreachable("Unknown identifier!"); 1812 } 1813 CreateString(OS.str(), Tok, Tok.getLocation(), Tok.getLocation()); 1814 } 1815 1816 void Preprocessor::markMacroAsUsed(MacroInfo *MI) { 1817 // If the 'used' status changed, and the macro requires 'unused' warning, 1818 // remove its SourceLocation from the warn-for-unused-macro locations. 1819 if (MI->isWarnIfUnused() && !MI->isUsed()) 1820 WarnUnusedMacroLocs.erase(MI->getDefinitionLoc()); 1821 MI->setIsUsed(true); 1822 } 1823