clang: clang::SourceManager Class Reference (original) (raw)

This class handles loading and caching of source files into memory. More...

#include "[clang/Basic/SourceManager.h](SourceManager%5F8h%5Fsource.html)"

Public Member Functions
SourceManager (DiagnosticsEngine &Diag, FileManager &FileMgr, bool UserFilesAreVolatile=false)
SourceManager (const SourceManager &)=delete
SourceManager & operator= (const SourceManager &)=delete
~SourceManager ()
void clearIDTables ()
void initializeForReplay (const SourceManager &Old)
Initialize this source manager suitably to replay the compilation described by Old.
DiagnosticsEngine & getDiagnostics () const
FileManager & getFileManager () const
void setOverridenFilesKeepOriginalName (bool value)
Set true if the SourceManager should report the original file name for contents of files that were overridden by other files.
bool userFilesAreVolatile () const
True if non-system source files should be treated as volatile (likely to change while trying to use them).
ModuleBuildStack getModuleBuildStack () const
Retrieve the module build stack.
void setModuleBuildStack (ModuleBuildStack stack)
Set the module build stack.
void pushModuleBuildStack (StringRef moduleName, FullSourceLoc importLoc)
Push an entry to the module build stack.
FileID getMainFileID () const
Returns the FileID of the main source file.
void setMainFileID (FileID FID)
Set the file ID for the main source file.
bool isMainFile (const FileEntry &SourceFile)
Returns true when the given FileEntry corresponds to the main file.
void setPreambleFileID (FileID Preamble)
Set the file ID for the precompiled preamble.
FileID getPreambleFileID () const
Get the file ID for the precompiled preamble if there is one.
FileID createFileID (FileEntryRef SourceFile, SourceLocation IncludePos, SrcMgr::CharacteristicKind FileCharacter, int LoadedID=0, SourceLocation::UIntTy LoadedOffset=0)
Create a new FileID that represents the specified file being #included from the specified IncludePosition.
FileID createFileID (std::unique_ptr< llvm::MemoryBuffer > Buffer, SrcMgr::CharacteristicKind FileCharacter=SrcMgr::C_User, int LoadedID=0, SourceLocation::UIntTy LoadedOffset=0, SourceLocation IncludeLoc=SourceLocation())
Create a new FileID that represents the specified memory buffer.
FileID createFileID (const llvm::MemoryBufferRef &Buffer, SrcMgr::CharacteristicKind FileCharacter=SrcMgr::C_User, int LoadedID=0, SourceLocation::UIntTy LoadedOffset=0, SourceLocation IncludeLoc=SourceLocation())
Create a new FileID that represents the specified memory buffer.
FileID getOrCreateFileID (FileEntryRef SourceFile, SrcMgr::CharacteristicKind FileCharacter)
Get the FileID for SourceFile if it exists.
SourceLocation createMacroArgExpansionLoc (SourceLocation SpellingLoc, SourceLocation ExpansionLoc, unsigned Length)
Creates an expansion SLocEntry for the substitution of an argument into a function-like macro's body.
SourceLocation createExpansionLoc (SourceLocation SpellingLoc, SourceLocation ExpansionLocStart, SourceLocation ExpansionLocEnd, unsigned Length, bool ExpansionIsTokenRange=true, int LoadedID=0, SourceLocation::UIntTy LoadedOffset=0)
Creates an expansion SLocEntry for a macro use.
SourceLocation createTokenSplitLoc (SourceLocation SpellingLoc, SourceLocation TokenStart, SourceLocation TokenEnd)
Return a new SourceLocation that encodes that the token starting at TokenStart ends prematurely at TokenEnd.
std::optional< llvm::MemoryBufferRef > getMemoryBufferForFileOrNone (FileEntryRef File)
Retrieve the memory buffer associated with the given file.
llvm::MemoryBufferRef getMemoryBufferForFileOrFake (FileEntryRef File)
Retrieve the memory buffer associated with the given file.
void overrideFileContents (FileEntryRef SourceFile, const llvm::MemoryBufferRef &Buffer)
Override the contents of the given source file by providing an already-allocated buffer.
void overrideFileContents (FileEntryRef SourceFile, std::unique_ptr< llvm::MemoryBuffer > Buffer)
Override the contents of the given source file by providing an already-allocated buffer.
void overrideFileContents (const FileEntry *SourceFile, FileEntryRef NewFile)
Override the given source file with another one.
bool isFileOverridden (const FileEntry *File) const
Returns true if the file contents have been overridden.
OptionalFileEntryRef bypassFileContentsOverride (FileEntryRef File)
Bypass the overridden contents of a file.
void setFileIsTransient (FileEntryRef SourceFile)
Specify that a file is transient.
void setAllFilesAreTransient (bool Transient)
Specify that all files that are read during this compilation are transient.
std::optional< llvm::MemoryBufferRef > getBufferOrNone (FileID FID, SourceLocation Loc=SourceLocation()) const
Return the buffer for the specified FileID.
llvm::MemoryBufferRef getBufferOrFake (FileID FID, SourceLocation Loc=SourceLocation()) const
Return the buffer for the specified FileID.
const FileEntry * getFileEntryForID (FileID FID) const
Returns the FileEntry record for the provided FileID.
OptionalFileEntryRef getFileEntryRefForID (FileID FID) const
Returns the FileEntryRef for the provided FileID.
std::optional< StringRef > getNonBuiltinFilenameForID (FileID FID) const
Returns the filename for the provided FileID, unless it's a built-in buffer that's not represented by a filename.
const FileEntry * getFileEntryForSLocEntry (const SrcMgr::SLocEntry &SLocEntry) const
Returns the FileEntry record for the provided SLocEntry.
StringRef getBufferData (FileID FID, bool *Invalid=nullptr) const
Return a StringRef to the source buffer data for the specified FileID.
std::optional< StringRef > getBufferDataOrNone (FileID FID) const
Return a StringRef to the source buffer data for the specified FileID, returning std::nullopt if invalid.
std::optional< StringRef > getBufferDataIfLoaded (FileID FID) const
Return a StringRef to the source buffer data for the specified FileID, returning std::nullopt if it's not yet loaded.
unsigned getNumCreatedFIDsForFileID (FileID FID) const
Get the number of FileIDs (files and macros) that were created during preprocessing of FID, including it.
void setNumCreatedFIDsForFileID (FileID FID, unsigned NumFIDs, bool Force=false)
Set the number of FileIDs (files and macros) that were created during preprocessing of FID, including it.
FileID getFileID (SourceLocation SpellingLoc) const
Return the FileID for a SourceLocation.
StringRef getFilename (SourceLocation SpellingLoc) const
Return the filename of the file containing a SourceLocation.
SourceLocation getLocForStartOfFile (FileID FID) const
Return the source location corresponding to the first byte of the specified file.
SourceLocation getLocForEndOfFile (FileID FID) const
Return the source location corresponding to the last byte of the specified file.
SourceLocation getIncludeLoc (FileID FID) const
Returns the include location if FID is a #include'd file otherwise it returns an invalid location.
std::pair< SourceLocation, StringRef > getModuleImportLoc (SourceLocation Loc) const
SourceLocation getExpansionLoc (SourceLocation Loc) const
Given a SourceLocation object Loc, return the expansion location referenced by the ID.
SourceLocation getFileLoc (SourceLocation Loc) const
Given Loc, if it is a macro location return the expansion location or the spelling location, depending on if it comes from a macro argument or not.
CharSourceRange getImmediateExpansionRange (SourceLocation Loc) const
Return the start/end of the expansion information for an expansion location.
CharSourceRange getExpansionRange (SourceLocation Loc) const
Given a SourceLocation object, return the range of tokens covered by the expansion in the ultimate file.
CharSourceRange getExpansionRange (SourceRange Range) const
Given a SourceRange object, return the range of tokens or characters covered by the expansion in the ultimate file.
CharSourceRange getExpansionRange (CharSourceRange Range) const
Given a CharSourceRange object, return the range of tokens or characters covered by the expansion in the ultimate file.
SourceLocation getSpellingLoc (SourceLocation Loc) const
Given a SourceLocation object, return the spelling location referenced by the ID.
SourceLocation getImmediateSpellingLoc (SourceLocation Loc) const
Given a SourceLocation object, return the spelling location referenced by the ID.
SourceLocation getComposedLoc (FileID FID, unsigned Offset) const
Form a SourceLocation from a FileID and Offset pair.
std::pair< FileID, unsigned > getDecomposedLoc (SourceLocation Loc) const
Decompose the specified location into a raw FileID + Offset pair.
std::pair< FileID, unsigned > getDecomposedExpansionLoc (SourceLocation Loc) const
Decompose the specified location into a raw FileID + Offset pair.
std::pair< FileID, unsigned > getDecomposedSpellingLoc (SourceLocation Loc) const
Decompose the specified location into a raw FileID + Offset pair.
std::pair< FileID, unsigned > getDecomposedIncludedLoc (FileID FID) const
Returns the "included/expanded in" decomposed location of the given FileID.
unsigned getFileOffset (SourceLocation SpellingLoc) const
Returns the offset from the start of the file that the specified SourceLocation represents.
bool isMacroArgExpansion (SourceLocation Loc, SourceLocation *StartLoc=nullptr) const
Tests whether the given source location represents a macro argument's expansion into the function-like macro definition.
bool isMacroBodyExpansion (SourceLocation Loc) const
Tests whether the given source location represents the expansion of a macro body.
bool isAtStartOfImmediateMacroExpansion (SourceLocation Loc, SourceLocation *MacroBegin=nullptr) const
Returns true if the given MacroID location points at the beginning of the immediate macro expansion.
bool isAtEndOfImmediateMacroExpansion (SourceLocation Loc, SourceLocation *MacroEnd=nullptr) const
Returns true if the given MacroID location points at the character end of the immediate macro expansion.
bool isInSLocAddrSpace (SourceLocation Loc, SourceLocation Start, unsigned Length, SourceLocation::UIntTy *RelativeOffset=nullptr) const
Returns true if Loc is inside the [Start, +Length) chunk of the source location address space.
bool isInSameSLocAddrSpace (SourceLocation LHS, SourceLocation RHS, SourceLocation::IntTy *RelativeOffset) const
Return true if both LHS and RHS are in the local source location address space or the loaded one.
const char * getCharacterData (SourceLocation SL, bool *Invalid=nullptr) const
Return a pointer to the start of the specified location in the appropriate spelling MemoryBuffer.
unsigned getColumnNumber (FileID FID, unsigned FilePos, bool *Invalid=nullptr) const
Return the column # for the specified file position.
unsigned getSpellingColumnNumber (SourceLocation Loc, bool *Invalid=nullptr) const
unsigned getExpansionColumnNumber (SourceLocation Loc, bool *Invalid=nullptr) const
unsigned getPresumedColumnNumber (SourceLocation Loc, bool *Invalid=nullptr) const
unsigned getLineNumber (FileID FID, unsigned FilePos, bool *Invalid=nullptr) const
Given a SourceLocation, return the spelling line number for the position indicated.
unsigned getSpellingLineNumber (SourceLocation Loc, bool *Invalid=nullptr) const
unsigned getExpansionLineNumber (SourceLocation Loc, bool *Invalid=nullptr) const
unsigned getPresumedLineNumber (SourceLocation Loc, bool *Invalid=nullptr) const
StringRef getBufferName (SourceLocation Loc, bool *Invalid=nullptr) const
Return the filename or buffer identifier of the buffer the location is in.
SrcMgr::CharacteristicKind getFileCharacteristic (SourceLocation Loc) const
Return the file characteristic of the specified source location, indicating whether this is a normal file, a system header, or an "implicit extern C" system header.
PresumedLoc getPresumedLoc (SourceLocation Loc, bool UseLineDirectives=true) const
Returns the "presumed" location of a SourceLocation specifies.
bool isInMainFile (SourceLocation Loc) const
Returns whether the [PresumedLoc](classclang%5F1%5F1PresumedLoc.html "Represents an unpacked "presumed" location which can be presented to the user.") for a given SourceLocation is in the main file.
bool isWrittenInSameFile (SourceLocation Loc1, SourceLocation Loc2) const
Returns true if the spelling locations for both SourceLocations are part of the same file buffer.
bool isWrittenInMainFile (SourceLocation Loc) const
Returns true if the spelling location for the given location is in the main file buffer.
bool isWrittenInBuiltinFile (SourceLocation Loc) const
Returns whether Loc is located in a file.
bool isWrittenInCommandLineFile (SourceLocation Loc) const
Returns whether Loc is located in a file.
bool isWrittenInScratchSpace (SourceLocation Loc) const
Returns whether Loc is located in a file.
bool isInSystemHeader (SourceLocation Loc) const
Returns if a SourceLocation is in a system header.
bool isInExternCSystemHeader (SourceLocation Loc) const
Returns if a SourceLocation is in an "extern C" system header.
bool isInSystemMacro (SourceLocation loc) const
Returns whether Loc is expanded from a macro in a system header.
unsigned getFileIDSize (FileID FID) const
The size of the SLocEntry that FID represents.
bool isInFileID (SourceLocation Loc, FileID FID, unsigned *RelativeOffset=nullptr) const
Given a specific FileID, returns true if Loc is inside that FileID chunk and sets relative offset (offset of Loc from beginning of FileID) to relativeOffset.
unsigned getLineTableFilenameID (StringRef Str)
Return the uniqued ID for the specified filename.
void AddLineNote (SourceLocation Loc, unsigned LineNo, int FilenameID, bool IsFileEntry, bool IsFileExit, SrcMgr::CharacteristicKind FileKind)
Add a line note to the line table for the FileID and offset specified by Loc.
bool hasLineTable () const
Determine if the source manager has a line table.
LineTableInfo & getLineTable ()
Retrieve the stored line table.
size_t getContentCacheSize () const
Return the total amount of physical memory allocated by the ContentCache allocator.
MemoryBufferSizes getMemoryBufferSizes () const
Return the amount of memory used by memory buffers, breaking down by heap-backed versus mmap'ed memory.
size_t getDataStructureSizes () const
Return the amount of memory used for various side tables and data structures in the SourceManager.
SourceLocation translateFileLineCol (const FileEntry *SourceFile, unsigned Line, unsigned Col) const
Get the source location for the given file:line:col triplet.
FileID translateFile (const FileEntry *SourceFile) const
Get the FileID for the given file.
FileID translateFile (FileEntryRef SourceFile) const
SourceLocation translateLineCol (FileID FID, unsigned Line, unsigned Col) const
Get the source location in FID for the given line:col.
SourceLocation getMacroArgExpandedLocation (SourceLocation Loc) const
If Loc points inside a function macro argument, the returned location will be the macro location in which the argument was expanded.
bool isBeforeInTranslationUnit (SourceLocation LHS, SourceLocation RHS) const
Determines the order of 2 source locations in the translation unit.
std::pair< bool, bool > isInTheSameTranslationUnit (std::pair< FileID, unsigned > &LOffs, std::pair< FileID, unsigned > &ROffs) const
Determines whether the two decomposed source location is in the same translation unit.
FileID getUniqueLoadedASTFileID (SourceLocation Loc) const
bool isInTheSameTranslationUnitImpl (const std::pair< FileID, unsigned > &LOffs, const std::pair< FileID, unsigned > &ROffs) const
Determines whether the two decomposed source location is in the same TU.
bool isBeforeInSLocAddrSpace (SourceLocation LHS, SourceLocation RHS) const
Determines the order of 2 source locations in the "source location address space".
bool isBeforeInSLocAddrSpace (SourceLocation LHS, SourceLocation::UIntTy RHS) const
Determines the order of a source location and a source location offset in the "source location address space".
bool isPointWithin (SourceLocation Location, SourceLocation Start, SourceLocation End) const
Return true if the Point is within Start and End.
fileinfo_iterator fileinfo_begin () const
fileinfo_iterator fileinfo_end () const
bool hasFileInfo (const FileEntry *File) const
void PrintStats () const
Print statistics to stderr.
void dump () const
void noteSLocAddressSpaceUsage (DiagnosticsEngine &Diag, std::optional< unsigned > MaxNotes=32) const
unsigned local_sloc_entry_size () const
Get the number of local SLocEntries we have.
const SrcMgr::SLocEntry & getLocalSLocEntry (unsigned Index) const
Get a local SLocEntry. This is exposed for indexing.
SrcMgr::SLocEntry & getLocalSLocEntry (unsigned Index)
Get a local SLocEntry. This is exposed for indexing.
unsigned loaded_sloc_entry_size () const
Get the number of loaded SLocEntries we have.
const SrcMgr::SLocEntry & getLoadedSLocEntry (unsigned Index, bool *Invalid=nullptr) const
Get a loaded SLocEntry. This is exposed for indexing.
SrcMgr::SLocEntry & getLoadedSLocEntry (unsigned Index, bool *Invalid=nullptr)
Get a loaded SLocEntry. This is exposed for indexing.
const SrcMgr::SLocEntry & getSLocEntry (FileID FID, bool *Invalid=nullptr) const
SrcMgr::SLocEntry & getSLocEntry (FileID FID, bool *Invalid=nullptr)
SourceLocation::UIntTy getNextLocalOffset () const
void setExternalSLocEntrySource (ExternalSLocEntrySource *Source)
std::pair< int, SourceLocation::UIntTy > AllocateLoadedSLocEntries (unsigned NumSLocEntries, SourceLocation::UIntTy TotalSize)
Allocate a number of loaded SLocEntries, which will be actually loaded on demand from the external source.
bool isLoadedSourceLocation (SourceLocation Loc) const
Returns true if Loc came from a PCH/Module.
bool isLocalSourceLocation (SourceLocation Loc) const
Returns true if Loc did not come from a PCH/Module.
bool isLoadedFileID (FileID FID) const
Returns true if FID came from a PCH/Module.
bool isLocalFileID (FileID FID) const
Returns true if FID did not come from a PCH/Module.
SourceLocation getImmediateMacroCallerLoc (SourceLocation Loc) const
Gets the location of the immediate macro caller, one level up the stack toward the initial macro typed into the source.
SourceLocation getTopMacroCallerLoc (SourceLocation Loc) const

