clang 20.0.0git
Classes | Public Member Functions | Friends | List of all members
clang::FullSourceLoc Class Reference

A SourceLocation and its associated SourceManager. More...

#include "clang/Basic/SourceLocation.h"

Inheritance diagram for clang::FullSourceLoc:
Inheritance graph
[legend]

Classes

struct  BeforeThanCompare
 Comparison function class, useful for sorting FullSourceLocs. More...
 

Public Member Functions

 FullSourceLoc ()=default
 Creates a FullSourceLoc where isValid() returns false.
 
 FullSourceLoc (SourceLocation Loc, const SourceManager &SM)
 
bool hasManager () const
 Checks whether the SourceManager is present.
 
const SourceManagergetManager () const
 
FileID getFileID () const
 
FullSourceLoc getExpansionLoc () const
 
FullSourceLoc getSpellingLoc () const
 
FullSourceLoc getFileLoc () const
 
PresumedLoc getPresumedLoc (bool UseLineDirectives=true) const
 
bool isMacroArgExpansion (FullSourceLoc *StartLoc=nullptr) const
 
FullSourceLoc getImmediateMacroCallerLoc () const
 
std::pair< FullSourceLoc, StringRef > getModuleImportLoc () const
 
unsigned getFileOffset () const
 
unsigned getExpansionLineNumber (bool *Invalid=nullptr) const
 
unsigned getExpansionColumnNumber (bool *Invalid=nullptr) const
 
std::pair< FileID, unsignedgetDecomposedExpansionLoc () const
 Decompose the underlying SourceLocation into a raw (FileID + Offset) pair, after walking through all expansion records.
 
unsigned getSpellingLineNumber (bool *Invalid=nullptr) const
 
unsigned getSpellingColumnNumber (bool *Invalid=nullptr) const
 
const char * getCharacterData (bool *Invalid=nullptr) const
 
unsigned getLineNumber (bool *Invalid=nullptr) const
 
unsigned getColumnNumber (bool *Invalid=nullptr) const
 
const FileEntrygetFileEntry () const
 
OptionalFileEntryRef getFileEntryRef () const
 
StringRef getBufferData (bool *Invalid=nullptr) const
 Return a StringRef to the source buffer data for the specified FileID.
 
std::pair< FileID, unsignedgetDecomposedLoc () const
 Decompose the specified location into a raw FileID + Offset pair.
 
bool isInSystemHeader () const
 
bool isBeforeInTranslationUnitThan (SourceLocation Loc) const
 Determines the order of 2 source locations in the translation unit.
 
bool isBeforeInTranslationUnitThan (FullSourceLoc Loc) const
 Determines the order of 2 source locations in the translation unit.
 
void dump () const
 Prints information about this FullSourceLoc to stderr.
 
- Public Member Functions inherited from clang::SourceLocation
bool isFileID () const
 
bool isMacroID () const
 
bool isValid () const
 Return true if this is a valid SourceLocation object.
 
bool isInvalid () const
 
SourceLocation getLocWithOffset (IntTy Offset) const
 Return a source location with the specified offset from this SourceLocation.
 
UIntTy getRawEncoding () const
 When a SourceLocation itself cannot be used, this returns an (opaque) 32-bit integer encoding for it.
 
void * getPtrEncoding () const
 When a SourceLocation itself cannot be used, this returns an (opaque) pointer encoding for it.
 
unsigned getHashValue () const
 
void print (raw_ostream &OS, const SourceManager &SM) const
 
std::string printToString (const SourceManager &SM) const
 
void dump (const SourceManager &SM) const
 

Friends

bool operator== (const FullSourceLoc &LHS, const FullSourceLoc &RHS)
 
bool operator!= (const FullSourceLoc &LHS, const FullSourceLoc &RHS)
 

Additional Inherited Members

- Public Types inherited from clang::SourceLocation
using UIntTy = uint32_t
 
using IntTy = int32_t
 
- Static Public Member Functions inherited from clang::SourceLocation
static SourceLocation getFromRawEncoding (UIntTy Encoding)
 Turn a raw encoding of a SourceLocation object into a real SourceLocation.
 
static SourceLocation getFromPtrEncoding (const void *Encoding)
 Turn a pointer encoding of a SourceLocation object back into a real SourceLocation.
 
static bool isPairOfFileLocations (SourceLocation Start, SourceLocation End)
 

Detailed Description

A SourceLocation and its associated SourceManager.

This is useful for argument passing to functions that expect both objects.

This class does not guarantee the presence of either the SourceManager or a valid SourceLocation. Clients should use isValid() and hasManager() before calling the member functions.

Definition at line 369 of file SourceLocation.h.

Constructor & Destructor Documentation

◆ FullSourceLoc() [1/2]

clang::FullSourceLoc::FullSourceLoc ( )
default

◆ FullSourceLoc() [2/2]

clang::FullSourceLoc::FullSourceLoc ( SourceLocation  Loc,
const SourceManager SM 
)
inlineexplicit

Definition at line 376 of file SourceLocation.h.

