forked from OSchip/llvm-project
Use enumerators instead of hardcoded integers when we decide if keyword is enabled.
llvm-svn: 220849
This commit is contained in:
parent
f9c3480322
commit
77af3812ec
|
@ -110,49 +110,59 @@ namespace {
|
|||
HALFSUPPORT = 0x04000,
|
||||
KEYALL = (0xffff & ~KEYNOMS) // Because KEYNOMS is used to exclude.
|
||||
};
|
||||
|
||||
/// \brief How a keyword is treated in the selected standard.
|
||||
enum KeywordStatus {
|
||||
KS_Disabled, // Disabled
|
||||
KS_Extension, // Is an extension
|
||||
KS_Enabled, // Enabled
|
||||
KS_Future // Is a keyword in future standard
|
||||
};
|
||||
}
|
||||
|
||||
/// \brief Translates flags as specified in TokenKinds.def into keyword status
|
||||
/// in the given language standard.
|
||||
static KeywordStatus GetKeywordStatus(const LangOptions &LangOpts,
|
||||
unsigned Flags) {
|
||||
if (Flags == KEYALL) return KS_Enabled;
|
||||
if (LangOpts.CPlusPlus && (Flags & KEYCXX)) return KS_Enabled;
|
||||
if (LangOpts.CPlusPlus11 && (Flags & KEYCXX11)) return KS_Enabled;
|
||||
if (LangOpts.C99 && (Flags & KEYC99)) return KS_Enabled;
|
||||
if (LangOpts.GNUKeywords && (Flags & KEYGNU)) return KS_Extension;
|
||||
if (LangOpts.MicrosoftExt && (Flags & KEYMS)) return KS_Extension;
|
||||
if (LangOpts.Borland && (Flags & KEYBORLAND)) return KS_Extension;
|
||||
if (LangOpts.Bool && (Flags & BOOLSUPPORT)) return KS_Enabled;
|
||||
if (LangOpts.Half && (Flags & HALFSUPPORT)) return KS_Enabled;
|
||||
if (LangOpts.WChar && (Flags & WCHARSUPPORT)) return KS_Enabled;
|
||||
if (LangOpts.AltiVec && (Flags & KEYALTIVEC)) return KS_Enabled;
|
||||
if (LangOpts.OpenCL && (Flags & KEYOPENCL)) return KS_Enabled;
|
||||
if (!LangOpts.CPlusPlus && (Flags & KEYNOCXX)) return KS_Enabled;
|
||||
if (LangOpts.C11 && (Flags & KEYC11)) return KS_Enabled;
|
||||
// We treat bridge casts as objective-C keywords so we can warn on them
|
||||
// in non-arc mode.
|
||||
if (LangOpts.ObjC2 && (Flags & KEYARC)) return KS_Enabled;
|
||||
if (LangOpts.CPlusPlus && (Flags & KEYCXX11)) return KS_Future;
|
||||
return KS_Disabled;
|
||||
}
|
||||
|
||||
/// AddKeyword - This method is used to associate a token ID with specific
|
||||
/// identifiers because they are language keywords. This causes the lexer to
|
||||
/// automatically map matching identifiers to specialized token codes.
|
||||
///
|
||||
/// The C90/C99/CPP/CPP0x flags are set to 3 if the token is a keyword in a
|
||||
/// future language standard, set to 2 if the token should be enabled in the
|
||||
/// specified language, set to 1 if it is an extension in the specified
|
||||
/// language, and set to 0 if disabled in the specified language.
|
||||
static void AddKeyword(StringRef Keyword,
|
||||
tok::TokenKind TokenCode, unsigned Flags,
|
||||
const LangOptions &LangOpts, IdentifierTable &Table) {
|
||||
unsigned AddResult = 0;
|
||||
if (Flags == KEYALL) AddResult = 2;
|
||||
else if (LangOpts.CPlusPlus && (Flags & KEYCXX)) AddResult = 2;
|
||||
else if (LangOpts.CPlusPlus11 && (Flags & KEYCXX11)) AddResult = 2;
|
||||
else if (LangOpts.C99 && (Flags & KEYC99)) AddResult = 2;
|
||||
else if (LangOpts.GNUKeywords && (Flags & KEYGNU)) AddResult = 1;
|
||||
else if (LangOpts.MicrosoftExt && (Flags & KEYMS)) AddResult = 1;
|
||||
else if (LangOpts.Borland && (Flags & KEYBORLAND)) AddResult = 1;
|
||||
else if (LangOpts.Bool && (Flags & BOOLSUPPORT)) AddResult = 2;
|
||||
else if (LangOpts.Half && (Flags & HALFSUPPORT)) AddResult = 2;
|
||||
else if (LangOpts.WChar && (Flags & WCHARSUPPORT)) AddResult = 2;
|
||||
else if (LangOpts.AltiVec && (Flags & KEYALTIVEC)) AddResult = 2;
|
||||
else if (LangOpts.OpenCL && (Flags & KEYOPENCL)) AddResult = 2;
|
||||
else if (!LangOpts.CPlusPlus && (Flags & KEYNOCXX)) AddResult = 2;
|
||||
else if (LangOpts.C11 && (Flags & KEYC11)) AddResult = 2;
|
||||
// We treat bridge casts as objective-C keywords so we can warn on them
|
||||
// in non-arc mode.
|
||||
else if (LangOpts.ObjC2 && (Flags & KEYARC)) AddResult = 2;
|
||||
else if (LangOpts.CPlusPlus && (Flags & KEYCXX11)) AddResult = 3;
|
||||
KeywordStatus AddResult = GetKeywordStatus(LangOpts, Flags);
|
||||
|
||||
// Don't add this keyword under MSVCCompat.
|
||||
if (LangOpts.MSVCCompat && (Flags & KEYNOMS))
|
||||
return;
|
||||
// Don't add this keyword if disabled in this language.
|
||||
if (AddResult == 0) return;
|
||||
if (AddResult == KS_Disabled) return;
|
||||
|
||||
IdentifierInfo &Info =
|
||||
Table.get(Keyword, AddResult == 3 ? tok::identifier : TokenCode);
|
||||
Info.setIsExtensionToken(AddResult == 1);
|
||||
Info.setIsCXX11CompatKeyword(AddResult == 3);
|
||||
Table.get(Keyword, AddResult == KS_Future ? tok::identifier : TokenCode);
|
||||
Info.setIsExtensionToken(AddResult == KS_Extension);
|
||||
Info.setIsCXX11CompatKeyword(AddResult == KS_Future);
|
||||
}
|
||||
|
||||
/// AddCXXOperatorKeyword - Register a C++ operator keyword alternative
|
||||
|
|
Loading…
Reference in New Issue