diff options
Diffstat (limited to 'clang/lib')
| -rw-r--r-- | clang/lib/Basic/Attributes.cpp | 17 | ||||
| -rw-r--r-- | clang/lib/Basic/CMakeLists.txt | 1 | ||||
| -rw-r--r-- | clang/lib/Lex/PPMacroExpansion.cpp | 18 | 
3 files changed, 21 insertions, 15 deletions
| diff --git a/clang/lib/Basic/Attributes.cpp b/clang/lib/Basic/Attributes.cpp new file mode 100644 index 00000000000..c882bc226d4 --- /dev/null +++ b/clang/lib/Basic/Attributes.cpp @@ -0,0 +1,17 @@ +#include "clang/Basic/Attributes.h" +#include "clang/Basic/IdentifierTable.h" +#include "llvm/ADT/StringSwitch.h" +using namespace clang; + +bool clang::HasAttribute(AttrSyntax Syntax, const IdentifierInfo *Scope, +                         const IdentifierInfo *Attr, const llvm::Triple &T, +                         const LangOptions &LangOpts) { +  StringRef Name = Attr->getName(); +  // Normalize the attribute name, __foo__ becomes foo. +  if (Name.size() >= 4 && Name.startswith("__") && Name.endswith("__")) +    Name = Name.substr(2, Name.size() - 4); + +#include "clang/Basic/AttrHasAttributeImpl.inc" + +  return false; +} diff --git a/clang/lib/Basic/CMakeLists.txt b/clang/lib/Basic/CMakeLists.txt index d248d3dc827..0448fdb0d41 100644 --- a/clang/lib/Basic/CMakeLists.txt +++ b/clang/lib/Basic/CMakeLists.txt @@ -4,6 +4,7 @@ set(LLVM_LINK_COMPONENTS    )  add_clang_library(clangBasic +  Attributes.cpp    Builtins.cpp    CharInfo.cpp    Diagnostic.cpp diff --git a/clang/lib/Lex/PPMacroExpansion.cpp b/clang/lib/Lex/PPMacroExpansion.cpp index 917d434c483..62a89c03e18 100644 --- a/clang/lib/Lex/PPMacroExpansion.cpp +++ b/clang/lib/Lex/PPMacroExpansion.cpp @@ -13,6 +13,7 @@  //===----------------------------------------------------------------------===//  #include "clang/Lex/Preprocessor.h" +#include "clang/Basic/Attributes.h"  #include "clang/Basic/FileManager.h"  #include "clang/Basic/SourceManager.h"  #include "clang/Basic/TargetInfo.h" @@ -1047,20 +1048,6 @@ static bool HasExtension(const Preprocessor &PP, const IdentifierInfo *II) {             .Default(false);  } -/// HasAttribute -  Return true if we recognize and implement the attribute -/// specified by the given identifier. -static bool HasAttribute(const IdentifierInfo *II, const llvm::Triple &T) { -  StringRef Name = II->getName(); -  // Normalize the attribute name, __foo__ becomes foo. -  if (Name.size() >= 4 && Name.startswith("__") && Name.endswith("__")) -    Name = Name.substr(2, Name.size() - 4); - -  // FIXME: Do we need to handle namespaces here? -  return llvm::StringSwitch<bool>(Name) -#include "clang/Lex/AttrSpellings.inc" -        .Default(false); -} -  /// EvaluateHasIncludeCommon - Process a '__has_include("path")'  /// or '__has_include_next("path")' expression.  /// Returns true if successful. @@ -1399,7 +1386,8 @@ void Preprocessor::ExpandBuiltinMacro(Token &Tok) {        // Check for a builtin is trivial.        Value = FeatureII->getBuiltinID() != 0;      } else if (II == Ident__has_attribute) -      Value = HasAttribute(FeatureII, getTargetInfo().getTriple()); +      Value = HasAttribute(AttrSyntax::Generic, nullptr, FeatureII, +                           getTargetInfo().getTriple(), getLangOpts());      else if (II == Ident__has_extension)        Value = HasExtension(*this, FeatureII);      else { | 

