clang  6.0.0svn
Public Types | Public Member Functions | Static Public Member Functions | Friends | List of all members
clang::DiagnosticIDs Class Reference

Used for handling and querying diagnostic IDs. More...

#include "clang/Basic/DiagnosticIDs.h"

Inheritance diagram for clang::DiagnosticIDs:
Inheritance graph
[legend]
Collaboration diagram for clang::DiagnosticIDs:
Collaboration graph
[legend]

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. More...
 
StringRef getDescription (unsigned DiagID) const
 Given a diagnostic ID, return a description of the issue. More...
 
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. More...
 

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. More...
 
static bool isDefaultMappingAsError (unsigned DiagID)
 Return true if the specified diagnostic is mapped to errors by default. More...
 
static bool isBuiltinNote (unsigned DiagID)
 Determine whether the given built-in diagnostic ID is a Note. More...
 
static bool isBuiltinExtensionDiag (unsigned DiagID)
 Determine whether the given built-in diagnostic ID is for an extension of some sort. More...
 
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. More...
 
static StringRef getWarningOptionForDiag (unsigned DiagID)
 Return the lowest-level warning option that enables the specified diagnostic. More...
 
static unsigned getCategoryNumberForDiag (unsigned DiagID)
 Return the category number that a specified DiagID belongs to, or 0 if no category. More...
 
static unsigned getNumberOfCategories ()
 Return the number of diagnostic categories. More...
 
static StringRef getCategoryNameFromID (unsigned CategoryID)
 Given a category ID, return the name of the category. More...
 
static bool isARCDiagnostic (unsigned DiagID)
 Return true if a given diagnostic falls into an ARC diagnostic category. More...
 
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. More...
 
static std::vector< std::string > getDiagnosticFlags ()
 Get the string of all diagnostic flags. More...
 
static void getAllDiagnostics (diag::Flavor Flavor, SmallVectorImpl< diag::kind > &Diags)
 Get the set of all diagnostic IDs. More...
 
static StringRef getNearestOption (diag::Flavor Flavor, StringRef Group)
 Get the diagnostic option with the closest edit distance to the given group name. More...
 

Friends

class DiagnosticsEngine
 

Detailed Description

Used for handling and querying diagnostic IDs.

Can be used and shared by multiple Diagnostics for multiple translation units.

Definition at line 164 of file DiagnosticIDs.h.

Member Enumeration Documentation

◆ Level

The level of the diagnostic, after it has been through mapping.

Enumerator
Ignored 
Note 
Remark 
Warning 
Error 
Fatal 

Definition at line 167 of file DiagnosticIDs.h.

◆ SFINAEResponse

Enumeration describing how the emission of a diagnostic should be treated when it occurs during C++ template argument deduction.

Enumerator
SFINAE_SubstitutionFailure 

The diagnostic should not be reported, but it should cause template argument deduction to fail.

The vast majority of errors that occur during template argument deduction fall into this category.

SFINAE_Suppress 

The diagnostic should be suppressed entirely.

Warnings generally fall into this category.

SFINAE_Report 

The diagnostic should be reported.

The diagnostic should be reported. Various fatal errors (e.g., template instantiation depth exceeded) fall into this category.

SFINAE_AccessControl 

The diagnostic is an access-control diagnostic, which will be substitution failures in some contexts and reported in others.

Definition at line 250 of file DiagnosticIDs.h.

Constructor & Destructor Documentation

◆ DiagnosticIDs()

DiagnosticIDs::DiagnosticIDs ( )

Definition at line 315 of file DiagnosticIDs.cpp.

◆ ~DiagnosticIDs()

DiagnosticIDs::~DiagnosticIDs ( )

Definition at line 317 of file DiagnosticIDs.cpp.

Member Function Documentation

◆ getAllDiagnostics()

void DiagnosticIDs::getAllDiagnostics ( diag::Flavor  Flavor,
SmallVectorImpl< diag::kind > &  Diags 
)
static

Get the set of all diagnostic IDs.

Definition at line 585 of file DiagnosticIDs.cpp.

References StaticDiagInfoSize.

Referenced by clang::DiagnosticsEngine::setSeverityForAll().

◆ getCategoryNameFromID()

StringRef DiagnosticIDs::getCategoryNameFromID ( unsigned  CategoryID)
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 241 of file DiagnosticIDs.cpp.

Referenced by AddRangeLocationAbbrev(), isARCDiagnostic(), PrintDiagnosticCategories(), and printDiagnosticOptions().

◆ getCategoryNumberForDiag()

unsigned DiagnosticIDs::getCategoryNumberForDiag ( unsigned  DiagID)
static

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 192 of file DiagnosticIDs.cpp.

References Diag(), GetDefaultDiagMapping(), GetDiagInfo(), and clang::Result.

