clang 20.0.0git
|
Used for handling and querying diagnostic IDs. More...
#include "clang/Basic/DiagnosticIDs.h"
Public Types | |
enum | Level { Ignored , Note , Remark , Warning , Error , Fatal } |
The level of the diagnostic, after it has been through mapping. More... | |
enum | SFINAEResponse { SFINAE_SubstitutionFailure , SFINAE_Suppress , SFINAE_Report , SFINAE_AccessControl } |
Enumeration describing how the emission of a diagnostic should be treated when it occurs during C++ template argument deduction. More... | |
Public Member Functions | |
DiagnosticIDs () | |
~DiagnosticIDs () | |
unsigned | getCustomDiagID (Level L, StringRef FormatString) |
Return an ID for a diagnostic with the specified format string and level. | |
StringRef | getDescription (unsigned DiagID) const |
Given a diagnostic ID, return a description of the issue. | |
bool | getDiagnosticsInGroup (diag::Flavor Flavor, StringRef Group, SmallVectorImpl< diag::kind > &Diags) const |
Get the set of all diagnostic IDs in the group with the given name. | |
Static Public Member Functions | |
static bool | isBuiltinWarningOrExtension (unsigned DiagID) |
Return true if the unmapped diagnostic levelof the specified diagnostic ID is a Warning or Extension. | |
static bool | isDefaultMappingAsError (unsigned DiagID) |
Return true if the specified diagnostic is mapped to errors by default. | |
static DiagnosticMapping | getDefaultMapping (unsigned DiagID) |
Get the default mapping for this diagnostic. | |
static bool | isBuiltinNote (unsigned DiagID) |
Determine whether the given built-in diagnostic ID is a Note. | |
static bool | isBuiltinExtensionDiag (unsigned DiagID) |
Determine whether the given built-in diagnostic ID is for an extension of some sort. | |
static bool | isBuiltinExtensionDiag (unsigned DiagID, bool &EnabledByDefault) |
Determine whether the given built-in diagnostic ID is for an extension of some sort, and whether it is enabled by default. | |
static StringRef | getWarningOptionForGroup (diag::Group) |
Given a group ID, returns the flag that toggles the group. | |
static StringRef | getWarningOptionDocumentation (diag::Group GroupID) |
Given a diagnostic group ID, return its documentation. | |
static std::optional< diag::Group > | getGroupForWarningOption (StringRef) |
Given a group ID, returns the flag that toggles the group. | |
static std::optional< diag::Group > | getGroupForDiag (unsigned DiagID) |
Return the lowest-level group that contains the specified diagnostic. | |
static StringRef | getWarningOptionForDiag (unsigned DiagID) |
Return the lowest-level warning option that enables the specified diagnostic. | |
static unsigned | getCategoryNumberForDiag (unsigned DiagID) |
Return the category number that a specified DiagID belongs to, or 0 if no category. | |
static unsigned | getNumberOfCategories () |
Return the number of diagnostic categories. | |
static StringRef | getCategoryNameFromID (unsigned CategoryID) |
Given a category ID, return the name of the category. | |
static bool | isARCDiagnostic (unsigned DiagID) |
Return true if a given diagnostic falls into an ARC diagnostic category. | |
static bool | isCodegenABICheckDiagnostic (unsigned DiagID) |
Return true if a given diagnostic is a codegen-time ABI check. | |
static SFINAEResponse | getDiagnosticSFINAEResponse (unsigned DiagID) |
Determines whether the given built-in diagnostic ID is for an error that is suppressed if it occurs during C++ template argument deduction. | |
static bool | isDeferrable (unsigned DiagID) |
Whether the diagnostic message can be deferred. | |
static std::vector< std::string > | getDiagnosticFlags () |
Get the string of all diagnostic flags. | |
static void | getAllDiagnostics (diag::Flavor Flavor, std::vector< diag::kind > &Diags) |
Get the set of all diagnostic IDs. | |
static StringRef | getNearestOption (diag::Flavor Flavor, StringRef Group) |
Get the diagnostic option with the closest edit distance to the given group name. | |
Friends | |
class | DiagnosticsEngine |
Used for handling and querying diagnostic IDs.
Can be used and shared by multiple Diagnostics for multiple translation units.
Definition at line 181 of file DiagnosticIDs.h.
The level of the diagnostic, after it has been through mapping.
Enumerator | |
---|---|
Ignored | |
Note | |
Remark | |
Warning | |
Error | |
Fatal |
Definition at line 184 of file DiagnosticIDs.h.
Enumeration describing how the emission of a diagnostic should be treated when it occurs during C++ template argument deduction.
Definition at line 288 of file DiagnosticIDs.h.
DiagnosticIDs::DiagnosticIDs | ( | ) |
Definition at line 406 of file DiagnosticIDs.cpp.
DiagnosticIDs::~DiagnosticIDs | ( | ) |
Definition at line 408 of file DiagnosticIDs.cpp.
|
static |
Get the set of all diagnostic IDs.
Definition at line 721 of file DiagnosticIDs.cpp.
References StaticDiagInfoSize.
Referenced by clang::DiagnosticsEngine::setSeverityForAll().
|
static |
Given a category ID, return the name of the category.
getCategoryNameFromID - Given a category ID, return the name of the category, an empty string if CategoryID is zero, or null if CategoryID is invalid.
Definition at line 326 of file DiagnosticIDs.cpp.
References CategoryNameTable, and getNumberOfCategories().
Referenced by isARCDiagnostic(), isCodegenABICheckDiagnostic(), PrintDiagnosticCategories(), printDiagnosticOptions(), and clang::arcmt::writeARCDiagsToPlist().
Return the category number that a specified DiagID
belongs to, or 0 if no category.
getCategoryNumberForDiag - Return the category number that a specified DiagID belongs to, or 0 if no category.
Definition at line 292 of file DiagnosticIDs.cpp.
References GetDiagInfo().
Referenced by isARCDiagnostic(), isCodegenABICheckDiagnostic(), printDiagnosticOptions(), and clang::arcmt::writeARCDiagsToPlist().
Return an ID for a diagnostic with the specified format string and level.
getCustomDiagID - Return an ID for a diagnostic with the specified message and level.
If this is the first request for this diagnostic, it is registered and created, otherwise the existing ID is returned.
If this is the first request for this diagnostic, it is registered and created, otherwise the existing ID is returned.
FormatString | A fixed diagnostic format string that will be hashed and mapped to a unique DiagID. |
Definition at line 416 of file DiagnosticIDs.cpp.
|
static |
Get the default mapping for this diagnostic.
Definition at line 273 of file DiagnosticIDs.cpp.
References clang::diag::Fatal, GetDiagInfo(), clang::DiagnosticMapping::getSeverity(), clang::DiagnosticMapping::Make(), clang::DiagnosticMapping::setNoWarningAsError(), clang::DiagnosticMapping::setSeverity(), and clang::diag::Warning.
Referenced by isBuiltinExtensionDiag(), and isDefaultMappingAsError().
StringRef DiagnosticIDs::getDescription | ( | unsigned | DiagID | ) | const |
Given a diagnostic ID, return a description of the issue.
getDescription - Given a diagnostic ID, return a description of the issue.
Definition at line 464 of file DiagnosticIDs.cpp.
References GetDiagInfo().
|
static |
Get the string of all diagnostic flags.
no-
variants. For example: {"-Wempty-body", "-Wno-empty-body", ...}
Definition at line 670 of file DiagnosticIDs.cpp.
References Diag().
Referenced by clang::driver::Driver::HandleAutocompletions(), and clang::driver::Driver::HandleImmediateArgs().
|
static |
Determines whether the given built-in diagnostic ID is for an error that is suppressed if it occurs during C++ template argument deduction.
When an error is suppressed due to SFINAE, the template argument deduction fails but no diagnostic is emitted. Certain classes of errors, such as those errors that involve C++ access control, are not SFINAE errors.
Definition at line 335 of file DiagnosticIDs.cpp.
References GetDiagInfo(), and SFINAE_Report.
Referenced by clang::Sema::EmitDiagnostic().
bool DiagnosticIDs::getDiagnosticsInGroup | ( | diag::Flavor | Flavor, |
StringRef | Group, | ||
SmallVectorImpl< diag::kind > & | Diags | ||
) | const |
Get the set of all diagnostic IDs in the group with the given name.
[out] | Diags | - On return, the diagnostics in the group. |
true
if the given group is unknown, false
otherwise. Definition at line 713 of file DiagnosticIDs.cpp.
References getGroupForWarningOption(), and OptionTable.
Referenced by getNearestOption().
|
static |
Return the lowest-level group that contains the specified diagnostic.
Definition at line 655 of file DiagnosticIDs.cpp.
References GetDiagInfo().
Referenced by getWarningOptionForDiag().
|
static |
Given a group ID, returns the flag that toggles the group.
For example, for "deprecated-declarations", returns Group::DeprecatedDeclarations.
Definition at line 647 of file DiagnosticIDs.cpp.
References clang::Found, and OptionTable.
Referenced by getDiagnosticsInGroup().
|
static |
Get the diagnostic option with the closest edit distance to the given group name.
Definition at line 728 of file DiagnosticIDs.cpp.
References getDiagnosticsInGroup(), and OptionTable.
Referenced by EmitUnknownDiagWarning().
|
static |
Return the number of diagnostic categories.
getNumberOfCategories - Return the number of categories
Definition at line 319 of file DiagnosticIDs.cpp.
References CategoryNameTable.
Referenced by getCategoryNameFromID(), and PrintDiagnosticCategories().
|
static |
Given a diagnostic group ID, return its documentation.
Definition at line 638 of file DiagnosticIDs.cpp.
References OptionTable.
|
static |
Return the lowest-level warning option that enables the specified diagnostic.
getWarningOptionForDiag - Return the lowest-level warning option that enables the specified diagnostic.
If there is no -Wfoo flag that controls the diagnostic, this returns null.
Definition at line 664 of file DiagnosticIDs.cpp.
References getGroupForDiag(), and getWarningOptionForGroup().
Referenced by clang::LogDiagnosticPrinter::HandleDiagnostic(), and printDiagnosticOptions().
|
static |
Given a group ID, returns the flag that toggles the group.
For example, for Group::DeprecatedDeclarations, returns "deprecated-declarations".
Definition at line 642 of file DiagnosticIDs.cpp.
References getName(), and OptionTable.
Referenced by clang::driver::tools::Clang::ConstructJob(), and getWarningOptionForDiag().
Return true if a given diagnostic falls into an ARC diagnostic category.
Definition at line 881 of file DiagnosticIDs.cpp.
References getCategoryNameFromID(), and getCategoryNumberForDiag().
Determine whether the given built-in diagnostic ID is for an extension of some sort.
Definition at line 233 of file DiagnosticIDs.h.
References isBuiltinExtensionDiag().
Referenced by isBuiltinExtensionDiag().
Determine whether the given built-in diagnostic ID is for an extension of some sort, and whether it is enabled by default.
isBuiltinExtensionDiag - Determine whether the given built-in diagnostic ID is for an extension of some sort.
This also returns EnabledByDefault, which is set to indicate whether the diagnostic is ignored by default (in which case -pedantic enables it) or treated as a warning/error by default.
Definition at line 444 of file DiagnosticIDs.cpp.
References clang::diag::DIAG_UPPER_LIMIT, getBuiltinDiagClass(), getDefaultMapping(), clang::DiagnosticMapping::getSeverity(), and clang::diag::Ignored.
Determine whether the given built-in diagnostic ID is a Note.
Definition at line 434 of file DiagnosticIDs.cpp.
References clang::diag::DIAG_UPPER_LIMIT, and getBuiltinDiagClass().
Referenced by clang::Sema::EmitDiagnostic().
Return true if the unmapped diagnostic levelof the specified diagnostic ID is a Warning or Extension.
isBuiltinWarningOrExtension - Return true if the unmapped diagnostic level of the specified diagnostic ID is a Warning or Extension.
This only works on builtin diagnostics, not custom ones, and is not legal to call on NOTEs.
Definition at line 427 of file DiagnosticIDs.cpp.
References clang::diag::DIAG_UPPER_LIMIT, and getBuiltinDiagClass().
Referenced by printDiagnosticOptions().
Return true if a given diagnostic is a codegen-time ABI check.
Definition at line 886 of file DiagnosticIDs.cpp.
References getCategoryNameFromID(), and getCategoryNumberForDiag().
Return true if the specified diagnostic is mapped to errors by default.
Definition at line 455 of file DiagnosticIDs.cpp.
References clang::diag::DIAG_UPPER_LIMIT, clang::diag::Error, getDefaultMapping(), and clang::DiagnosticMapping::getSeverity().
Referenced by clang::Sema::hasUncompilableErrorOccurred(), and printDiagnosticOptions().
Whether the diagnostic message can be deferred.
For single source offloading languages, a diagnostic message occurred in a device host function may be deferred until the function is sure to be emitted.
Definition at line 341 of file DiagnosticIDs.cpp.
References GetDiagInfo().
Referenced by clang::SemaBase::Diag().
|
friend |
Definition at line 384 of file DiagnosticIDs.h.