This class handles loading and caching of source files into memory.

This object owns the MemoryBuffer objects for all of the loaded files and assigns unique FileID's for each unique #include chain.

The SourceManager can be queried for information about SourceLocation objects, turning them into either spelling or expansion locations. Spelling locations represent where the bytes corresponding to a token came from and expansion locations represent where the location is in the user's view. In the case of a macro expansion, for example, the spelling location indicates where the expanded token came from and the expansion location specifies where it was expanded.

Definition at line 663 of file SourceManager.h.

fileinfo_iterator

SourceManager() [2/2]

clang::SourceManager::SourceManager ( const SourceManager & ) explicitdelete

~SourceManager()

SourceManager::~SourceManager ( )

AddLineNote()

AllocateLoadedSLocEntries()

Allocate a number of loaded SLocEntries, which will be actually loaded on demand from the external source.

NumSLocEntries will be allocated, which occupy a total of TotalSize space in the global source view. The lowest ID and the base offset of the entries will be returned.

Definition at line 455 of file SourceManager.cpp.

References int.

bypassFileContentsOverride()

clearIDTables()

void SourceManager::clearIDTables ( )

createExpansionLoc()

createFileID() [1/3]

createFileID() [2/3]

Create a new FileID that represents the specified file being #included from the specified IncludePosition.