Referenced by getStableLevel(), and printDiagnosticOptions().

◆ getCustomDiagID()

unsigned DiagnosticIDs::getCustomDiagID ( Level  L,
StringRef  FormatString 
)

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.

Parameters
FormatStringA fixed diagnostic format string that will be hashed and mapped to a unique DiagID.

Definition at line 327 of file DiagnosticIDs.cpp.

◆ getDescription()

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 375 of file DiagnosticIDs.cpp.

References GetDiagInfo().

◆ getDiagnosticFlags()

std::vector< std::string > DiagnosticIDs::getDiagnosticFlags ( )
static

Get the string of all diagnostic flags.

Returns
A list of all diagnostics flags as they would be written in a command line invocation including their no- variants. For example: {"-Wempty-body", "-Wno-empty-body", ...}

Definition at line 529 of file DiagnosticIDs.cpp.

◆ getDiagnosticSFINAEResponse()

DiagnosticIDs::SFINAEResponse DiagnosticIDs::getDiagnosticSFINAEResponse ( unsigned  DiagID)
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 250 of file DiagnosticIDs.cpp.

References GetDiagInfo().

Referenced by clang::Sema::EmitCurrentDiagnostic().

◆ getDiagnosticsInGroup()

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.

Parameters
[out]Diags- On return, the diagnostics in the group.
Returns
true if the given group is unknown, false otherwise.

Definition at line 572 of file DiagnosticIDs.cpp.

References getDiagnosticsInGroup().

◆ getNearestOption()

StringRef DiagnosticIDs::getNearestOption ( diag::Flavor  Flavor,
StringRef  Group 
)
static

◆ getNumberOfCategories()

unsigned DiagnosticIDs::getNumberOfCategories ( )
static

Return the number of diagnostic categories.

getNumberOfCategories - Return the number of categories

Definition at line 234 of file DiagnosticIDs.cpp.

Referenced by PrintDiagnosticCategories().

◆ getWarningOptionForDiag()

StringRef DiagnosticIDs::getWarningOptionForDiag ( unsigned  DiagID)
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 523 of file DiagnosticIDs.cpp.

References GetDiagInfo().

Referenced by AddRangeLocationAbbrev(), clang::LogDiagnosticPrinter::HandleDiagnostic(), and printDiagnosticOptions().

◆ isARCDiagnostic()

bool DiagnosticIDs::isARCDiagnostic ( unsigned  DiagID)
static

Return true if a given diagnostic falls into an ARC diagnostic category.

Definition at line 741 of file DiagnosticIDs.cpp.

References getCategoryNameFromID().

◆ isBuiltinExtensionDiag() [1/2]

static bool clang::DiagnosticIDs::isBuiltinExtensionDiag ( unsigned  DiagID)
inlinestatic

Determine whether the given built-in diagnostic ID is for an extension of some sort.

Definition at line 213 of file DiagnosticIDs.h.

◆ isBuiltinExtensionDiag() [2/2]

bool DiagnosticIDs::isBuiltinExtensionDiag ( unsigned  DiagID,
bool EnabledByDefault 
)
static

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 355 of file DiagnosticIDs.cpp.

References clang::diag::DIAG_UPPER_LIMIT, getBuiltinDiagClass(), GetDefaultDiagMapping(), clang::DiagnosticMapping::getSeverity(), and clang::diag::Ignored.

◆ isBuiltinNote()

bool DiagnosticIDs::isBuiltinNote ( unsigned  DiagID)
static

Determine whether the given built-in diagnostic ID is a Note.

Definition at line 345 of file DiagnosticIDs.cpp.

References clang::diag::DIAG_UPPER_LIMIT, and getBuiltinDiagClass().

Referenced by clang::Sema::EmitCurrentDiagnostic().

◆ isBuiltinWarningOrExtension()

bool DiagnosticIDs::isBuiltinWarningOrExtension ( unsigned  DiagID)
static

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 338 of file DiagnosticIDs.cpp.

References clang::diag::DIAG_UPPER_LIMIT, and getBuiltinDiagClass().

Referenced by printDiagnosticOptions().

◆ isDefaultMappingAsError()

bool DiagnosticIDs::isDefaultMappingAsError ( unsigned  DiagID)
static

Return true if the specified diagnostic is mapped to errors by default.

Definition at line 366 of file DiagnosticIDs.cpp.

References clang::diag::DIAG_UPPER_LIMIT, clang::diag::Error, GetDefaultDiagMapping(), and clang::DiagnosticMapping::getSeverity().

Referenced by printDiagnosticOptions().

Friends And Related Function Documentation

◆ DiagnosticsEngine

friend class DiagnosticsEngine
friend

Definition at line 337 of file DiagnosticIDs.h.


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