Member Function Documentation

◆ dump()

LLVM_DUMP_METHOD void FullSourceLoc::dump ( ) const

Prints information about this FullSourceLoc to stderr.

This is useful for debugging.

Definition at line 265 of file SourceLocation.cpp.

References clang::SourceLocation::dump().

◆ getBufferData()

StringRef FullSourceLoc::getBufferData ( bool Invalid = nullptr) const

Return a StringRef to the source buffer data for the specified FileID.

Definition at line 274 of file SourceLocation.cpp.

References clang::SourceManager::getBufferData(), clang::SourceManager::getFileID(), clang::Invalid, and clang::SourceLocation::isValid().

Referenced by EmitAlphaCounter().

◆ getCharacterData()

const char * FullSourceLoc::getCharacterData ( bool Invalid = nullptr) const

◆ getColumnNumber()

unsigned FullSourceLoc::getColumnNumber ( bool Invalid = nullptr) const

◆ getDecomposedExpansionLoc()

std::pair< FileID, unsigned > FullSourceLoc::getDecomposedExpansionLoc ( ) const

Decompose the underlying SourceLocation into a raw (FileID + Offset) pair, after walking through all expansion records.

See also
SourceManager::getDecomposedExpansionLoc

Definition at line 169 of file SourceLocation.cpp.

References clang::SourceManager::getDecomposedExpansionLoc().

◆ getDecomposedLoc()

std::pair< FileID, unsigned > FullSourceLoc::getDecomposedLoc ( ) const

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 279 of file SourceLocation.cpp.

References clang::SourceManager::getDecomposedLoc().

Referenced by clang::tooling::AtomicChange::AtomicChange(), compareCrossTUSourceLocs(), and EmitAlphaCounter().

◆ getExpansionColumnNumber()

unsigned FullSourceLoc::getExpansionColumnNumber ( bool Invalid = nullptr) const

◆ getExpansionLineNumber()

unsigned FullSourceLoc::getExpansionLineNumber ( bool Invalid = nullptr) const

◆ getExpansionLoc()

FullSourceLoc FullSourceLoc::getExpansionLoc ( ) const

◆ getFileEntry()

const FileEntry * FullSourceLoc::getFileEntry ( ) const

◆ getFileEntryRef()

OptionalFileEntryRef FullSourceLoc::getFileEntryRef ( ) const

◆ getFileID()

FileID FullSourceLoc::getFileID ( ) const

◆ getFileLoc()

FullSourceLoc FullSourceLoc::getFileLoc ( ) const

◆ getFileOffset()

unsigned FullSourceLoc::getFileOffset ( ) const

◆ getImmediateMacroCallerLoc()

FullSourceLoc FullSourceLoc::getImmediateMacroCallerLoc ( ) const

◆ getLineNumber()

unsigned FullSourceLoc::getLineNumber ( bool Invalid = nullptr) const

◆ getManager()

const SourceManager & clang::FullSourceLoc::getManager ( ) const
inline

◆ getModuleImportLoc()

std::pair< FullSourceLoc, StringRef > FullSourceLoc::getModuleImportLoc ( ) const

◆ getPresumedLoc()

PresumedLoc FullSourceLoc::getPresumedLoc ( bool  UseLineDirectives = true) const

◆ getSpellingColumnNumber()

unsigned FullSourceLoc::getSpellingColumnNumber ( bool Invalid = nullptr) const

◆ getSpellingLineNumber()

unsigned FullSourceLoc::getSpellingLineNumber ( bool Invalid = nullptr) const

◆ getSpellingLoc()

FullSourceLoc FullSourceLoc::getSpellingLoc ( ) const

◆ hasManager()

bool clang::FullSourceLoc::hasManager ( ) const
inline

Checks whether the SourceManager is present.

Definition at line 380 of file SourceLocation.h.

Referenced by clang::operator<<().

◆ isBeforeInTranslationUnitThan() [1/2]

bool clang::FullSourceLoc::isBeforeInTranslationUnitThan ( FullSourceLoc  Loc) const
inline

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

Returns
true if this source location comes before 'Loc', false otherwise.

Definition at line 439 of file SourceLocation.h.

References isBeforeInTranslationUnitThan(), and Loc.

◆ isBeforeInTranslationUnitThan() [2/2]

bool FullSourceLoc::isBeforeInTranslationUnitThan ( SourceLocation  Loc) const

◆ isInSystemHeader()

bool FullSourceLoc::isInSystemHeader ( ) const

◆ isMacroArgExpansion()

bool FullSourceLoc::isMacroArgExpansion ( FullSourceLoc StartLoc = nullptr) const

Friends And Related Function Documentation

◆ operator!=

bool operator!= ( const FullSourceLoc LHS,
const FullSourceLoc RHS 
)
friend

Definition at line 464 of file SourceLocation.h.

◆ operator==

bool operator== ( const FullSourceLoc LHS,
const FullSourceLoc RHS 
)
friend

Definition at line 458 of file SourceLocation.h.


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