Definition at line 536 of file SourceManager.cpp.

References clang::SrcMgr::ContentCache::ContentsEntry, clang::SrcMgr::ContentCache::getBufferOrNone(), getFileManager(), clang::FileEntryRef::getName(), clang::FileEntryRef::isNamedPipe(), and clang::SrcMgr::isSystem().

Referenced by clang::tooling::applyAllReplacements(), clang::FrontendAction::BeginSourceFile(), ConvertBackendLocation(), createFileID(), clang::Preprocessor::EnterMainSourceFile(), getOrCreateFileID(), clang::ASTImporter::Import(), clang::CompilerInstance::InitializeSourceManager(), clang::SourceMgrAdapter::mapLocation(), and clang::ModuleMap::parseModuleMapFile().

createFileID() [3/3]

Create a new FileID that represents the specified memory buffer.

This does no caching of the buffer and takes ownership of the MemoryBuffer, so only pass a MemoryBuffer to this once.

Definition at line 557 of file SourceManager.cpp.

createMacroArgExpansionLoc()

createTokenSplitLoc()

dump()

LLVM_DUMP_METHOD void SourceManager::dump ( ) const

fileinfo_begin()

fileinfo_end()

getBufferData()

StringRef SourceManager::getBufferData ( FileID FID,
bool * Invalid = nullptr
) const

