diff options
| author | Roman Divacky <rdivacky@FreeBSD.org> | 2009-10-23 14:22:18 +0000 | 
|---|---|---|
| committer | Roman Divacky <rdivacky@FreeBSD.org> | 2009-10-23 14:22:18 +0000 | 
| commit | 73490b890977362d28dd6326843a1ecae413921d (patch) | |
| tree | 3fdd91eae574e32453a4baf462961c742df2691a /lib/Parse/AttributeList.cpp | |
| parent | a5f348eb914e67b51914117fac117c18c1f8d650 (diff) | |
Diffstat (limited to 'lib/Parse/AttributeList.cpp')
| -rw-r--r-- | lib/Parse/AttributeList.cpp | 13 | 
1 files changed, 5 insertions, 8 deletions
| diff --git a/lib/Parse/AttributeList.cpp b/lib/Parse/AttributeList.cpp index 2ee41bc3eb8d..224a31cd5a5e 100644 --- a/lib/Parse/AttributeList.cpp +++ b/lib/Parse/AttributeList.cpp @@ -45,18 +45,15 @@ AttributeList::~AttributeList() {  }  AttributeList::Kind AttributeList::getKind(const IdentifierInfo *Name) { -  const char *Str = Name->getName(); -  unsigned Len = Name->getLength(); +  llvm::StringRef AttrName = Name->getName();    // Normalize the attribute name, __foo__ becomes foo. -  if (Len > 4 && Str[0] == '_' && Str[1] == '_' && -      Str[Len - 2] == '_' && Str[Len - 1] == '_') { -    Str += 2; -    Len -= 4; -  } +  if (AttrName.startswith("__") && AttrName.endswith("__")) +    AttrName = AttrName.substr(2, AttrName.size() - 4);    // FIXME: Hand generating this is neither smart nor efficient. -  switch (Len) { +  const char *Str = AttrName.data(); +  switch (AttrName.size()) {    case 4:      if (!memcmp(Str, "weak", 4)) return AT_weak;      if (!memcmp(Str, "pure", 4)) return AT_pure; | 
