14#ifndef LLVM_CLANG_BASIC_DIAGNOSTIC_H
15#define LLVM_CLANG_BASIC_DIAGNOSTIC_H
22#include "llvm/ADT/ArrayRef.h"
23#include "llvm/ADT/DenseMap.h"
24#include "llvm/ADT/FunctionExtras.h"
25#include "llvm/ADT/IntrusiveRefCntPtr.h"
26#include "llvm/ADT/SmallString.h"
27#include "llvm/ADT/SmallVector.h"
28#include "llvm/ADT/StringExtras.h"
29#include "llvm/ADT/iterator_range.h"
30#include "llvm/Support/Compiler.h"
58class DiagnosticConsumer;
63class StoredDiagnostic;
195 static const unsigned NumCached = 16;
198 unsigned NumFreeListEntries;
206 if (NumFreeListEntries == 0)
211 Result->DiagRanges.clear();
212 Result->FixItHints.clear();
218 if (S >= Cached && S <= Cached + NumCached) {
219 FreeList[NumFreeListEntries++] = S;
306 unsigned char AllExtensionsSilenced = 0;
309 bool FatalsAsError =
false;
312 bool SuppressAllDiagnostics =
false;
317 bool ForceSystemWarnings =
false;
320 bool ElideType =
true;
323 bool PrintTemplateTree =
false;
326 bool ShowColors =
false;
336 unsigned NumOverloadsToShow = 32;
339 unsigned ErrorLimit = 0;
342 unsigned TemplateBacktraceLimit = 0;
345 unsigned ConstexprBacktraceLimit = 0;
350 std::unique_ptr<DiagnosticConsumer> Owner;
365 llvm::DenseMap<unsigned, DiagnosticMapping> DiagMap;
371 LLVM_PREFERRED_TYPE(
bool)
372 unsigned IgnoreAllWarnings : 1;
375 LLVM_PREFERRED_TYPE(
bool)
376 unsigned EnableAllWarnings : 1;
379 LLVM_PREFERRED_TYPE(
bool)
380 unsigned WarningsAsErrors : 1;
383 LLVM_PREFERRED_TYPE(
bool)
384 unsigned ErrorsAsFatal : 1;
387 LLVM_PREFERRED_TYPE(
bool)
388 unsigned SuppressSystemWarnings : 1;
396 : IgnoreAllWarnings(
false), EnableAllWarnings(
false),
397 WarningsAsErrors(
false), ErrorsAsFatal(
false),
398 SuppressSystemWarnings(
false), DiagIDs(DiagIDs) {}
400 using iterator = llvm::DenseMap<unsigned, DiagnosticMapping>::iterator;
402 llvm::DenseMap<unsigned, DiagnosticMapping>::const_iterator;
405 DiagMap[
Diag] = Info;
409 return DiagMap.lookup(
Diag);
419 std::list<DiagState> DiagStates;
426 void appendFirst(DiagState *State);
435 bool empty()
const {
return Files.empty(); }
438 void clear(
bool Soft) {
442 FirstDiagState = CurDiagState =
nullptr;
443 CurDiagStateLoc = SourceLocation();
448 LLVM_DUMP_METHOD
void dump(SourceManager &SrcMgr,
449 StringRef DiagName = StringRef())
const;
452 DiagState *getCurDiagState()
const {
return CurDiagState; }
455 SourceLocation getCurDiagStateLoc()
const {
return CurDiagStateLoc; }
458 friend class ASTReader;
459 friend class ASTWriter;
466 struct DiagStatePoint {
470 DiagStatePoint(DiagState *State,
unsigned Offset)
471 : State(State), Offset(Offset) {}
480 File *Parent =
nullptr;
483 unsigned ParentOffset = 0;
487 bool HasLocalTransitions =
false;
491 llvm::SmallVector<DiagStatePoint, 4> StateTransitions;
493 DiagState *lookup(
unsigned Offset)
const;
497 mutable std::map<FileID, File> Files;
500 DiagState *FirstDiagState;
503 DiagState *CurDiagState;
506 SourceLocation CurDiagStateLoc;
509 File *getFile(SourceManager &SrcMgr, FileID ID)
const;
512 DiagStateMap DiagStatesByLoc;
516 std::vector<DiagState *> DiagStateOnPushStack;
518 DiagState *GetCurDiagState()
const {
519 return DiagStatesByLoc.getCurDiagState();
522 void PushDiagStatePoint(DiagState *State, SourceLocation L);
526 DiagState *GetDiagStateForLoc(SourceLocation Loc)
const {
527 return SourceMgr ? DiagStatesByLoc.lookup(*SourceMgr, Loc)
528 : DiagStatesByLoc.getCurDiagState();
536 bool UncompilableErrorOccurred;
539 bool FatalErrorOccurred;
542 bool UnrecoverableErrorOccurred;
546 unsigned TrapNumErrorsOccurred;
547 unsigned TrapNumUnrecoverableErrorsOccurred;
556 unsigned NumWarnings;
572 StringRef Modifier, StringRef Argument,
573 ArrayRef<ArgumentValue> PrevArgs,
574 SmallVectorImpl<char> &Output,
void *Cookie,
575 ArrayRef<intptr_t> QualTypeVals);
577 void *ArgToStringCookie =
nullptr;
578 ArgToStringFnTy ArgToStringFn;
582 const SourceManager &)
const>
583 DiagSuppressionMapping;
587 DiagnosticOptions &DiagOpts,
588 DiagnosticConsumer *client =
nullptr,
589 bool ShouldOwnClient =
true);
595 LLVM_DUMP_METHOD
void dump()
const;
596 LLVM_DUMP_METHOD
void dump(StringRef DiagName)
const;
609 const DiagState &DS = *GetCurDiagState();
621 std::unique_ptr<DiagnosticConsumer>
takeClient() {
return std::move(Owner); }
626 assert(SourceMgr &&
"SourceManager not set!");
631 assert(DiagStatesByLoc.empty() &&
632 "Leftover diag state from a different SourceManager.");
667 TemplateBacktraceLimit = Limit;
677 ConstexprBacktraceLimit = Limit;
683 return ConstexprBacktraceLimit;
690 GetCurDiagState()->IgnoreAllWarnings = Val;
693 return GetCurDiagState()->IgnoreAllWarnings;
701 GetCurDiagState()->EnableAllWarnings = Val;
704 return GetCurDiagState()->EnableAllWarnings;
709 GetCurDiagState()->WarningsAsErrors = Val;
712 return GetCurDiagState()->WarningsAsErrors;
727 GetCurDiagState()->SuppressSystemWarnings = Val;
730 return GetCurDiagState()->SuppressSystemWarnings;
777 return std::numeric_limits<int>::max();
779 return NumOverloadsToShow;
781 llvm_unreachable(
"invalid OverloadsShown kind");
791 NumOverloadsToShow = 4;
802 if (LastDiagLevel ==
Fatal)
803 FatalErrorOccurred =
true;
817 GetCurDiagState()->ExtBehavior = H;
820 return GetCurDiagState()->ExtBehavior;
886 return UncompilableErrorOccurred;
892 return FatalErrorOccurred || UnrecoverableErrorOccurred;
908 template <
unsigned N>
916 StringRef(FormatString, N - 1));
925 ArgToStringFn(Kind, Val, Modifier, Argument, PrevArgs, Output,
926 ArgToStringCookie, QualTypeVals);
931 ArgToStringCookie = Cookie;
937 LastDiagLevel =
Other.LastDiagLevel;
942 void Reset(
bool soft =
false);
961 return Diags->getDiagnosticSeverity(DiagID, Loc, *
this) ==
976 return (
Level)Diags->getDiagnosticLevel(DiagID, Loc, *
this);
1089 unsigned NumUnrecoverableErrors;
1099 return Diag.TrapNumErrorsOccurred > NumErrors;
1105 return Diag.TrapNumUnrecoverableErrorsOccurred > NumUnrecoverableErrors;
1110 NumErrors = Diag.TrapNumErrorsOccurred;
1111 NumUnrecoverableErrors = Diag.TrapNumUnrecoverableErrorsOccurred;
1171 "Too many arguments to diagnostic!");
1181 "Too many arguments to diagnostic!");
1211 operator bool()
const {
return true; }
1258 mutable std::string FlagValue;
1265 mutable bool IsActive =
false;
1269 mutable bool IsForceEmit =
false;
1271 DiagnosticBuilder() =
default;
1284 IsForceEmit =
false;
1304 bool Result = DiagObj->EmitDiagnostic(*
this, IsForceEmit);
1317 template <
typename T>
const DiagnosticBuilder &
operator<<(
const T &
V)
const {
1318 assert(
isActive() &&
"Clients must not add to cleared diagnostic!");
1327 template <
typename T,
1328 typename = std::enable_if_t<!std::is_lvalue_reference<T>::value>>
1330 assert(
isActive() &&
"Clients must not add to cleared diagnostic!");
1336 DiagnosticBuilder &
operator=(
const DiagnosticBuilder &) =
delete;
1373 const llvm::Twine &S) {
1379 std::string_view S) {
1385 const std::string &S) {
1393 DB.
AddString(llvm::StringRef(S.data(), S.size()));
1405 const llvm::APSInt &Int) {
1413 const llvm::APInt &Int) {
1440template <
typename T>
1441inline std::enable_if_t<std::is_same<T, bool>::value,
1442 const StreamingDiagnostic &>
1443operator<<(
const StreamingDiagnostic &DB, T I) {
1461 unsigned long long I) {
1483template <
typename T>
1484inline std::enable_if_t<
1485 std::is_same<std::remove_const_t<T>, DeclContext>::value,
1486 const StreamingDiagnostic &>
1487operator<<(
const StreamingDiagnostic &DB, T *DC) {
1499template <
typename T,
typename U,
1500 typename UnderlyingU =
typename std::enable_if_t<
1501 std::is_enum_v<std::remove_reference_t<U>>,
1502 std::underlying_type<std::remove_reference_t<U>>>
::type>
1503inline std::enable_if_t<
1505 !std::is_convertible_v<U, UnderlyingU>,
1508 DB << llvm::to_underlying(SE);
1552 const std::optional<SourceRange> &Opt) {
1560 const std::optional<CharSourceRange> &Opt) {
1603 std::string FlagValue;
1605 std::optional<StringRef> StoredDiagMessage;
1611 StringRef StoredDiagMessage);
1614 unsigned getID()
const {
return DiagID; }
1618 return DiagObj->getSourceManager();
1630 assert(Idx <
getNumArgs() &&
"Argument index out of range!");
1638 "invalid argument accessor!");
1639 return DiagStorage.DiagArgumentsStr[Idx];
1646 "invalid argument accessor!");
1647 return reinterpret_cast<const char *
>(DiagStorage.DiagArgumentsVal[Idx]);
1654 "invalid argument accessor!");
1655 return (int64_t)DiagStorage.DiagArgumentsVal[Idx];
1662 "invalid argument accessor!");
1663 return DiagStorage.DiagArgumentsVal[Idx];
1670 "invalid argument accessor!");
1672 DiagStorage.DiagArgumentsVal[Idx]);
1679 "invalid argument accessor!");
1680 return DiagStorage.DiagArgumentsVal[Idx];
1688 assert(Idx <
getNumRanges() &&
"Invalid diagnostic range index!");
1689 return DiagStorage.DiagRanges[Idx];
1699 return DiagStorage.FixItHints[Idx];
1727 std::string Message;
1728 std::vector<CharSourceRange> Ranges;
1729 std::vector<FixItHint> FixIts;
1742 explicit operator bool()
const {
return !Message.empty(); }
1769llvm::raw_ostream &
operator<<(llvm::raw_ostream &OS,
const StoredDiagnostic &);
1826 virtual void anchor();
1846 void clear()
override;
1855 LLVM_PREFERRED_TYPE(
bool)
1857 LLVM_PREFERRED_TYPE(
bool)
1859 LLVM_PREFERRED_TYPE(
bool)
1861 LLVM_PREFERRED_TYPE(
bool)
1865 LLVM_PREFERRED_TYPE(
bool)
1877 llvm::
vfs::FileSystem &VFS,
bool ReportDiags =
true);
Defines the Diagnostic IDs-related interfaces.
static DiagnosticBuilder Diag(DiagnosticsEngine *Diags, const LangOptions &Features, FullSourceLoc TokLoc, const char *TokBegin, const char *TokRangeBegin, const char *TokRangeEnd, unsigned DiagID)
Produce a diagnostic highlighting some portion of a literal.
static std::string toString(const clang::SanitizerSet &Sanitizers)
Produce a string containing comma-separated names of sanitizers in Sanitizers set.
Defines the clang::SourceLocation class and associated facilities.
Defines various enumerations that describe declaration and type specifiers.
Defines clang::UnsignedOrNone.
Class to make it convenient to initialize TrapReason objects which can be used to attach the "trap re...
Represents a byte-granular source range.
static CharSourceRange getCharRange(SourceRange R)
static CharSourceRange getTokenRange(SourceRange R)
An allocator for DiagnosticStorage objects, which uses a small cache to objects, used to reduce mallo...
void Deallocate(DiagnosticStorage *S)
Free the given storage object.
DiagnosticStorage * Allocate()
Allocate new storage.
A little helper class used to produce diagnostics.
DiagnosticBuilder & operator=(const DiagnosticBuilder &)=delete
const DiagnosticBuilder & setForceEmit() const
Forces the diagnostic to be emitted.
void Clear() const
Clear out the current diagnostic.
void addFlagValue(StringRef V) const
bool isActive() const
Determine whether this diagnostic is still active.
friend class PartialDiagnostic
const DiagnosticBuilder & operator<<(const T &V) const
DiagnosticsEngine * getDiagnosticsEngine() const
friend class DiagnosticsEngine
bool Emit()
Force the diagnostic builder to emit the diagnostic now.
~DiagnosticBuilder()
Emits the diagnostic.
const DiagnosticBuilder & operator<<(T &&V) const
unsigned getDiagID() const
Abstract interface, implemented by clients of the front-end, which formats and prints fully processed...
virtual ~DiagnosticConsumer()
virtual void EndSourceFile()
Callback to inform the diagnostic client that processing of a source file has ended.
virtual void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel, const Diagnostic &Info)
Handle this diagnostic, reporting it to the user or capturing it to a log as needed.
unsigned getNumErrors() const
unsigned NumErrors
Number of errors reported.
unsigned getNumWarnings() const
unsigned NumWarnings
Number of warnings reported.
virtual bool IncludeInDiagnosticCounts() const
Indicates whether the diagnostics handled by this DiagnosticConsumer should be included in the number...
virtual void BeginSourceFile(const LangOptions &LangOpts, const Preprocessor *PP=nullptr)
Callback to inform the diagnostic client that processing of a source file is beginning.
DiagnosticConsumer()=default
void reset()
Set to initial state of "no errors occurred".
bool hasUnrecoverableErrorOccurred() const
Determine whether any unrecoverable errors have occurred since this object instance was created.
DiagnosticErrorTrap(DiagnosticsEngine &Diag)
bool hasErrorOccurred() const
Determine whether any errors have occurred since this object instance was created.
Level
The level of the diagnostic, after it has been through mapping.
void setNoWarningAsError(bool Value)
static DiagnosticMapping Make(diag::Severity Severity, bool IsUser, bool IsPragma)
void setNoErrorAsFatal(bool Value)
Options for controlling the compiler diagnostics engine.
A little helper class (which is basically a smart pointer that forwards info from DiagnosticsEngine a...
Diagnostic(const DiagnosticsEngine *DO, const DiagnosticBuilder &DiagBuilder)
const SourceLocation & getLocation() const
const std::string & getArgStdStr(unsigned Idx) const
Return the provided argument string specified by Idx.
void FormatDiagnostic(SmallVectorImpl< char > &OutStr) const
Format this diagnostic into a string, substituting the formal arguments into the %0 slots.
uint64_t getRawArg(unsigned Idx) const
Return the specified non-string argument in an opaque form.
unsigned getNumFixItHints() const
StringRef getFlagValue() const
Return the value associated with this diagnostic flag.
unsigned getNumRanges() const
Return the number of source ranges associated with this diagnostic.
const char * getArgCStr(unsigned Idx) const
Return the specified C string argument.
const IdentifierInfo * getArgIdentifier(unsigned Idx) const
Return the specified IdentifierInfo argument.
const CharSourceRange & getRange(unsigned Idx) const
SourceManager & getSourceManager() const
ArrayRef< FixItHint > getFixItHints() const
unsigned getNumArgs() const
bool hasSourceManager() const
DiagnosticsEngine::ArgumentKind getArgKind(unsigned Idx) const
Return the kind of the specified index.
int64_t getArgSInt(unsigned Idx) const
Return the specified signed integer argument.
uint64_t getArgUInt(unsigned Idx) const
Return the specified unsigned integer argument.
const FixItHint & getFixItHint(unsigned Idx) const
ArrayRef< CharSourceRange > getRanges() const
Return an array reference for this diagnostic's ranges.
const DiagnosticsEngine * getDiags() const
Concrete class used by the front-end to report problems and issues.
void setErrorsAsFatal(bool Val)
When set to true, any error reported is made a fatal error.
DiagnosticBuilder Report(SourceLocation Loc, unsigned DiagID)
Issue the message to the client.
void SetArgToStringFn(ArgToStringFnTy Fn, void *Cookie)
bool hasSourceManager() const
bool EmitDiagnostic(const DiagnosticBuilder &DB, bool Force=false)
Emit the diagnostic.
unsigned getCustomDiagID(Level L, const char(&FormatString)[N])
Return an ID for a diagnostic with the specified format string and level.
void setDiagSuppressionMapping(llvm::MemoryBuffer &Input)
Diagnostic suppression mappings can be used to suppress specific diagnostics in specific files.
bool isLastDiagnosticIgnored() const
Determine whether the previous diagnostic was ignored.
DiagnosticsEngine(IntrusiveRefCntPtr< DiagnosticIDs > Diags, DiagnosticOptions &DiagOpts, DiagnosticConsumer *client=nullptr, bool ShouldOwnClient=true)
bool hasErrorOccurred() const
void overloadCandidatesShown(unsigned N)
Call this after showing N overload candidates.
void setPrintTemplateTree(bool Val)
Set tree printing, to outputting the template difference in a tree format.
void setSuppressSystemWarnings(bool Val)
When set to true mask warnings that come from system headers.
void setNumWarnings(unsigned NumWarnings)
bool getErrorsAsFatal() const
DiagnosticsEngine(const DiagnosticsEngine &)=delete
bool isSuppressedViaMapping(diag::kind DiagId, SourceLocation DiagLoc) const
void setSeverityForAll(diag::Flavor Flavor, diag::Severity Map, SourceLocation Loc=SourceLocation())
Add the specified mapping to all diagnostics of the specified flavor.
void setIgnoreAllWarnings(bool Val)
When set to true, any unmapped warnings are ignored.
bool getForceSystemWarnings() const
bool getSuppressAllDiagnostics() const
bool getIgnoreAllWarnings() const
friend class DiagnosticIDs
void setSourceManager(SourceManager *SrcMgr)
void notePriorDiagnosticFrom(const DiagnosticsEngine &Other)
Note that the prior diagnostic was emitted by some other DiagnosticsEngine, and we may be attaching a...
friend void DiagnosticsTestHelper(DiagnosticsEngine &)
friend class DiagnosticErrorTrap
void setExtensionHandlingBehavior(diag::Severity H)
Controls whether otherwise-unmapped extension diagnostics are mapped onto ignore/warning/error.
LLVM_DUMP_METHOD void dump() const
unsigned getNumOverloadCandidatesToShow() const
When a call or operator fails, print out up to this many candidate overloads as suggestions.
DiagnosticOptions & getDiagnosticOptions() const
Retrieve the diagnostic options.
friend class PartialDiagnostic
void setTemplateBacktraceLimit(unsigned Limit)
Specify the maximum number of template instantiation notes to emit along with a given diagnostic.
void DecrementAllExtensionsSilenced()
bool hasUnrecoverableErrorOccurred() const
Determine whether any kind of unrecoverable error has occurred.
void ResetPragmas()
We keep a cache of FileIDs for diagnostics mapped by pragmas.
void setFatalsAsError(bool Val)
When set to true, any fatal error reported is made an error.
diag_mapping_range getDiagnosticMappings() const
Get the current set of diagnostic mappings.
void setErrorLimit(unsigned Limit)
Specify a limit for the number of errors we should emit before giving up.
void setWarningsAsErrors(bool Val)
When set to true, any warnings reported are issued as errors.
bool getEnableAllWarnings() const
bool getPrintTemplateTree()
void setClient(DiagnosticConsumer *client, bool ShouldOwnClient=true)
Set the diagnostic client associated with this diagnostic object.
void setShowOverloads(OverloadsShown Val)
Specify which overload candidates to show when overload resolution fails.
std::unique_ptr< DiagnosticConsumer > takeClient()
Return the current diagnostic client along with ownership of that client.
llvm::iterator_range< DiagState::const_iterator > diag_mapping_range
void setLastDiagnosticIgnored(bool IsIgnored)
Pretend that the last diagnostic issued was ignored, so any subsequent notes will be suppressed,...
SourceManager & getSourceManager() const
void pushMappings(SourceLocation Loc)
Copies the current DiagMappings and pushes the new copy onto the top of the stack.
const DiagnosticConsumer * getClient() const
void setSeverity(diag::kind Diag, diag::Severity Map, SourceLocation Loc)
This allows the client to specify that certain warnings are ignored.
DiagnosticsEngine & operator=(const DiagnosticsEngine &)=delete
unsigned getConstexprBacktraceLimit() const
Retrieve the maximum number of constexpr evaluation notes to emit along with a given diagnostic.
Level
The level of the diagnostic, after it has been through mapping.
void setEnableAllWarnings(bool Val)
When set to true, any unmapped ignored warnings are no longer ignored.
friend class DiagnosticBuilder
DiagnosticConsumer * getClient()
bool hasFatalErrorOccurred() const
std::pair< ArgumentKind, intptr_t > ArgumentValue
Represents on argument value, which is a union discriminated by ArgumentKind, with a value.
@ ak_nameddecl
NamedDecl *.
@ ak_declcontext
DeclContext *.
@ ak_addrspace
address space
@ ak_identifierinfo
IdentifierInfo.
@ ak_qualtype_pair
pair<QualType, QualType>
@ ak_attr_info
AttributeCommonInfo *.
@ ak_c_string
const char *
@ ak_declarationname
DeclarationName.
@ ak_tokenkind
enum TokenKind : unsigned
@ ak_std_string
std::string
@ ak_nestednamespec
NestedNameSpecifier *.
unsigned getNumErrors() const
bool isIgnored(unsigned DiagID, SourceLocation Loc) const
Determine whether the diagnostic is known to be ignored.
bool hasAllExtensionsSilenced()
Level getDiagnosticLevel(unsigned DiagID, SourceLocation Loc) const
Based on the way the client configured the DiagnosticsEngine object, classify the specified diagnosti...
bool ownsClient() const
Determine whether this DiagnosticsEngine object own its client.
OverloadsShown getShowOverloads() const
void setConstexprBacktraceLimit(unsigned Limit)
Specify the maximum number of constexpr evaluation notes to emit along with a given diagnostic.
bool setDiagnosticGroupErrorAsFatal(StringRef Group, bool Enabled)
Set the error-as-fatal flag for the given diagnostic group.
bool getSuppressSystemWarnings() const
bool getFatalsAsError() const
void setForceSystemWarnings(bool Val)
void setShowColors(bool Val)
Set color printing, so the type diffing will inject color markers into the output.
bool setDiagnosticGroupWarningAsError(StringRef Group, bool Enabled)
Set the warning-as-error flag for the given diagnostic group.
bool getWarningsAsErrors() const
void IncrementAllExtensionsSilenced()
Counter bumped when an extension block is/ encountered.
void ConvertArgToString(ArgumentKind Kind, intptr_t Val, StringRef Modifier, StringRef Argument, ArrayRef< ArgumentValue > PrevArgs, SmallVectorImpl< char > &Output, ArrayRef< intptr_t > QualTypeVals) const
Converts a diagnostic argument (as an intptr_t) into the string that represents it.
diag::Severity getExtensionHandlingBehavior() const
void setSuppressAllDiagnostics(bool Val)
Suppress all diagnostics, to silence the front end when we know that we don't want any more diagnosti...
unsigned getTemplateBacktraceLimit() const
Retrieve the maximum number of template instantiation notes to emit along with a given diagnostic.
bool setSeverityForGroup(diag::Flavor Flavor, StringRef Group, diag::Severity Map, SourceLocation Loc=SourceLocation())
Change an entire diagnostic group (e.g.
bool hasUncompilableErrorOccurred() const
Errors that actually prevent compilation, not those that are upgraded from a warning by -Werror.
void setElideType(bool Val)
Set type eliding, to skip outputting same types occurring in template types.
bool popMappings(SourceLocation Loc)
Pops the current DiagMappings off the top of the stack, causing the new top of the stack to be the ac...
unsigned getNumWarnings() const
const IntrusiveRefCntPtr< DiagnosticIDs > & getDiagnosticIDs() const
Annotates a diagnostic with some code that should be inserted, removed, or replaced to fix the proble...
static FixItHint CreateInsertionFromRange(SourceLocation InsertionLoc, CharSourceRange FromRange, bool BeforePreviousInsertions=false)
Create a code modification hint that inserts the given code from FromRange at a specific location.
static FixItHint CreateRemoval(SourceRange RemoveRange)
FixItHint()=default
Empty code modification hint, indicating that no code modification is known.
bool BeforePreviousInsertions
CharSourceRange RemoveRange
Code that should be replaced to correct the error.
static FixItHint CreateReplacement(CharSourceRange RemoveRange, StringRef Code)
Create a code modification hint that replaces the given source range with the given code string.
static FixItHint CreateRemoval(CharSourceRange RemoveRange)
Create a code modification hint that removes the given source range.
static FixItHint CreateReplacement(SourceRange RemoveRange, StringRef Code)
CharSourceRange InsertFromRange
Code in the specific range that should be inserted in the insertion location.
std::string CodeToInsert
The actual code to insert at the insertion location, as a string.
static FixItHint CreateInsertion(SourceLocation InsertionLoc, StringRef Code, bool BeforePreviousInsertions=false)
Create a code modification hint that inserts the given code string at a specific location.
bool IncludeInDiagnosticCounts() const override
Indicates whether the diagnostics handled by this DiagnosticConsumer should be included in the number...
~ForwardingDiagnosticConsumer() override
void HandleDiagnostic(DiagnosticsEngine::Level DiagLevel, const Diagnostic &Info) override
Handle this diagnostic, reporting it to the user or capturing it to a log as needed.
ForwardingDiagnosticConsumer(DiagnosticConsumer &Target)
A SourceLocation and its associated SourceManager.
One of these records is kept for each identifier that is lexed.
A diagnostic client that ignores all diagnostics.
Keeps track of the various options that can be enabled, which controls the dialect of C or C++ that i...
Engages in a tight little dance with the lexer to efficiently preprocess tokens.
Encodes a location in the source.
bool isValid() const
Return true if this is a valid SourceLocation object.
This class handles loading and caching of source files into memory.
A trivial tuple used to represent a source range.
Represents a diagnostic in a form that can be retained until its corresponding source manager is dest...
void setLocation(FullSourceLoc Loc)
unsigned range_size() const
ArrayRef< FixItHint > getFixIts() const
range_iterator range_begin() const
StoredDiagnostic()=default
ArrayRef< CharSourceRange > getRanges() const
unsigned fixit_size() const
DiagnosticsEngine::Level getLevel() const
fixit_iterator fixit_begin() const
const FullSourceLoc & getLocation() const
std::vector< FixItHint >::const_iterator fixit_iterator
range_iterator range_end() const
std::vector< CharSourceRange >::const_iterator range_iterator
StringRef getMessage() const
fixit_iterator fixit_end() const
The streaming interface shared between DiagnosticBuilder and PartialDiagnostic.
StreamingDiagnostic(StreamingDiagnostic &&Diag)=default
DiagStorageAllocator * Allocator
Allocator used to allocate storage for this diagnostic.
StreamingDiagnostic()=default
clang::DiagStorageAllocator DiagStorageAllocator
StreamingDiagnostic(DiagStorageAllocator &Alloc)
Construct with a storage allocator which will manage the storage.
DiagnosticStorage * DiagStorage
void AddString(StringRef V) const
StreamingDiagnostic(const StreamingDiagnostic &Diag)=default
void AddTaggedVal(uint64_t V, DiagnosticsEngine::ArgumentKind Kind) const
void AddSourceRange(const CharSourceRange &R) const
DiagnosticStorage * getStorage() const
Retrieve storage for this particular diagnostic.
void AddFixItHint(const FixItHint &Hint) const
Public enums and private classes that are part of the SourceManager implementation.
const internal::VariadicAllOfMatcher< Type > type
Matches Types in the clang AST.
Flavor
Flavors of diagnostics we can emit.
unsigned kind
All of the diagnostics that can be emitted by the frontend.
Severity
Enum values that allow the client to map NOTEs, WARNINGs, and EXTENSIONs to either Ignore (nothing),...
@ Ignored
Do not present this diagnostic, ignore it.
TokenKind
Provides a simple uniform namespace for tokens from all C languages.
The JSON file list parser is used to communicate input to InstallAPI.
OverloadsShown
Specifies which overload candidates to display when overload resolution fails.
@ Ovl_All
Show all overloads.
@ Ovl_Best
Show just the "best" overload candidates.
std::pair< NullabilityKind, bool > DiagNullabilityKind
A nullability kind paired with a bit indicating whether it used a context-sensitive keyword.
@ Result
The result type of a method or function.
void EscapeStringForDiagnostic(StringRef Str, SmallVectorImpl< char > &OutStr)
EscapeStringForDiagnostic - Append Str to the diagnostic buffer, escaping non-printable characters an...
void ProcessWarningOptions(DiagnosticsEngine &Diags, const DiagnosticOptions &Opts, llvm::vfs::FileSystem &VFS, bool ReportDiags=true)
ProcessWarningOptions - Initialize the diagnostic client and process the warning options specified on...
const char ToggleHighlight
Special character that the diagnostic printer will use to toggle the bold attribute.
const StreamingDiagnostic & operator<<(const StreamingDiagnostic &DB, const ConceptReference *C)
Insertion operator for diagnostics.
@ Other
Other implicit parameter.
Diagnostic wrappers for TextAPI types for error reporting.
__INTPTR_TYPE__ intptr_t
A signed integer type with the property that any valid pointer to void can be converted to this type,...
AddFlagValue(StringRef V)
unsigned char DiagArgumentsKind[MaxArguments]
Specifies for each argument whether it is in DiagArgumentsStr or in DiagArguments.
SmallVector< CharSourceRange, 8 > DiagRanges
The list of ranges added to this diagnostic.
unsigned char NumDiagArgs
The number of entries in Arguments.
SmallVector< FixItHint, 6 > FixItHints
If valid, provides a hint with some code to insert, remove, or modify at a particular position.
std::string DiagArgumentsStr[MaxArguments]
The values for the various substitution positions that have string arguments.
@ MaxArguments
The maximum number of arguments we can hold.
uint64_t DiagArgumentsVal[MaxArguments]
The values for the various substitution positions.
DiagnosticStorage()=default
unsigned TemplateDiffUsed