getBufferDataIfLoaded()

std::optional< StringRef > SourceManager::getBufferDataIfLoaded ( FileID FID ) const

getBufferDataOrNone()

std::optional< StringRef > SourceManager::getBufferDataOrNone ( FileID FID ) const

getBufferName()

StringRef SourceManager::getBufferName ( SourceLocation Loc,
bool * Invalid = nullptr
) const

getBufferOrFake()

getBufferOrNone()

getCharacterData()

const char * SourceManager::getCharacterData ( SourceLocation SL,
bool * Invalid = nullptr
) const

Return a pointer to the start of the specified location in the appropriate spelling MemoryBuffer.

getCharacterData - Return a pointer to the start of the specified location in the appropriate MemoryBuffer.

Parameters

Invalid If non-NULL, will be set true if an error occurs.

Definition at line 1124 of file SourceManager.cpp.

References clang::SrcMgr::ContentCache::getBufferOrNone(), clang::SrcMgr::FileInfo::getContentCache(), getDecomposedSpellingLoc(), clang::SrcMgr::SLocEntry::getFile(), getFileManager(), getSLocEntry(), clang::Invalid, and clang::SrcMgr::SLocEntry::isFile().

Referenced by clang::Preprocessor::DumpToken(), fixItNullability(), clang::FullSourceLoc::getCharacterData(), clang::Rewriter::getRewrittenText(), clang::Lexer::getSpelling(), and isSameWidthConstantConversion().

getColumnNumber()

getComposedLoc()

getContentCacheSize()

size_t clang::SourceManager::getContentCacheSize ( ) const inline

Return the total amount of physical memory allocated by the ContentCache allocator.

Definition at line 1607 of file SourceManager.h.

getDataStructureSizes()

size_t SourceManager::getDataStructureSizes ( ) const

getDecomposedExpansionLoc()

getDecomposedIncludedLoc()

getDecomposedLoc()

Decompose the specified location into a raw FileID + Offset pair.

The first element is the FileID, the second is the offset from the start of the buffer of the location.

Definition at line 1272 of file SourceManager.h.

References getFileID(), and Loc.

Referenced by clang::RawCommentList::addComment(), clang::ASTContext::attachCommentsToJustParsedDecls(), clang::RawCommentList::getCommentEndOffset(), clang::FullSourceLoc::getDecomposedLoc(), getFileOffset(), getImmediateSpellingLoc(), getRangeSize(), clang::ASTContext::getRawCommentForDeclNoCache(), clang::ASTContext::getRawCommentForDeclNoCacheImpl(), clang::comments::Lexer::getSpelling(), clang::ASTImporter::Import(), isAtStartOfImmediateMacroExpansion(), loadModuleMapForModuleBuild(), clang::Sema::notePreviousDefinition(), clang::ModuleMap::parseModuleMapFile(), clang::RawComment::RawComment(), and clang::ASTReader::ReadComments().

getDecomposedSpellingLoc()

getDiagnostics()

getExpansionColumnNumber()

getExpansionLineNumber()

getExpansionLoc()

Given a SourceLocation object Loc, return the expansion location referenced by the ID.

Definition at line 1194 of file SourceManager.h.

References Loc.

