55#include "llvm/ADT/APInt.h"
56#include "llvm/ADT/ArrayRef.h"
57#include "llvm/ADT/DenseMap.h"
58#include "llvm/ADT/STLExtras.h"
59#include "llvm/ADT/ScopeExit.h"
60#include "llvm/ADT/SmallVector.h"
61#include "llvm/ADT/StringRef.h"
62#include "llvm/Support/Capacity.h"
63#include "llvm/Support/ErrorHandling.h"
64#include "llvm/Support/FormatVariadic.h"
65#include "llvm/Support/MemoryBuffer.h"
66#include "llvm/Support/MemoryBufferRef.h"
67#include "llvm/Support/SaveAndRestore.h"
68#include "llvm/Support/raw_ostream.h"
92 : PPOpts(PPOpts), Diags(&diags), LangOpts(opts),
93 FileMgr(Headers.getFileMgr()), SourceMgr(
SM),
94 ScratchBuf(new
ScratchBuffer(SourceMgr)), HeaderInfo(Headers),
95 TheModuleLoader(TheModuleLoader), ExternalSource(
nullptr),
99 Identifiers(IILookup), PragmaHandlers(new
PragmaNamespace(StringRef())),
101 CurSubmoduleState(&NullSubmoduleState) {
102 OwnsHeaderSearch = OwnsHeaders;
105 KeepComments =
false;
106 KeepMacroComments =
false;
107 SuppressIncludeNotFoundError =
false;
110 DisableMacroExpansion =
false;
111 MacroExpansionInDirectivesOverride =
false;
114 InMacroArgPreExpansion =
false;
115 NumCachedTokenLexers = 0;
116 PragmasEnabled =
true;
117 ParsingIfOrElifDirective =
false;
118 PreprocessedOutput =
false;
121 ReadMacrosFromExternalSource =
false;
123 LastExportKeyword.startToken();
125 BuiltinInfo = std::make_unique<Builtin::Context>();
135 RegisterBuiltinPragmas();
138 RegisterBuiltinMacros();
140 if(LangOpts.Borland) {
151 Ident__exception_info = Ident__exception_code =
nullptr;
152 Ident__abnormal_termination = Ident___exception_info =
nullptr;
153 Ident___exception_code = Ident___abnormal_termination =
nullptr;
154 Ident_GetExceptionInfo = Ident_GetExceptionCode =
nullptr;
155 Ident_AbnormalTermination =
nullptr;
160 IncrementalProcessing = LangOpts.IncrementalExtensions;
164 SkippingUntilPragmaHdrStop =
true;
168 !this->PPOpts.ImplicitPCHInclude.empty())
169 SkippingUntilPCHThroughHeader =
true;
172 PreambleConditionalStack.startRecording();
174 MaxTokens = LangOpts.MaxTokens;
180 IncludeMacroStack.clear();
185 std::fill(TokenLexerCache, TokenLexerCache + NumCachedTokenLexers,
nullptr);
186 CurTokenLexer.reset();
189 for (
MacroArgs *ArgList = MacroArgCache; ArgList;)
190 ArgList = ArgList->deallocate();
193 if (OwnsHeaderSearch)
199 assert((!this->Target || this->Target == &Target) &&
200 "Invalid override of target information");
201 this->Target = &Target;
203 assert((!this->AuxTarget || this->AuxTarget == AuxTarget) &&
204 "Invalid override of aux target information.");
205 this->AuxTarget = AuxTarget;
208 BuiltinInfo->InitializeTarget(Target, AuxTarget);
209 HeaderInfo.setTarget(Target);
212 Identifiers.AddKeywords(LangOpts);
226 NumEnteredSourceFiles = 0;
229 PragmaHandlersBackup = std::move(PragmaHandlers);
230 PragmaHandlers = std::make_unique<PragmaNamespace>(StringRef());
231 RegisterBuiltinPragmas();
234 PredefinesFileID =
FileID();
238 NumEnteredSourceFiles = 1;
240 PragmaHandlers = std::move(PragmaHandlersBackup);
244 std::string TokenStr;
245 llvm::raw_string_ostream OS(TokenStr);
252 if (!
Tok.isAnnotation()) {
261 llvm::errs() << llvm::formatv(
"{0,-48} ", OS.str());
263 if (!DumpFlags)
return;
265 auto Loc =
Tok.getLocation();
266 llvm::errs() <<
"Loc=<";
279 if (Loc.isFileID()) {
283 int LineWidth = llvm::utostr(PLoc.
getLine()).size();
288 const int ReservedSpace = 6;
290 int LeftSpace = ReservedSpace - LineWidth -
ColumnWidth;
291 int Padding = std::max<int>(0, LeftSpace);
293 llvm::errs().indent(Padding);
297 if (
Tok.isAtStartOfLine())
298 llvm::errs() <<
" [StartOfLine]";
299 if (
Tok.hasLeadingSpace())
300 llvm::errs() <<
" [LeadingSpace]";
301 if (
Tok.isExpandDisabled())
302 llvm::errs() <<
" [ExpandDisabled]";
303 if (
Tok.needsCleaning()) {
304 const char *Start = SourceMgr.getCharacterData(
Tok.getLocation());
305 llvm::errs() <<
" [UnClean='" << StringRef(Start,
Tok.getLength()) <<
"']";
310 Loc.
print(llvm::errs(), SourceMgr);
314 llvm::errs() <<
"MACRO: ";
315 for (
unsigned i = 0, e = MI.
getNumTokens(); i != e; ++i) {
319 llvm::errs() <<
"\n";
323 llvm::errs() <<
"\n*** Preprocessor Stats:\n";
324 llvm::errs() << NumDirectives <<
" directives found:\n";
325 llvm::errs() <<
" " << NumDefined <<
" #define.\n";
326 llvm::errs() <<
" " << NumUndefined <<
" #undef.\n";
327 llvm::errs() <<
" #include/#include_next/#import:\n";
328 llvm::errs() <<
" " << NumEnteredSourceFiles <<
" source files entered.\n";
329 llvm::errs() <<
" " << MaxIncludeStackDepth <<
" max include stack depth\n";
330 llvm::errs() <<
" " << NumIf <<
" #if/#ifndef/#ifdef.\n";
331 llvm::errs() <<
" " << NumElse <<
" #else/#elif/#elifdef/#elifndef.\n";
332 llvm::errs() <<
" " << NumEndif <<
" #endif.\n";
333 llvm::errs() <<
" " << NumPragma <<
" #pragma.\n";
334 llvm::errs() << NumSkipped <<
" #if/#ifndef#ifdef regions skipped\n";
336 llvm::errs() << NumMacroExpanded <<
"/" << NumFnMacroExpanded <<
"/"
337 << NumBuiltinMacroExpanded <<
" obj/fn/builtin macros expanded, "
338 << NumFastMacroExpanded <<
" on the fast path.\n";
339 llvm::errs() << (NumFastTokenPaste+NumTokenPaste)
340 <<
" token paste (##) operations performed, "
341 << NumFastTokenPaste <<
" on the fast path.\n";
343 llvm::errs() <<
"\nPreprocessor Memory: " <<
getTotalMemory() <<
"B total";
345 llvm::errs() <<
"\n BumpPtr: " << BP.getTotalMemory();
346 llvm::errs() <<
"\n Macro Expanded Tokens: "
347 << llvm::capacity_in_bytes(MacroExpandedTokens);
348 llvm::errs() <<
"\n Predefines Buffer: " << Predefines.capacity();
350 llvm::errs() <<
"\n Macros: "
351 << llvm::capacity_in_bytes(CurSubmoduleState->Macros);
352 llvm::errs() <<
"\n #pragma push_macro Info: "
353 << llvm::capacity_in_bytes(PragmaPushMacroInfo);
354 llvm::errs() <<
"\n Poison Reasons: "
355 << llvm::capacity_in_bytes(PoisonReasons);
356 llvm::errs() <<
"\n Comment Handlers: "
357 << llvm::capacity_in_bytes(CommentHandlers) <<
"\n";
362 if (IncludeExternalMacros && ExternalSource &&
363 !ReadMacrosFromExternalSource) {
364 ReadMacrosFromExternalSource =
true;
365 ExternalSource->ReadDefinedMacros();
370 CurSubmoduleState->Macros.try_emplace(
Macro.II);
372 return CurSubmoduleState->Macros.begin();
376 return BP.getTotalMemory()
377 + llvm::capacity_in_bytes(MacroExpandedTokens)
378 + Predefines.capacity()
381 + llvm::capacity_in_bytes(CurSubmoduleState->Macros)
382 + llvm::capacity_in_bytes(PragmaPushMacroInfo)
383 + llvm::capacity_in_bytes(PoisonReasons)
384 + llvm::capacity_in_bytes(CommentHandlers);
389 if (IncludeExternalMacros && ExternalSource &&
390 !ReadMacrosFromExternalSource) {
391 ReadMacrosFromExternalSource =
true;
392 ExternalSource->ReadDefinedMacros();
395 return CurSubmoduleState->Macros.end();
402 std::equal(Tokens.begin(), Tokens.end(), MI->
tokens_begin());
409 StringRef BestSpelling;
413 Def = I->second.findDirectiveAtLoc(Loc, SourceMgr);
423 (Location.isValid() &&
424 SourceMgr.isBeforeInTranslationUnit(BestLocation, Location))) {
425 BestLocation = Location;
426 BestSpelling = I->first->getName();
434 CurLexerCallback = CurLexer->isDependencyDirectivesLexer()
435 ? CLK_DependencyDirectivesLexer
437 else if (CurTokenLexer)
438 CurLexerCallback = CLK_TokenLexer;
440 CurLexerCallback = CLK_CachingLexer;
444 unsigned CompleteLine,
445 unsigned CompleteColumn) {
446 assert(CompleteLine && CompleteColumn &&
"Starts from 1:1");
447 assert(!CodeCompletionFile &&
"Already set");
450 std::optional<llvm::MemoryBufferRef> Buffer =
451 SourceMgr.getMemoryBufferForFileOrNone(
File);
456 const char *Position = Buffer->getBufferStart();
458 for (; *Position; ++Position) {
459 if (*Position !=
'\r' && *Position !=
'\n')
463 if ((Position[1] ==
'\r' || Position[1] ==
'\n') &&
464 Position[0] != Position[1])
471 Position += CompleteColumn - 1;
475 if (SkipMainFilePreamble.first &&
476 SourceMgr.getFileEntryForID(SourceMgr.getMainFileID()) ==
File) {
477 if (Position - Buffer->getBufferStart() < SkipMainFilePreamble.first)
478 Position = Buffer->getBufferStart() + SkipMainFilePreamble.first;
481 if (Position > Buffer->getBufferEnd())
482 Position = Buffer->getBufferEnd();
484 CodeCompletionFile =
File;
485 CodeCompletionOffset = Position - Buffer->getBufferStart();
487 auto NewBuffer = llvm::WritableMemoryBuffer::getNewUninitMemBuffer(
488 Buffer->getBufferSize() + 1, Buffer->getBufferIdentifier());
489 char *NewBuf = NewBuffer->getBufferStart();
490 char *NewPos = std::copy(Buffer->getBufferStart(), Position, NewBuf);
492 std::copy(Position, Buffer->getBufferEnd(), NewPos+1);
493 SourceMgr.overrideFileContents(
File, std::move(NewBuffer));
502 CodeComplete->CodeCompleteIncludedFile(Dir, IsAngled);
508 CodeComplete->CodeCompleteNaturalLanguage();
518 if (
Tok.isNot(tok::raw_identifier) && !
Tok.hasUCN()) {
521 return II->getName();
525 if (
Tok.needsCleaning())
526 Buffer.resize(
Tok.getLength());
528 const char *Ptr = Buffer.data();
530 return StringRef(Ptr, Len);
539 Tok.setLength(Str.size());
542 SourceLocation Loc = ScratchBuf->getToken(Str.data(), Str.size(), DestPtr);
544 if (ExpansionLocStart.
isValid())
545 Loc = SourceMgr.createExpansionLoc(Loc, ExpansionLocStart,
546 ExpansionLocEnd, Str.size());
547 Tok.setLocation(Loc);
550 if (
Tok.is(tok::raw_identifier))
551 Tok.setRawIdentifierData(DestPtr);
552 else if (
Tok.isLiteral())
553 Tok.setLiteralData(DestPtr);
561 StringRef Buffer =
SM.getBufferData(LocInfo.first, &
Invalid);
568 ScratchBuf->getToken(Buffer.data() + LocInfo.second, Length, DestPtr);
580 if (!
getLangOpts().isCompilingModuleImplementation())
596 assert(NumEnteredSourceFiles == 0 &&
"Cannot reenter the main file!");
597 FileID MainFileID = SourceMgr.getMainFileID();
601 if (!SourceMgr.isLoadedFileID(MainFileID)) {
607 if (SkipMainFilePreamble.first > 0)
608 CurLexer->SetByteOffset(SkipMainFilePreamble.first,
609 SkipMainFilePreamble.second);
626 std::optional<StringRef> Input =
629 MainFileIsPreprocessedModuleFile =
631 auto Tracer = std::make_unique<NoTrivialPPDirectiveTracer>(*
this);
632 DirTracer = Tracer.get();
634 std::optional<Token> FirstPPTok = CurLexer->peekNextPPToken();
636 FirstPPTokenLoc = FirstPPTok->getLocation();
641 std::unique_ptr<llvm::MemoryBuffer> SB =
642 llvm::MemoryBuffer::getMemBufferCopy(Predefines,
"<built-in>");
643 assert(SB &&
"Cannot create predefined source buffer");
644 FileID FID = SourceMgr.createFileID(std::move(SB));
645 assert(FID.
isValid() &&
"Could not create FileID for predefines?");
646 setPredefinesFileID(FID);
651 if (!PPOpts.PCHThroughHeader.empty()) {
656 false,
nullptr,
nullptr,
657 nullptr,
nullptr,
nullptr,
662 << PPOpts.PCHThroughHeader;
665 setPCHThroughHeaderFileID(
675void Preprocessor::setPCHThroughHeaderFileID(
FileID FID) {
676 assert(PCHThroughHeaderFileID.
isInvalid() &&
677 "PCHThroughHeaderFileID already set!");
678 PCHThroughHeaderFileID = FID;
682 assert(PCHThroughHeaderFileID.isValid() &&
683 "Invalid PCH through header FileID");
684 return FE == SourceMgr.getFileEntryForID(PCHThroughHeaderFileID);
689 PCHThroughHeaderFileID.isValid();
694 PCHThroughHeaderFileID.isValid();
711 bool ReachedMainFileEOF =
false;
712 bool UsingPCHThroughHeader = SkippingUntilPCHThroughHeader;
713 bool UsingPragmaHdrStop = SkippingUntilPragmaHdrStop;
718 CurLexerCallback(*
this,
Tok);
719 if (
Tok.is(tok::eof) && !InPredefines) {
720 ReachedMainFileEOF =
true;
723 if (UsingPCHThroughHeader && !SkippingUntilPCHThroughHeader)
725 if (UsingPragmaHdrStop && !SkippingUntilPragmaHdrStop)
728 if (ReachedMainFileEOF) {
729 if (UsingPCHThroughHeader)
731 << PPOpts.PCHThroughHeader << 1;
732 else if (!PPOpts.PCHWithHdrStopCreate)
737void Preprocessor::replayPreambleConditionalStack() {
739 if (PreambleConditionalStack.isReplaying()) {
741 "CurPPLexer is null when calling replayPreambleConditionalStack.");
743 PreambleConditionalStack.doneReplaying();
744 if (PreambleConditionalStack.reachedEOFWhileSkipping())
745 SkipExcludedConditionalBlock(
746 PreambleConditionalStack.SkipInfo->HashTokenLoc,
747 PreambleConditionalStack.SkipInfo->IfTokenLoc,
748 PreambleConditionalStack.SkipInfo->FoundNonSkipPortion,
749 PreambleConditionalStack.SkipInfo->FoundElse,
750 PreambleConditionalStack.SkipInfo->ElseLoc);
757 Callbacks->EndOfMainFile();
768 assert(!Identifier.
getRawIdentifier().empty() &&
"No raw identifier data!");
778 StringRef CleanedStr =
getSpelling(Identifier, IdentifierBuffer);
780 if (Identifier.
hasUCN()) {
803 PoisonReasons[II] = DiagID;
807 assert(Ident__exception_code && Ident__exception_info);
808 assert(Ident___exception_code && Ident___exception_info);
809 Ident__exception_code->setIsPoisoned(Poison);
810 Ident___exception_code->setIsPoisoned(Poison);
811 Ident_GetExceptionCode->setIsPoisoned(Poison);
812 Ident__exception_info->setIsPoisoned(Poison);
813 Ident___exception_info->setIsPoisoned(Poison);
814 Ident_GetExceptionInfo->setIsPoisoned(Poison);
815 Ident__abnormal_termination->setIsPoisoned(Poison);
816 Ident___abnormal_termination->setIsPoisoned(Poison);
817 Ident_AbnormalTermination->setIsPoisoned(Poison);
822 "Can't handle identifiers without identifier info!");
823 llvm::DenseMap<IdentifierInfo*,unsigned>::const_iterator it =
825 if(it == PoisonReasons.end())
826 Diag(Identifier, diag::err_pp_used_poisoned_id);
831void Preprocessor::updateOutOfDateIdentifier(
const IdentifierInfo &II)
const {
834 "getExternalSource() should not return nullptr");
848 "Can't handle identifiers without identifier info!");
858 bool CurrentIsPoisoned =
false;
859 const bool IsSpecialVariadicMacro =
860 &II == Ident__VA_ARGS__ || &II == Ident__VA_OPT__;
861 if (IsSpecialVariadicMacro)
864 updateOutOfDateIdentifier(II);
867 if (IsSpecialVariadicMacro)
879 const auto *MI = MD.getMacroInfo();
880 assert(MI &&
"macro definition with no macro info?");
881 if (!DisableMacroExpansion) {
886 return HandleMacroExpandedIdentifier(Identifier, MD);
893 Diag(Identifier, diag::pp_disabled_macro_expansion);
913 Diag(Identifier, diag::warn_pp_identifier_is_cpp_keyword) << &II;
920 Diag(Identifier, diag::ext_token_used);
924 !CurLexer->isLexingRawMode() && !CurLexer->isPragmaLexer() &&
925 !CurLexer->ParsingPreprocessorDirective &&
940 while (!CurLexerCallback(*
this,
Result))
943 if (
Result.is(tok::unknown) && TheModuleLoader.HadFatalFailure)
946 if (
Result.is(tok::code_completion) &&
Result.getIdentifierInfo()) {
952 Result.setIdentifierInfo(
nullptr);
960 if (
getLangOpts().CPlusPlusModules && LexLevel == 1 &&
962 switch (
Result.getKind()) {
963 case tok::l_paren:
case tok::l_square:
case tok::l_brace:
964 StdCXXImportSeqState.handleOpenBracket();
966 case tok::r_paren:
case tok::r_square:
967 StdCXXImportSeqState.handleCloseBracket();
970 StdCXXImportSeqState.handleCloseBrace();
972#define PRAGMA_ANNOTATION(X) case tok::annot_##X:
974#include "clang/Basic/TokenKinds.def"
975#undef PRAGMA_ANNOTATION
978 case tok::annot_module_include:
979 case tok::annot_repl_input_end:
981 TrackGMFState.handleSemi();
982 StdCXXImportSeqState.handleSemi();
983 ModuleDeclState.handleSemi();
985 case tok::header_name:
986 case tok::annot_header_unit:
987 StdCXXImportSeqState.handleHeaderName();
992 TrackGMFState.handleExport();
993 StdCXXImportSeqState.handleExport();
994 ModuleDeclState.handleExport();
997 ModuleDeclState.handleColon();
1000 if (StdCXXImportSeqState.atTopLevel()) {
1001 TrackGMFState.handleImport(StdCXXImportSeqState.afterTopLevelSeq());
1002 StdCXXImportSeqState.handleImport();
1005 case tok::kw_module:
1006 if (StdCXXImportSeqState.atTopLevel()) {
1009 TrackGMFState.handleModule(StdCXXImportSeqState.afterTopLevelSeq());
1010 ModuleDeclState.handleModule();
1013 case tok::annot_module_name:
1014 ModuleDeclState.handleModuleName(
1016 if (ModuleDeclState.isModuleCandidate())
1020 TrackGMFState.handleMisc();
1021 StdCXXImportSeqState.handleMisc();
1022 ModuleDeclState.handleMisc();
1028 CheckPoints[CurLexer->getFileID()].push_back(CurLexer->BufferPtr);
1029 CheckPointCounter = 0;
1032 if (
Result.isNot(tok::kw_export))
1033 LastExportKeyword.startToken();
1040 if (LexLevel == 0 && !PendingDestroyLexers.empty())
1041 PendingDestroyLexers.clear();
1043 if ((LexLevel == 0 || PreprocessToken) &&
1056 if (
Tok.isOneOf(tok::unknown, tok::eof, tok::eod,
1057 tok::annot_repl_input_end))
1059 if (Tokens !=
nullptr)
1060 Tokens->push_back(
Tok);
1081 if (CurPPLexer->ParsingFilename)
1084 CurPPLexer->LexIncludeFilename(FilenameTok);
1092 if (FilenameTok.
is(tok::less) && AllowMacroExpansion) {
1099 FilenameBuffer.push_back(
'<');
1105 while (FilenameTok.
isNot(tok::greater)) {
1107 if (FilenameTok.
isOneOf(tok::eod, tok::eof)) {
1109 Diag(Start, diag::note_matching) << tok::less;
1116 if (FilenameTok.
is(tok::code_completion)) {
1125 FilenameBuffer.push_back(
' ');
1129 size_t PreAppendSize = FilenameBuffer.size();
1130 FilenameBuffer.resize(PreAppendSize + FilenameTok.
getLength());
1132 const char *BufPtr = &FilenameBuffer[PreAppendSize];
1133 unsigned ActualLen =
getSpelling(FilenameTok, BufPtr);
1136 if (BufPtr != &FilenameBuffer[PreAppendSize])
1137 memcpy(&FilenameBuffer[PreAppendSize], BufPtr, ActualLen);
1140 if (FilenameTok.
getLength() != ActualLen)
1141 FilenameBuffer.resize(PreAppendSize + ActualLen);
1145 FilenameTok.
setKind(tok::header_name);
1150 }
else if (FilenameTok.
is(tok::string_literal) && AllowMacroExpansion) {
1161 StringRef Str =
getSpelling(FilenameTok, FilenameBuffer);
1162 if (Str.size() >= 2 && Str.front() ==
'"' && Str.back() ==
'"')
1163 FilenameTok.
setKind(tok::header_name);
1169std::optional<Token> Preprocessor::peekNextPPToken()
const {
1171 std::optional<Token> Val;
1173 Val = CurLexer->peekNextPPToken();
1175 Val = CurTokenLexer->peekNextPPToken();
1182 return std::nullopt;
1183 for (
const IncludeStackInfo &Entry : llvm::reverse(IncludeMacroStack)) {
1185 Val = Entry.TheLexer->peekNextPPToken();
1187 Val = Entry.TheTokenLexer->peekNextPPToken();
1193 if (Entry.ThePPLexer)
1194 return std::nullopt;
1212 for (
auto &Piece : Path) {
1213 assert(Piece.getIdentifierInfo() && Piece.getLoc().isValid());
1216 Name += Piece.getIdentifierInfo()->getName();
1222 assert(!Path.empty() &&
"expect at least one identifier in a module name");
1224 totalSizeToAlloc<IdentifierLoc>(Path.size()),
alignof(ModuleNameLoc));
1225 return new (Mem) ModuleNameLoc(Path);
1231 bool AllowMacroExpansion,
1233 auto ConsumeToken = [&]() {
1234 if (AllowMacroExpansion)
1238 Suffix.push_back(
Tok);
1242 if (
Tok.isNot(tok::identifier)) {
1243 if (
Tok.is(tok::code_completion)) {
1244 CurLexer->cutOffLexing();
1245 CodeComplete->CodeCompleteModuleImport(UseLoc, Path);
1249 Diag(
Tok, diag::err_pp_module_expected_ident) << Path.empty();
1258 !AllowMacroExpansion) {
1259 Diag(
Tok, diag::err_pp_module_name_is_macro)
1260 << IsPartition <<
Tok.getIdentifierInfo();
1261 Diag(MI->getDefinitionLoc(), diag::note_macro_here)
1262 <<
Tok.getIdentifierInfo();
1266 Path.emplace_back(
Tok.getLocation(),
Tok.getIdentifierInfo());
1269 if (
Tok.isNot(tok::period))
1280 bool AllowMacroExpansion,
1282 bool LeadingSpace =
Tok.hasLeadingSpace();
1283 unsigned NumToksInDirective = DirToks.size();
1286 if (
Tok.isNot(tok::eod))
1295 DirToks.resize(NumToksInDirective);
1297 DirToks.emplace_back();
1298 DirToks.back().setKind(tok::annot_module_name);
1299 DirToks.back().setAnnotationRange(NameLoc->
getRange());
1300 DirToks.back().setAnnotationValue(
static_cast<void *
>(NameLoc));
1302 DirToks.push_back(
Tok);
1335 if (
Result.is(tok::kw_export)) {
1336 LastExportKeyword =
Result;
1349 if (LastExportKeyword.is(tok::kw_export)) {
1352 if (!LastExportKeyword.isAtPhysicalStartOfLine())
1357 if (
Result.isAtPhysicalStartOfLine())
1359 }
else if (!
Result.isAtPhysicalStartOfLine())
1363 CurPPLexer->ParsingPreprocessorDirective,
true);
1367 CurPPLexer->ParsingFilename,
1368 Result.getIdentifierInfo()->isImportKeyword());
1370 std::optional<Token> NextTok = peekNextPPToken();
1374 if (NextTok->is(tok::raw_identifier))
1377 if (
Result.getIdentifierInfo()->isImportKeyword()) {
1378 if (NextTok->isOneOf(tok::identifier, tok::less, tok::colon,
1379 tok::header_name)) {
1380 Result.setKind(tok::kw_import);
1381 ModuleImportLoc =
Result.getLocation();
1386 if (
Result.getIdentifierInfo()->isModuleKeyword() &&
1387 NextTok->isOneOf(tok::identifier, tok::colon, tok::semi)) {
1388 Result.setKind(tok::kw_module);
1389 ModuleDeclLoc =
Result.getLocation();
1406 bool StopUntilEOD) {
1408 Toks.emplace_back();
1411 switch (Toks.back().getKind()) {
1430 auto ToksCopy = std::make_unique<Token[]>(Toks.size());
1431 std::copy(Toks.begin(), Toks.end(), ToksCopy.get());
1432 EnterTokenStream(std::move(ToksCopy), Toks.size(),
1434 assert(CurTokenLexer &&
"Must have a TokenLexer");
1435 CurTokenLexer->setLexingCXXModuleDirective();
1439 bool IncludeExports) {
1440 CurSubmoduleState->VisibleModules.setVisible(
1441 M, Loc, IncludeExports, [](
Module *) {},
1445 Diag(ModuleImportLoc, diag::warn_module_conflict)
1446 << Path[0]->getFullModuleName()
1447 << Conflict->getFullModuleName()
1452 if (!BuildingSubmoduleStack.empty() && M != BuildingSubmoduleStack.back().M)
1453 BuildingSubmoduleStack.back().M->Imports.insert(M);
1457 const char *DiagnosticTag,
1458 bool AllowMacroExpansion) {
1460 if (
Result.isNot(tok::string_literal)) {
1461 Diag(
Result, diag::err_expected_string_literal)
1462 << 0 << DiagnosticTag;
1469 StrToks.push_back(
Result);
1471 if (
Result.hasUDSuffix())
1474 if (AllowMacroExpansion)
1478 }
while (
Result.is(tok::string_literal));
1482 assert(Literal.isOrdinary() &&
"Didn't allow wide strings in");
1484 if (Literal.hadError)
1487 if (Literal.Pascal) {
1488 Diag(StrToks[0].getLocation(), diag::err_expected_string_literal)
1489 << 0 << DiagnosticTag;
1493 String = std::string(Literal.GetString());
1498 assert(
Tok.is(tok::numeric_constant));
1500 bool NumberInvalid =
false;
1501 StringRef Spelling =
getSpelling(
Tok, IntegerBuffer, &NumberInvalid);
1507 if (Literal.hadError || !Literal.isIntegerLiteral() || Literal.hasUDSuffix())
1509 llvm::APInt APVal(64, 0);
1510 if (Literal.GetIntegerValue(APVal))
1513 Value = APVal.getLimitedValue();
1518 assert(Handler &&
"NULL comment handler");
1519 assert(!llvm::is_contained(CommentHandlers, Handler) &&
1520 "Comment handler already registered");
1521 CommentHandlers.push_back(Handler);
1525 std::vector<CommentHandler *>::iterator Pos =
1526 llvm::find(CommentHandlers, Handler);
1527 assert(Pos != CommentHandlers.end() &&
"Comment handler not registered");
1528 CommentHandlers.erase(Pos);
1532 bool AnyPendingTokens =
false;
1534 if (H->HandleComment(*
this, Comment))
1535 AnyPendingTokens =
true;
1543void Preprocessor::emitMacroDeprecationWarning(
const Token &Identifier)
const {
1544 const MacroAnnotations &A =
1546 assert(A.DeprecationInfo &&
1547 "Macro deprecation warning without recorded annotation!");
1548 const MacroAnnotationInfo &Info = *A.DeprecationInfo;
1549 if (Info.Message.empty())
1550 Diag(Identifier, diag::warn_pragma_deprecated_macro_use)
1553 Diag(Identifier, diag::warn_pragma_deprecated_macro_use)
1555 Diag(Info.Location, diag::note_pp_macro_annotation) << 0;
1558void Preprocessor::emitRestrictExpansionWarning(
const Token &Identifier)
const {
1559 const MacroAnnotations &A =
1561 assert(A.RestrictExpansionInfo &&
1562 "Macro restricted expansion warning without recorded annotation!");
1563 const MacroAnnotationInfo &Info = *A.RestrictExpansionInfo;
1564 if (Info.Message.empty())
1565 Diag(Identifier, diag::warn_pragma_restrict_expansion_macro_use)
1568 Diag(Identifier, diag::warn_pragma_restrict_expansion_macro_use)
1570 Diag(Info.Location, diag::note_pp_macro_annotation) << 1;
1573void Preprocessor::emitRestrictInfNaNWarning(
const Token &Identifier,
1574 unsigned DiagSelection)
const {
1575 Diag(Identifier, diag::warn_fp_nan_inf_when_disabled) << DiagSelection << 1;
1578void Preprocessor::emitFinalMacroWarning(
const Token &Identifier,
1579 bool IsUndef)
const {
1580 const MacroAnnotations &A =
1582 assert(A.FinalAnnotationLoc &&
1583 "Final macro warning without recorded annotation!");
1585 Diag(Identifier, diag::warn_pragma_final_macro)
1587 Diag(*A.FinalAnnotationLoc, diag::note_pp_macro_annotation) << 2;
1594 auto TestInMap = [&SourceMgr](
const SafeBufferOptOutRegionsTy &Map,
1597 auto FirstRegionEndingAfterLoc = llvm::partition_point(
1599 &Loc](
const std::pair<SourceLocation, SourceLocation> &Region) {
1600 return SourceMgr.isBeforeInTranslationUnit(Region.second, Loc);
1603 if (FirstRegionEndingAfterLoc != Map.end()) {
1605 return SourceMgr.isBeforeInTranslationUnit(
1606 FirstRegionEndingAfterLoc->first, Loc);
1610 if (!Map.empty() && Map.back().first == Map.back().second)
1611 return SourceMgr.isBeforeInTranslationUnit(Map.back().first, Loc);
1633 if (SourceMgr.isLocalSourceLocation(Loc))
1634 return TestInMap(SafeBufferOptOutMap, Loc);
1637 LoadedSafeBufferOptOutMap.lookupLoadedOptOutMap(Loc, SourceMgr);
1649 InSafeBufferOptOutRegion =
true;
1650 CurrentSafeBufferOptOutStart = Loc;
1654 if (!SafeBufferOptOutMap.empty()) {
1655 [[maybe_unused]]
auto *PrevRegion = &SafeBufferOptOutMap.back();
1656 assert(PrevRegion->first != PrevRegion->second &&
1657 "Shall not begin a safe buffer opt-out region before closing the "
1663 SafeBufferOptOutMap.emplace_back(Loc, Loc);
1667 InSafeBufferOptOutRegion =
false;
1671 assert(!SafeBufferOptOutMap.empty() &&
1672 "Misordered safe buffer opt-out regions");
1673 auto *CurrRegion = &SafeBufferOptOutMap.back();
1674 assert(CurrRegion->first == CurrRegion->second &&
1675 "Set end location to a closed safe buffer opt-out region");
1676 CurrRegion->second = Loc;
1682 return InSafeBufferOptOutRegion;
1685 StartLoc = CurrentSafeBufferOptOutStart;
1686 return InSafeBufferOptOutRegion;
1691 assert(!InSafeBufferOptOutRegion &&
1692 "Attempt to serialize safe buffer opt-out regions before file being "
1693 "completely preprocessed");
1697 for (
const auto &[begin, end] : SafeBufferOptOutMap) {
1698 SrcSeq.push_back(begin);
1699 SrcSeq.push_back(end);
1711 if (SourceLocations.size() == 0)
1714 assert(SourceLocations.size() % 2 == 0 &&
1715 "ill-formed SourceLocation sequence");
1717 auto It = SourceLocations.begin();
1718 SafeBufferOptOutRegionsTy &Regions =
1719 LoadedSafeBufferOptOutMap.findAndConsLoadedOptOutMap(*It, SourceMgr);
1725 Regions.emplace_back(Begin, End);
1726 }
while (It != SourceLocations.end());
1747 if (
auto It = CheckPoints.find(FID); It != CheckPoints.end()) {
1749 const char *
Last =
nullptr;
1751 for (
const char *P : FileCheckPoints) {
1763 return DirTracer && DirTracer->hasSeenNoTrivialPPDirective();
1767 return SeenNoTrivialPPDirective;
1770void NoTrivialPPDirectiveTracer::setSeenNoTrivialPPDirective() {
1771 if (InMainFile && !SeenNoTrivialPPDirective)
1772 SeenNoTrivialPPDirective =
true;
1778 InMainFile = (FID == PP.getSourceManager().getMainFileID());
1787 setSeenNoTrivialPPDirective();
Defines enum values for all the target-independent builtin functions.
This is the interface for scanning header and source files to get the minimum necessary preprocessor ...
Defines the clang::FileManager interface and associated types.
Defines the clang::IdentifierInfo, clang::IdentifierTable, and clang::Selector interfaces.
Forward-declares and imports various common LLVM datatypes that clang wants to use unqualified.
Defines the clang::LangOptions interface.
Defines the clang::MacroInfo and clang::MacroDirective classes.
Defines the clang::Module class, which describes a module in the source code.
Defines the PreprocessorLexer interface.
static bool MacroDefinitionEquals(const MacroInfo *MI, ArrayRef< TokenValue > Tokens)
Compares macro tokens with a specified token value sequence.
static constexpr unsigned CheckPointStepSize
Minimum distance between two check points, in tokens.
Defines the clang::Preprocessor interface.
Defines the clang::SourceLocation class and associated facilities.
Defines the SourceManager interface.
__DEVICE__ void * memcpy(void *__a, const void *__b, size_t __c)
virtual ~CodeCompletionHandler()
Concrete class used by the front-end to report problems and issues.
virtual ~EmptylineHandler()
virtual ~ExternalPreprocessorSource()
virtual void updateOutOfDateIdentifier(const IdentifierInfo &II)=0
Update an out-of-date identifier.
A reference to a FileEntry that includes the name of the file as it was accessed by the FileManager's...
Cached information about one file (either on disk or in the virtual file system).
An opaque identifier used by SourceManager which refers to a source file (MemoryBuffer) along with it...
Provides lookups to, and iteration over, IdentiferInfo objects.
One of these records is kept for each identifier that is lexed.
bool IsKeywordInCPlusPlus() const
Return true if this identifier would be a keyword in C++ mode.
tok::TokenKind getTokenID() const
If this is a source-language token (e.g.
void setIsPoisoned(bool Value=true)
setIsPoisoned - Mark this identifier as poisoned.
bool isPoisoned() const
Return true if this token has been poisoned.
bool isStr(const char(&Str)[StrLen]) const
Return true if this is the identifier for the specified string.
bool isOutOfDate() const
Determine whether the information for this identifier is out of date with respect to the external sou...
void setIsFutureCompatKeyword(bool Val)
StringRef getName() const
Return the actual identifier string.
bool isFutureCompatKeyword() const
is/setIsFutureCompatKeyword - Initialize information about whether or not this language token is a ke...
bool isExtensionToken() const
get/setExtension - Initialize information about whether or not this language token is an extension.
@ FEM_UnsetOnCommandLine
Used only for FE option processing; this is only used to indicate that the user did not specify an ex...
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
MacroArgs - An instance of this class captures information about the formal arguments specified to a ...
A description of the current definition of a macro.
MacroInfo * getMacroInfo() const
Get the MacroInfo that should be used for this definition.
MacroInfo * getMacroInfo()
SourceLocation getLocation() const
Encapsulates the data about a macro definition (e.g.
const_tokens_iterator tokens_begin() const
unsigned getNumTokens() const
Return the number of tokens that this macro expands to.
const Token & getReplacementToken(unsigned Tok) const
bool isBuiltinMacro() const
Return true if this macro requires processing before expansion.
bool isObjectLike() const
Abstract interface for a module loader.
static std::string getFlatNameFromPath(ModuleIdPath Path)
Represents a macro directive exported by a module.
static ModuleNameLoc * Create(Preprocessor &PP, ModuleIdPath Path)
SourceRange getRange() const
Describes a module or submodule.
void MacroExpands(const Token &MacroNameTok, const MacroDefinition &MD, SourceRange Range, const MacroArgs *Args) override
Called by Preprocessor::HandleMacroExpandedIdentifier when a macro invocation is found.
bool hasSeenNoTrivialPPDirective() const
void LexedFileChanged(FileID FID, LexedFileChangeReason Reason, SrcMgr::CharacteristicKind FileType, FileID PrevFID, SourceLocation Loc) override
Callback invoked whenever the Lexer moves to a different file for lexing.
NumericLiteralParser - This performs strict semantic analysis of the content of a ppnumber,...
PragmaNamespace - This PragmaHandler subdivides the namespace of pragmas, allowing hierarchical pragm...
A record of the steps taken while preprocessing a source file, including the various preprocessing di...
void setConditionalLevels(ArrayRef< PPConditionalInfo > CL)
PreprocessorOptions - This class is used for passing the various options used in preprocessor initial...
std::string PCHThroughHeader
If non-empty, the filename used in an include directive in the primary source file (or command-line p...
bool GeneratePreamble
True indicates that a preamble is being generated.
Engages in a tight little dance with the lexer to efficiently preprocess tokens.
bool markIncluded(FileEntryRef File)
Mark the file as included.
void FinalizeForModelFile()
Cleanup after model file parsing.
bool FinishLexStringLiteral(Token &Result, std::string &String, const char *DiagnosticTag, bool AllowMacroExpansion)
Complete the lexing of a string literal where the first token has already been lexed (see LexStringLi...
bool creatingPCHWithThroughHeader()
True if creating a PCH with a through header.
void DumpToken(const Token &Tok, bool DumpFlags=false) const
Print the token to stderr, used for debugging.
void EnterModuleSuffixTokenStream(ArrayRef< Token > Toks)
void InitializeForModelFile()
Initialize the preprocessor to parse a model file.
const MacroInfo * getMacroInfo(const IdentifierInfo *II) const
void setCodeCompletionTokenRange(const SourceLocation Start, const SourceLocation End)
Set the code completion token range for detecting replacement range later on.
macro_iterator macro_begin(bool IncludeExternalMacros=true) const
void CreateString(StringRef Str, Token &Tok, SourceLocation ExpansionLocStart=SourceLocation(), SourceLocation ExpansionLocEnd=SourceLocation())
Plop the specified string into a scratch buffer and set the specified token's location and length to ...
bool isSafeBufferOptOut(const SourceManager &SourceMgr, const SourceLocation &Loc) const
const char * getCheckPoint(FileID FID, const char *Start) const
Returns a pointer into the given file's buffer that's guaranteed to be between tokens.
IdentifierInfo * LookUpIdentifierInfo(Token &Identifier) const
Given a tok::raw_identifier token, look up the identifier information for the token and install it in...
void DumpMacro(const MacroInfo &MI) const
void setCodeCompletionReached()
Note that we hit the code-completion point.
bool SetCodeCompletionPoint(FileEntryRef File, unsigned Line, unsigned Column)
Specify the point at which code-completion will be performed.
void Lex(Token &Result)
Lex the next token for this preprocessor.
const TranslationUnitKind TUKind
The kind of translation unit we are processing.
bool EnterSourceFile(FileID FID, ConstSearchDirIterator Dir, SourceLocation Loc, bool IsFirstIncludeOfFile=true)
Add a source file to the top of the include stack and start lexing tokens from it instead of the curr...
void addCommentHandler(CommentHandler *Handler)
Add the specified comment handler to the preprocessor.
void removeCommentHandler(CommentHandler *Handler)
Remove the specified comment handler.
void HandlePoisonedIdentifier(Token &Identifier)
Display reason for poisoned identifier.
bool HandleIdentifier(Token &Identifier)
Callback invoked when the lexer reads an identifier and has filled in the tokens IdentifierInfo membe...
void addPPCallbacks(std::unique_ptr< PPCallbacks > C)
bool enterOrExitSafeBufferOptOutRegion(bool isEnter, const SourceLocation &Loc)
Alter the state of whether this PP currently is in a "-Wunsafe-buffer-usage" opt-out region.
void EnterMainSourceFile()
Enter the specified FileID as the main source file, which implicitly adds the builtin defines etc.
const MacroAnnotations & getMacroAnnotations(const IdentifierInfo *II) const
IdentifierInfo * getIdentifierInfo(StringRef Name) const
Return information about the specified preprocessor identifier token.
macro_iterator macro_end(bool IncludeExternalMacros=true) const
SourceManager & getSourceManager() const
bool isBacktrackEnabled() const
True if EnableBacktrackAtThisPos() was called and caching of tokens is on.
MacroDefinition getMacroDefinition(const IdentifierInfo *II)
bool isPreprocessedModuleFile() const
Whether the main file is preprocessed module file.
void SetPoisonReason(IdentifierInfo *II, unsigned DiagID)
Specifies the reason for poisoning an identifier.
SourceLocation CheckEndOfDirective(StringRef DirType, bool EnableMacros=false, SmallVectorImpl< Token > *ExtraToks=nullptr)
Ensure that the next token is a tok::eod token.
bool getCommentRetentionState() const
Module * getCurrentModuleImplementation()
Retrieves the module whose implementation we're current compiling, if any.
MacroMap::const_iterator macro_iterator
void createPreprocessingRecord()
Create a new preprocessing record, which will keep track of all macro expansions, macro definitions,...
SourceLocation SplitToken(SourceLocation TokLoc, unsigned Length)
Split the first Length characters out of the token starting at TokLoc and return a location pointing ...
Module * getCurrentModule()
Retrieves the module that we're currently building, if any.
bool isPPInSafeBufferOptOutRegion()
void makeModuleVisible(Module *M, SourceLocation Loc, bool IncludeExports=true)
bool hadModuleLoaderFatalFailure() const
void setCurrentFPEvalMethod(SourceLocation PragmaLoc, LangOptions::FPEvalMethodKind Val)
bool HandleModuleContextualKeyword(Token &Result)
Callback invoked when the lexer sees one of export, import or module token at the start of a line.
const TargetInfo & getTargetInfo() const
bool LexHeaderName(Token &Result, bool AllowMacroExpansion=true)
Lex a token, forming a header-name token if possible.
bool isPCHThroughHeader(const FileEntry *FE)
Returns true if the FileEntry is the PCH through header.
void DumpLocation(SourceLocation Loc) const
bool parseSimpleIntegerLiteral(Token &Tok, uint64_t &Value)
Parses a simple integer literal to get its numeric value.
void LexUnexpandedToken(Token &Result)
Just like Lex, but disables macro expansion of identifier tokens.
bool creatingPCHWithPragmaHdrStop()
True if creating a PCH with a pragma hdrstop.
void Initialize(const TargetInfo &Target, const TargetInfo *AuxTarget=nullptr)
Initialize the preprocessor using information about the target.
FileID getPredefinesFileID() const
Returns the FileID for the preprocessor predefines.
llvm::BumpPtrAllocator & getPreprocessorAllocator()
StringRef getSpelling(SourceLocation loc, SmallVectorImpl< char > &buffer, bool *invalid=nullptr) const
Return the 'spelling' of the token at the given location; does not go up to the spelling location or ...
bool HandleComment(Token &result, SourceRange Comment)
HeaderSearch & getHeaderSearchInfo() const
bool setDeserializedSafeBufferOptOutMap(const SmallVectorImpl< SourceLocation > &SrcLocSeqs)
ExternalPreprocessorSource * getExternalSource() const
void HandleDirective(Token &Result)
Callback invoked when the lexer sees a # token at the start of a line.
SmallVector< SourceLocation, 64 > serializeSafeBufferOptOutMap() const
void recomputeCurLexerKind()
Recompute the current lexer kind based on the CurLexer/ CurTokenLexer pointers.
OptionalFileEntryRef LookupFile(SourceLocation FilenameLoc, StringRef Filename, bool isAngled, ConstSearchDirIterator FromDir, const FileEntry *FromFile, ConstSearchDirIterator *CurDir, SmallVectorImpl< char > *SearchPath, SmallVectorImpl< char > *RelativePath, ModuleMap::KnownHeader *SuggestedModule, bool *IsMapped, bool *IsFrameworkFound, bool SkipCache=false, bool OpenFile=true, bool CacheFailures=true)
Given a "foo" or <foo> reference, look up the indicated file.
IdentifierTable & getIdentifierTable()
bool LexModuleNameContinue(Token &Tok, SourceLocation UseLoc, SmallVectorImpl< Token > &Suffix, SmallVectorImpl< IdentifierLoc > &Path, bool AllowMacroExpansion, bool IsPartition)
const LangOptions & getLangOpts() const
void setTUFPEvalMethod(LangOptions::FPEvalMethodKind Val)
void CodeCompleteIncludedFile(llvm::StringRef Dir, bool IsAngled)
Hook used by the lexer to invoke the "included file" code completion point.
llvm::DenseMap< FileID, SafeBufferOptOutRegionsTy > LoadedRegions
void PoisonSEHIdentifiers(bool Poison=true)
size_t getTotalMemory() const
void LexTokensUntilEOF(std::vector< Token > *Tokens=nullptr)
Lex all tokens for this preprocessor until (and excluding) end of file.
bool isNextPPTokenOneOf(Ts... Ks) const
isNextPPTokenOneOf - Check whether the next pp-token is one of the specificed token kind.
bool usingPCHWithPragmaHdrStop()
True if using a PCH with a pragma hdrstop.
void CodeCompleteNaturalLanguage()
Hook used by the lexer to invoke the "natural language" code completion point.
void EndSourceFile()
Inform the preprocessor callbacks that processing is complete.
void CollectPPImportSuffix(SmallVectorImpl< Token > &Toks, bool StopUntilEOD=false)
Collect the tokens of a C++20 pp-import-suffix.
DiagnosticsEngine & getDiagnostics() const
bool hasSeenNoTrivialPPDirective() const
Whether we've seen pp-directives which may have changed the preprocessing state.
StringRef getLastMacroWithSpelling(SourceLocation Loc, ArrayRef< TokenValue > Tokens) const
Return the name of the macro defined before Loc that has spelling Tokens.
void setCodeCompletionIdentifierInfo(IdentifierInfo *Filter)
Set the code completion token for filtering purposes.
bool HandleModuleName(StringRef DirType, SourceLocation UseLoc, Token &Tok, SmallVectorImpl< IdentifierLoc > &Path, SmallVectorImpl< Token > &DirToks, bool AllowMacroExpansion, bool IsPartition)
DiagnosticBuilder Diag(SourceLocation Loc, unsigned DiagID) const
Forwarding function for diagnostics.
void SkipTokensWhileUsingPCH()
Skip tokens until after the include of the through header or until after a pragma hdrstop.
bool usingPCHWithThroughHeader()
True if using a PCH with a through header.
bool CollectPPImportSuffixAndEnterStream(SmallVectorImpl< Token > &Toks, bool StopUntilEOD=false)
Preprocessor(const PreprocessorOptions &PPOpts, DiagnosticsEngine &diags, const LangOptions &LangOpts, SourceManager &SM, HeaderSearch &Headers, ModuleLoader &TheModuleLoader, IdentifierInfoLookup *IILookup=nullptr, bool OwnsHeaderSearch=false, TranslationUnitKind TUKind=TU_Complete)
Represents an unpacked "presumed" location which can be presented to the user.
unsigned getColumn() const
Return the presumed column number of this location.
unsigned getLine() const
Return the presumed line number of this location.
bool isInvalid() const
Return true if this object is invalid or uninitialized.
ScratchBuffer - This class exposes a simple interface for the dynamic construction of tokens.
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
void print(raw_ostream &OS, const SourceManager &SM) const
SourceLocation getLocWithOffset(IntTy Offset) const
Return a source location with the specified offset from this SourceLocation.
This class handles loading and caching of source files into memory.
std::optional< StringRef > getBufferDataOrNone(FileID FID) const
Return a StringRef to the source buffer data for the specified FileID, returning std::nullopt if inva...
A trivial tuple used to represent a source range.
StringLiteralParser - This decodes string escape characters and performs wide string analysis and Tra...
Exposes information about the current target.
Token - This structure provides full information about a lexed token.
IdentifierInfo * getIdentifierInfo() const
bool hasUCN() const
Returns true if this token contains a universal character name.
SourceLocation getLocation() const
Return a source location identifier for the specified offset in the current file.
unsigned getLength() const
bool isExpandDisabled() const
Return true if this identifier token should never be expanded in the future, due to C99 6....
void setKind(tok::TokenKind K)
bool is(tok::TokenKind K) const
is/isNot - Predicates to check if this token is a specific kind, as in "if (Tok.is(tok::l_brace)) {....
bool isAtStartOfLine() const
isAtStartOfLine - Return true if this token is at the start of a line.
bool isOneOf(Ts... Ks) const
@ HasSeenNoTrivialPPDirective
bool isModuleContextualKeyword(bool AllowExport=true) const
Return true if we have a C++20 modules contextual keyword(export, importor module).
bool hasLeadingSpace() const
Return true if this token has whitespace before it.
bool hasLeadingEmptyMacro() const
Return true if this token has an empty macro before it.
bool isNot(tok::TokenKind K) const
void startToken()
Reset all flags to cleared.
bool needsCleaning() const
Return true if this token has trigraphs or escaped newlines in it.
void setIdentifierInfo(IdentifierInfo *II)
void setFlagValue(TokenFlags Flag, bool Val)
Set a flag to either true or false.
StringRef getRawIdentifier() const
getRawIdentifier - For a raw identifier token (i.e., an identifier lexed in raw mode),...
void setFlag(TokenFlags Flag)
Set the specified flag.
Defines the clang::TargetInfo interface.
CharacteristicKind
Indicates whether a file or directory holds normal user code, system code, or system code which is im...
const char * getTokenName(TokenKind Kind) LLVM_READNONE
Determines the name of a token as used within the front end.
const char * getKeywordSpelling(TokenKind Kind) LLVM_READNONE
Determines the spelling of simple keyword and contextual keyword tokens like 'int' and 'dynamic_cast'...
The JSON file list parser is used to communicate input to InstallAPI.
CustomizableOptional< FileEntryRef > OptionalFileEntryRef
llvm::Registry< PragmaHandler > PragmaHandlerRegistry
Registry of pragma handlers added by plugins.
void expandUCNs(SmallVectorImpl< char > &Buf, StringRef Input)
Copy characters from Input to Buf, expanding any UCNs.
ArrayRef< IdentifierLoc > ModuleIdPath
A sequence of identifier/location pairs used to describe a particular module or submodule,...
std::pair< FileID, unsigned > FileIDAndOffset
nullptr
This class represents a compute construct, representing a 'Kind' of ‘parallel’, 'serial',...
bool isPreprocessedModuleFile(StringRef Source)
Scan an input source buffer, and check whether the input source is a preprocessed output.
@ Result
The result type of a method or function.
TranslationUnitKind
Describes the kind of translation unit being processed.
@ TU_Prefix
The translation unit is a prefix to a translation unit, and is not complete.