diff options
Diffstat (limited to 'lib/Support/StringRef.cpp')
| -rw-r--r-- | lib/Support/StringRef.cpp | 27 | 
1 files changed, 18 insertions, 9 deletions
diff --git a/lib/Support/StringRef.cpp b/lib/Support/StringRef.cpp index ca0f518a88b6..46f26b242aac 100644 --- a/lib/Support/StringRef.cpp +++ b/lib/Support/StringRef.cpp @@ -9,6 +9,7 @@  #include "llvm/ADT/StringRef.h"  #include "llvm/ADT/APInt.h" +#include <bitset>  using namespace llvm; @@ -30,14 +31,14 @@ static bool ascii_isdigit(char x) {  /// compare_lower - Compare strings, ignoring case.  int StringRef::compare_lower(StringRef RHS) const {    for (size_t I = 0, E = min(Length, RHS.Length); I != E; ++I) { -    char LHC = ascii_tolower(Data[I]); -    char RHC = ascii_tolower(RHS.Data[I]); +    unsigned char LHC = ascii_tolower(Data[I]); +    unsigned char RHC = ascii_tolower(RHS.Data[I]);      if (LHC != RHC)        return LHC < RHC ? -1 : 1;    }    if (Length == RHS.Length) -        return 0; +    return 0;    return Length < RHS.Length ? -1 : 1;  } @@ -58,10 +59,10 @@ int StringRef::compare_numeric(StringRef RHS) const {            break;        }      } -    return Data[I] < RHS.Data[I] ? -1 : 1; +    return (unsigned char)Data[I] < (unsigned char)RHS.Data[I] ? -1 : 1;    }    if (Length == RHS.Length) -        return 0; +    return 0;    return Length < RHS.Length ? -1 : 1;  } @@ -153,11 +154,15 @@ size_t StringRef::rfind(StringRef Str) const {  /// find_first_of - Find the first character in the string that is in \arg  /// Chars, or npos if not found.  /// -/// Note: O(size() * Chars.size()) +/// Note: O(size() + Chars.size())  StringRef::size_type StringRef::find_first_of(StringRef Chars,                                                size_t From) const { +  std::bitset<1 << CHAR_BIT> CharBits; +  for (size_type i = 0; i != Chars.size(); ++i) +    CharBits.set((unsigned char)Chars[i]); +    for (size_type i = min(From, Length), e = Length; i != e; ++i) -    if (Chars.find(Data[i]) != npos) +    if (CharBits.test((unsigned char)Data[i]))        return i;    return npos;  } @@ -174,11 +179,15 @@ StringRef::size_type StringRef::find_first_not_of(char C, size_t From) const {  /// find_first_not_of - Find the first character in the string that is not  /// in the string \arg Chars, or npos if not found.  /// -/// Note: O(size() * Chars.size()) +/// Note: O(size() + Chars.size())  StringRef::size_type StringRef::find_first_not_of(StringRef Chars,                                                    size_t From) const { +  std::bitset<1 << CHAR_BIT> CharBits; +  for (size_type i = 0; i != Chars.size(); ++i) +    CharBits.set((unsigned char)Chars[i]); +    for (size_type i = min(From, Length), e = Length; i != e; ++i) -    if (Chars.find(Data[i]) == npos) +    if (!CharBits.test((unsigned char)Data[i]))        return i;    return npos;  }  | 