Referenced by clang::Sema::ActOnEndOfTranslationUnit(), clang::Sema::ActOnUsingDirective(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER_REGEX(), clang::api_notes::APINotesManager::findAPINotes(), getDeclLocsForCommentSearch(), clang::FullSourceLoc::getExpansionLoc(), getIssueHash(), clang::Preprocessor::getModuleForLocation(), getNullabilityCompletenessCheckFileID(), clang::diff::SyntaxTree::getSourceRangeOffsets(), clang::VerifyDiagnosticConsumer::HandleDiagnostic(), handleObjCOwnershipTypeAttr(), clang::ento::PathDiagnosticConsumer::HandlePathDiagnostic(), clang::Sema::InstantiateClass(), clang::Sema::InstantiateFunctionDefinition(), and clang::CodeGen::CGDebugInfo::setLocation().

getExpansionRange() [1/3]

getExpansionRange() [2/3]

Given a SourceLocation object, return the range of tokens covered by the expansion in the ultimate file.

getExpansionRange - Given a SourceLocation object, return the range of tokens covered by the expansion in the ultimate file.

Definition at line 1008 of file SourceManager.cpp.

References clang::CharSourceRange::getBegin(), clang::CharSourceRange::getEnd(), getImmediateExpansionRange(), clang::SourceLocation::isFileID(), clang::CharSourceRange::isTokenRange(), Loc, clang::CharSourceRange::setBegin(), clang::CharSourceRange::setEnd(), and clang::CharSourceRange::setTokenRange().

Referenced by clang::SourceLocExpr::EvaluateInContext(), and getExpansionRange().

getExpansionRange() [3/3]

getFileCharacteristic()

Return the file characteristic of the specified source location, indicating whether this is a normal file, a system header, or an "implicit extern C" system header.

getFileCharacteristic - return the file characteristic of the specified source location, indicating whether this is a normal file, a system header, or an "implicit extern C" system header.

This state can be modified with flags on GNU linemarker directives like:

which changes all source locations in the current file after that to be considered to be from a system header.

This state can be modified with flags on GNU linemarker directives like:

4 "foo.h" 3

which changes all source locations in the current file after that to be considered to be from a system header.

Definition at line 1440 of file SourceManager.cpp.

References clang::SrcMgr::C_User, clang::LineEntry::FileKind, clang::SrcMgr::SLocEntry::getFile(), clang::SrcMgr::FileInfo::getFileCharacteristic(), clang::SrcMgr::FileInfo::hasLineDirectives(), clang::SourceLocation::isValid(), and Loc.

Referenced by compileModule(), clang::Preprocessor::HandleEndOfFile(), isInExternCSystemHeader(), and isInSystemHeader().

getFileEntryForID()

const FileEntry * clang::SourceManager::getFileEntryForID ( FileID FID) const inline

getFileEntryForSLocEntry()

getFileEntryRefForID()

Returns the FileEntryRef for the provided FileID.

Definition at line 1077 of file SourceManager.h.

Referenced by clang::arcmt::MigrationProcess::applyTransform(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER_REGEX(), clang::PrecompiledPreamble::Build(), compileModule(), clang::ModuleMap::createModuleForInterfaceUnit(), clang::syntax::TokenBuffer::dumpForTests(), clang::tooling::dependencies::ModuleDepCollectorPP::EndOfMainFile(), clang::Preprocessor::EnterMainSourceFile(), clang::Preprocessor::EnterSourceFile(), clang::api_notes::APINotesManager::findAPINotes(), clang::ModuleMap::getContainingModuleMapFile(), clang::PreprocessorLexer::getFileEntry(), getFileEntryForID(), clang::FullSourceLoc::getFileEntryRef(), getFilename(), clang::ASTUnit::getMainFileName(), clang::Preprocessor::getModuleForLocation(), clang::ModuleMap::getModuleMapFileForUniquing(), clang::VerifyDiagnosticConsumer::HandleDiagnostic(), clang::Preprocessor::LookupFile(), clang::Sema::notePreviousDefinition(), clang::Rewriter::overwriteChangedFiles(), prepareToBuildModule(), and PrintUnexpected().

getFileID()

Return the FileID for a SourceLocation.

This is a very hot method that is used for all SourceManager queries that start with a SourceLocation object. It is responsible for finding the entry in SLocEntryTable which contains the specified location.

Definition at line 1145 of file SourceManager.h.

References getFileID().

Referenced by clang::Sema::ActOnAnnotModuleEnd(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER_REGEX(), checkConfigMacro(), compileModule(), createTokenSplitLoc(), clang::Sema::diagnoseMissingImport(), DiagnoseNullConversion(), EvaluateDefined(), clang::api_notes::APINotesManager::findAPINotes(), clang::tooling::findSelectedASTNodes(), clang::FullSourceLoc::getBufferData(), clang::ModuleMap::getContainingModuleMapFileID(), getDecomposedExpansionLoc(), getDecomposedLoc(), getDecomposedSpellingLoc(), clang::FullSourceLoc::getFileID(), getFileID(), getFilename(), getImmediateExpansionRange(), clang::Preprocessor::getModuleForLocation(), getModuleImportLoc(), getNullabilityCompletenessCheckFileID(), clang::ScratchBuffer::getToken(), clang::VerifyDiagnosticConsumer::HandleDiagnostic(), clang::Preprocessor::HandleDirective(), clang::ento::PathDiagnosticConsumer::HandlePathDiagnostic(), clang::ASTImporter::Import(), isAtEndOfImmediateMacroExpansion(), isMacroArgExpansion(), isMacroBodyExpansion(), isWrittenInMainFile(), isWrittenInSameFile(), PrintUnexpected(), shouldIgnoreMacro(), clang::syntax::TokenBuffer::spelledForExpanded(), and clang::syntax::TokenBuffer::spelledTokenContaining().

getFileIDSize()

getFileLoc()

getFileManager()

FileManager & clang::SourceManager::getFileManager ( ) const inline

Definition at line 854 of file SourceManager.h.

Referenced by clang::PrecompiledPreamble::Build(), clang::ModuleMap::canonicalizeModuleMapPath(), clang::SemaCodeCompletion::CodeCompleteIncludedFile(), createFileID(), clang::api_notes::APINotesManager::findAPINotes(), clang::BackendConsumer::getBestLocationFromDebugLoc(), getBufferDataOrNone(), getBufferOrNone(), getCharacterData(), clang::api_notes::APINotesManager::getCurrentModuleAPINotes(), getMemoryBufferForFileOrNone(), clang::ASTImporter::Import(), clang::ModuleMap::isHeaderUnavailableInModule(), and clang::Rewriter::overwriteChangedFiles().

getFilename()

StringRef SourceManager::getFilename ( SourceLocation SpellingLoc ) const

getFileOffset()

getImmediateExpansionRange()

Return the start/end of the expansion information for an expansion location.

getImmediateExpansionRange - Loc is required to be an expansion location.

Precondition

Loc is required to be an expansion location.

Return the start/end of the expansion information.

Definition at line 994 of file SourceManager.cpp.

References clang::SrcMgr::SLocEntry::getExpansion(), clang::SrcMgr::ExpansionInfo::getExpansionLocRange(), getFileID(), getSLocEntry(), clang::SourceLocation::isMacroID(), and Loc.

Referenced by checkAllAtProps(), CheckMoveOnConstruction(), clang::Sema::DiagnoseAbsenceOfOverrideControl(), DiagnoseNullConversion(), getExpansionRange(), GetFullTypeForDeclarator(), getImmediateMacroCallerLoc(), and handleObjCOwnershipTypeAttr().

getImmediateMacroCallerLoc()

getImmediateSpellingLoc()

getIncludeLoc()

getLineNumber()

Given a SourceLocation, return the spelling line number for the position indicated.

getLineNumber - Given a SourceLocation, return the spelling line number for the position indicated.

This requires building and caching a table of line offsets for the MemoryBuffer, so this is not cheap: use only when about to emit a diagnostic.

Definition at line 1315 of file SourceManager.cpp.

References clang::SrcMgr::LineOffsetMapping::begin(), Diag(), clang::SrcMgr::LineOffsetMapping::end(), clang::SrcMgr::LineOffsetMapping::get(), clang::SrcMgr::ContentCache::getBufferOrNone(), clang::SrcMgr::FileInfo::getContentCache(), clang::SrcMgr::SLocEntry::getFile(), clang::Invalid, clang::SrcMgr::SLocEntry::isFile(), clang::FileID::isInvalid(), and clang::SrcMgr::ContentCache::SourceLineCache.

Referenced by clang::RawCommentList::getCommentBeginLine(), clang::FullSourceLoc::getLineNumber(), clang::ASTContext::getRawCommentForDeclNoCacheImpl(), clang::Rewriter::IncreaseIndentation(), and clang::Rewriter::InsertText().

getLineTable()

getLineTableFilenameID()

unsigned SourceManager::getLineTableFilenameID ( StringRef Str )

getLoadedSLocEntry() [1/2]

getLoadedSLocEntry() [2/2]

getLocalSLocEntry() [1/2]

Get a local SLocEntry. This is exposed for indexing.

Definition at line 1746 of file SourceManager.h.

getLocalSLocEntry() [2/2]

getLocForEndOfFile()

getLocForStartOfFile()

Return the source location corresponding to the first byte of the specified file.

Definition at line 1154 of file SourceManager.h.

Referenced by clang::Sema::ActOnModuleDecl(), clang::html::AddHeaderFooterInternalBuiltinCSS(), ConvertBackendLocation(), clang::Preprocessor::EnterSourceFile(), clang::ASTUnit::getStartOfMainFileID(), clang::Preprocessor::HandleEndOfFile(), clang::ASTImporter::Import(), clang::SourceMgrAdapter::mapLocation(), clang::ASTUnit::mapLocationFromPreamble(), clang::ASTUnit::mapLocationToPreamble(), and clang::ModuleMap::parseModuleMapFile().

getMacroArgExpandedLocation()

If Loc points inside a function macro argument, the returned location will be the macro location in which the argument was expanded.

If.

If a macro argument is used multiple times, the expanded location will be at the first expansion of the argument. e.g. MY_MACRO(foo); ^ Passing a file location pointing at 'foo', will yield a macro location where 'foo' was expanded into.

Definition at line 1888 of file SourceManager.cpp.

References clang::SourceLocation::getLocWithOffset(), clang::SourceLocation::isFileID(), clang::FileID::isInvalid(), clang::SourceLocation::isInvalid(), clang::SourceLocation::isValid(), and Loc.

getMainFileID()

FileID clang::SourceManager::getMainFileID ( ) const inline

Returns the FileID of the main source file.

Definition at line 888 of file SourceManager.h.

Referenced by clang::Sema::ActOnModuleDecl(), clang::PrecompiledPreamble::Build(), clang::ModuleMap::createModuleForImplementationUnit(), clang::ModuleMap::createModuleForInterfaceUnit(), clang::tooling::dependencies::ModuleDepCollectorPP::EndOfMainFile(), clang::Preprocessor::EnterMainSourceFile(), clang::ASTUnit::getMainFileName(), clang::ASTUnit::getStartOfMainFileID(), clang::ASTImporter::Import(), clang::CompilerInstance::InitializeSourceManager(), clang::ASTUnit::isInMainFileID(), isWrittenInMainFile(), clang::Preprocessor::LookupFile(), clang::ASTUnit::mapLocationFromPreamble(), clang::ASTUnit::mapLocationToPreamble(), prepareToBuildModule(), ReadOriginalFileName(), and clang::Preprocessor::SetCodeCompletionPoint().

getMemoryBufferForFileOrFake()

llvm::MemoryBufferRef clang::SourceManager::getMemoryBufferForFileOrFake ( FileEntryRef File) inline

getMemoryBufferForFileOrNone()

std::optional< llvm::MemoryBufferRef > SourceManager::getMemoryBufferForFileOrNone ( FileEntryRef File )

getMemoryBufferSizes()

Return the amount of memory used by memory buffers, breaking down by heap-backed versus mmap'ed memory.

Definition at line 2352 of file SourceManager.cpp.

getModuleBuildStack()

getModuleImportLoc()

getNextLocalOffset()

getNonBuiltinFilenameForID()

std::optional< StringRef > SourceManager::getNonBuiltinFilenameForID ( FileID FID ) const

getNumCreatedFIDsForFileID()

unsigned clang::SourceManager::getNumCreatedFIDsForFileID ( FileID FID) const inline

Get the number of FileIDs (files and macros) that were created during preprocessing of FID, including it.

Definition at line 1118 of file SourceManager.h.

getOrCreateFileID()

getPreambleFileID()

FileID clang::SourceManager::getPreambleFileID ( ) const inline

getPresumedColumnNumber()

getPresumedLineNumber()

getPresumedLoc()

Returns the "presumed" location of a SourceLocation specifies.

getPresumedLoc - This method returns the "presumed" location of a SourceLocation specifies.

A "presumed location" can be modified by #line or GNU line marker directives. This provides a view on the data that a user should see in diagnostics, for example.

Note that a presumed location is always given as the expansion point of an expansion location, not at the spelling location.

Returns

The presumed location of the specified SourceLocation. If the presumed location cannot be calculated (e.g., because Loc is invalid or the file containing Loc has changed on disk), returns an invalid presumed location.

A "presumed location" can be modified by #line or GNU line marker directives. This provides a view on the data that a user should see in diagnostics, for example.

Note that a presumed location is always given as the expansion point of an expansion location, not at the spelling location.

Definition at line 1486 of file SourceManager.cpp.

References clang::C, Diag(), Filename, clang::SrcMgr::FileInfo::getContentCache(), clang::SrcMgr::SLocEntry::getFile(), clang::SrcMgr::FileInfo::getIncludeLoc(), clang::SourceLocation::getLocWithOffset(), clang::SrcMgr::FileInfo::hasLineDirectives(), clang::Invalid, clang::SrcMgr::SLocEntry::isFile(), clang::SourceLocation::isInvalid(), and Loc.

Referenced by clang::CodeGen::CGDebugInfo::AddStringLiteralDebugInfo(), clang::DoPrintPreprocessedInput(), clang::TextNodeDumper::dumpLocation(), emitMappingInformation(), clang::CodeGen::CGOpenMPRuntime::emitUpdateLocation(), clang::SourceLocExpr::EvaluateInContext(), clang::RawComment::getFormattedLines(), clang::AnalysisDeclContext::getFunctionName(), getIdentStringFromSourceLocation(), clang::CIRGen::CIRGenModule::getLoc(), getPresumedColumnNumber(), clang::FullSourceLoc::getPresumedLoc(), clang::Preprocessor::HandlePragmaSystemHeader(), isWrittenInBuiltinFile(), isWrittenInCommandLineFile(), and isWrittenInScratchSpace().

getSLocEntry() [1/2]

getSLocEntry() [2/2]

Definition at line 1770 of file SourceManager.h.

References getSLocEntry(), and clang::Invalid.

Referenced by EvaluateDefined(), getCharacterData(), getImmediateExpansionRange(), getImmediateSpellingLoc(), getNullabilityCompletenessCheckFileID(), getSLocEntry(), clang::ScratchBuffer::getToken(), clang::ASTImporter::Import(), clang::Rewriter::IncreaseIndentation(), clang::Rewriter::InsertText(), isAtEndOfImmediateMacroExpansion(), isAtStartOfImmediateMacroExpansion(), isInFileID(), isMacroArgExpansion(), and isMacroBodyExpansion().

getSpellingColumnNumber()

getSpellingLineNumber()

getSpellingLoc()

getTopMacroCallerLoc()

getUniqueLoadedASTFileID()

Parameters

Loc a source location in a loaded AST (of a PCH/Module file).

Returns

a FileID uniquely identifies the AST of a loaded module/PCH where Loc is at.

Definition at line 1950 of file SourceManager.cpp.

References Loc.

hasFileInfo()

bool clang::SourceManager::hasFileInfo ( const FileEntry * File) const inline

hasLineTable()

bool clang::SourceManager::hasLineTable ( ) const inline

Determine if the source manager has a line table.

Definition at line 1596 of file SourceManager.h.

initializeForReplay()

void SourceManager::initializeForReplay ( const SourceManager & Old )

isAtEndOfImmediateMacroExpansion()

Returns true if the given MacroID location points at the character end of the immediate macro expansion.

Parameters

MacroEnd If non-null and function returns true, it is set to the character end location of the immediate macro expansion.

Definition at line 1082 of file SourceManager.cpp.

References clang::SrcMgr::SLocEntry::getExpansion(), clang::SrcMgr::ExpansionInfo::getExpansionLocEnd(), clang::SrcMgr::ExpansionInfo::getExpansionLocStart(), getFileID(), clang::SourceLocation::getLocWithOffset(), getSLocEntry(), clang::Invalid, clang::SrcMgr::SLocEntry::isExpansion(), isInFileID(), clang::FileID::isInvalid(), clang::SrcMgr::ExpansionInfo::isMacroArgExpansion(), clang::SourceLocation::isMacroID(), clang::SourceLocation::isValid(), and Loc.

isAtStartOfImmediateMacroExpansion()

Returns true if the given MacroID location points at the beginning of the immediate macro expansion.

Parameters

MacroBegin If non-null and function returns true, it is set to the begin location of the immediate macro expansion.

Definition at line 1047 of file SourceManager.cpp.

References getDecomposedLoc(), clang::SrcMgr::SLocEntry::getExpansion(), clang::SrcMgr::ExpansionInfo::getExpansionLocStart(), getSLocEntry(), clang::Invalid, clang::SrcMgr::SLocEntry::isExpansion(), clang::FileID::isInvalid(), clang::SrcMgr::ExpansionInfo::isMacroArgExpansion(), clang::SourceLocation::isMacroID(), clang::SourceLocation::isValid(), and Loc.

Referenced by CheckMoveOnConstruction().

isBeforeInSLocAddrSpace() [1/2]

isBeforeInSLocAddrSpace() [2/2]

Determines the order of a source location and a source location offset in the "source location address space".

Note that we always consider source locations loaded from

Definition at line 1699 of file SourceManager.h.

isBeforeInTranslationUnit()

Determines the order of 2 source locations in the translation unit.

Returns

true if LHS source location comes before RHS, false otherwise.

Definition at line 2038 of file SourceManager.cpp.

References clang::SourceLocation::isValid().

Referenced by clang::PreprocessingRecord::addPreprocessedEntity(), clang::format::AffectedRangeManager::affectsCharSourceRange(), diagnoseRepeatedUseOfWeak(), clang::PPConditionalDirectiveRecord::findConditionalDirectiveRegionLoc(), clang::DeclSpec::Finish(), clang::Preprocessor::getLastMacroWithSpelling(), clang::syntax::TreeBuilder::getRange(), clang::FullSourceLoc::isBeforeInTranslationUnitThan(), isPointWithin(), clang::Preprocessor::isSafeBufferOptOut(), clang::format::WhitespaceManager::Change::IsBeforeInFile::operator()(), clang::PPConditionalDirectiveRecord::rangeIntersectsConditionalDirective(), and clang::LexicallyOrderedRecursiveASTVisitor< Derived >::TraverseDeclContextHelper().

isFileOverridden()

bool clang::SourceManager::isFileOverridden ( const FileEntry * File) const inline

isInExternCSystemHeader()

isInFileID()

isInMainFile()

Returns whether the [PresumedLoc](classclang%5F1%5F1PresumedLoc.html "Represents an unpacked "presumed" location which can be presented to the user.") for a given SourceLocation is in the main file.

This computes the "presumed" location for a SourceLocation, then checks whether it came from a file other than the main file. This is different from isWrittenInMainFile() because it takes line marker directives into account.

Definition at line 1562 of file SourceManager.cpp.

References clang::SrcMgr::SLocEntry::getFile(), clang::SrcMgr::FileInfo::getIncludeLoc(), clang::SrcMgr::FileInfo::hasLineDirectives(), clang::SourceLocation::isInvalid(), and Loc.

Referenced by clang::Sema::ActOnEndOfTranslationUnit(), clang::Sema::ActOnUsingDirective(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER(), CheckUnreachable(), diagnoseUseOfInternalDeclInInlineFunction(), clang::Preprocessor::getModuleForLocation(), clang::Preprocessor::HandlePragmaHdrstop(), isMainFileLoc(), and clang::diff::isNodeExcluded().

isInSameSLocAddrSpace()

Return true if both LHS and RHS are in the local source location address space or the loaded one.

If it's true and RelativeOffset is non-null, it will be set to the offset of RHS relative to LHS.

Definition at line 1393 of file SourceManager.h.

isInSLocAddrSpace()

Returns true if Loc is inside the [Start, +Length) chunk of the source location address space.

If it's true and RelativeOffset is non-null, it will be set to the relative offset of Loc inside the chunk.

Definition at line 1369 of file SourceManager.h.

References Loc.

isInSystemHeader()

Returns if a SourceLocation is in a system header.

Definition at line 1533 of file SourceManager.h.

References getFileCharacteristic(), and Loc.

Referenced by clang::SemaObjC::ActOnAtEnd(), clang::Sema::ActOnCXXTryBlock(), clang::Sema::ActOnLabelStmt(), clang::ASTContext::addComment(), clang::ast_matchers::AST_POLYMORPHIC_MATCHER(), clang::Sema::BuildCXXThrow(), CheckConstexprFunctionBody(), clang::Sema::CheckEquivalentExceptionSpec(), clang::SemaObjC::checkInitMethod(), clang::Preprocessor::CheckMacroName(), CheckSimplerImplicitMovesMSVCWorkaround(), DiagnoseBadConversion(), DiagReservedModuleName(), DoEmitAvailabilityWarning(), EmitDiagForCXXThrowInNonThrowingFunc(), clang::Preprocessor::getHeaderToIncludeForDiagnostics(), clang::ento::MemRegionManager::getVarRegion(), handleInitPriorityAttr(), clang::Sema::InstantiateFunctionDefinition(), clang::TemplateDeclInstantiator::InstantiateTypedefNameDecl(), isForbiddenTypeAllowed(), clang::FullSourceLoc::isInSystemHeader(), clang::extractapi::impl::ExtractAPIVisitorBase< Derived >::isInSystemHeader(), isInSystemMacro(), clang::Sema::isLibstdcxxEagerExceptionSpecHack(), isLibstdcxxPointerReturnFalseHack(), isStandardNew(), clang::sema::AnalysisBasedWarnings::IssueWarnings(), clang::Sema::makeUnavailableInSystemHeader(), clang::Sema::maybeAddDeclWithEffects(), clang::SemaCUDA::maybeAddHostDeviceAttrs(), clang::Sema::MergeTypedefNameDecl(), clang::SemaObjC::ParseObjCSelectorExpression(), and shouldIgnoreDueToReservedName().

isInSystemMacro()

Returns whether Loc is expanded from a macro in a system header.

Definition at line 1545 of file SourceManager.h.

References getImmediateMacroCallerLoc(), getSpellingLoc(), isInSystemHeader(), isInSystemMacro(), clang::SourceLocation::isMacroID(), and isWrittenInScratchSpace().

Referenced by AnalyzeBitFieldAssignment(), AnalyzeCompoundAssignment(), clang::Sema::CheckImplicitConversion(), diagnoseSubtractionOnNullPointer(), clang::Sema::diagnoseZeroToNullptrConversion(), handleStandardNoReturnAttr(), and isInSystemMacro().

isInTheSameTranslationUnit()

isInTheSameTranslationUnitImpl()

Determines whether the two decomposed source location is in the same TU.

Definition at line 1968 of file SourceManager.cpp.

isLoadedFileID()

bool clang::SourceManager::isLoadedFileID ( FileID FID) const inline

isLoadedSourceLocation()

isLocalFileID()

bool clang::SourceManager::isLocalFileID ( FileID FID) const inline

isLocalSourceLocation()

isMacroArgExpansion()

Tests whether the given source location represents a macro argument's expansion into the function-like macro definition.

Parameters

StartLoc If non-null and function returns true, it is set to the start location of the macro argument expansion.

Such source locations only appear inside of the expansion locations representing where a particular function-like macro was expanded.

Definition at line 1026 of file SourceManager.cpp.

References clang::SrcMgr::SLocEntry::getExpansion(), clang::SrcMgr::ExpansionInfo::getExpansionLocStart(), getFileID(), getSLocEntry(), clang::SrcMgr::ExpansionInfo::isMacroArgExpansion(), clang::SourceLocation::isMacroID(), and Loc.

Referenced by clang::edit::EditedSource::canInsertInOffset(), getImmediateMacroCallerLoc(), getTopMacroCallerLoc(), clang::FullSourceLoc::isMacroArgExpansion(), and clang::syntax::TokenBuffer::spelledForExpanded().

isMacroBodyExpansion()

isMainFile()

isPointWithin()

isWrittenInBuiltinFile()

isWrittenInCommandLineFile()

isWrittenInMainFile()

isWrittenInSameFile()

Returns true if the spelling locations for both SourceLocations are part of the same file buffer.

This check ignores line marker directives.

Definition at line 1493 of file SourceManager.h.

References getFileID().

isWrittenInScratchSpace()

loaded_sloc_entry_size()

unsigned clang::SourceManager::loaded_sloc_entry_size ( ) const inline

local_sloc_entry_size()

unsigned clang::SourceManager::local_sloc_entry_size ( ) const inline

noteSLocAddressSpaceUsage()

operator=()

overrideFileContents() [1/3]

overrideFileContents() [2/3]

void clang::SourceManager::overrideFileContents ( FileEntryRef SourceFile, const llvm::MemoryBufferRef & Buffer ) inline

overrideFileContents() [3/3]

void SourceManager::overrideFileContents ( FileEntryRef SourceFile,
std::unique_ptr< llvm::MemoryBuffer > Buffer
)

PrintStats()

void SourceManager::PrintStats ( ) const

pushModuleBuildStack()

void clang::SourceManager::pushModuleBuildStack ( StringRef moduleName, FullSourceLoc importLoc ) inline

setAllFilesAreTransient()

void clang::SourceManager::setAllFilesAreTransient ( bool Transient) inline

setExternalSLocEntrySource()

setFileIsTransient()

void SourceManager::setFileIsTransient ( FileEntryRef SourceFile )

setMainFileID()

void clang::SourceManager::setMainFileID ( FileID FID) inline

setModuleBuildStack()

setNumCreatedFIDsForFileID()

setOverridenFilesKeepOriginalName()

void clang::SourceManager::setOverridenFilesKeepOriginalName ( bool value) inline

setPreambleFileID()

void clang::SourceManager::setPreambleFileID ( FileID Preamble) inline

translateFile() [1/2]

translateFile() [2/2]

translateFileLineCol()

translateLineCol()

Get the source location in FID for the given line:col.

Get the source location in.

Returns null location if FID is not a file SLocEntry.

Definition at line 1664 of file SourceManager.cpp.

References Diag(), clang::SrcMgr::LineOffsetMapping::get(), clang::SrcMgr::ContentCache::getBufferOrNone(), clang::SrcMgr::FileInfo::getContentCache(), clang::SrcMgr::SLocEntry::getFile(), clang::SourceLocation::getLocWithOffset(), clang::SrcMgr::SLocEntry::getOffset(), clang::Invalid, clang::SrcMgr::SLocEntry::isFile(), clang::FileID::isInvalid(), clang::Line, clang::SrcMgr::LineOffsetMapping::size(), and clang::SrcMgr::ContentCache::SourceLineCache.

userFilesAreVolatile()

bool clang::SourceManager::userFilesAreVolatile ( ) const inline

True if non-system source files should be treated as volatile (likely to change while trying to use them).

Definition at line 865 of file SourceManager.h.

ASTReader

ASTWriter


The documentation for this class was generated from the following files: