| Index: third_party/re2/re2/stringpiece.cc
|
| diff --git a/third_party/re2/util/stringpiece.cc b/third_party/re2/re2/stringpiece.cc
|
| similarity index 64%
|
| rename from third_party/re2/util/stringpiece.cc
|
| rename to third_party/re2/re2/stringpiece.cc
|
| index 37895b01e861454981ab9969e7608449d8a69b35..00f478a54ee056f2ffe8e65dff2d9e70c63b9835 100644
|
| --- a/third_party/re2/util/stringpiece.cc
|
| +++ b/third_party/re2/re2/stringpiece.cc
|
| @@ -33,23 +33,33 @@ void StringPiece::CopyToString(string* target) const {
|
| target->assign(ptr_, length_);
|
| }
|
|
|
| -int StringPiece::copy(char* buf, size_type n, size_type pos) const {
|
| - int ret = min(length_ - pos, n);
|
| +void StringPiece::AppendToString(string* target) const {
|
| + target->append(ptr_, length_);
|
| +}
|
| +
|
| +StringPiece::size_type StringPiece::copy(char* buf, size_type n,
|
| + size_type pos) const {
|
| + size_type ret = min(length_ - pos, n);
|
| memcpy(buf, ptr_ + pos, ret);
|
| return ret;
|
| }
|
|
|
| -int StringPiece::find(const StringPiece& s, size_type pos) const {
|
| +bool StringPiece::contains(StringPiece s) const {
|
| + return find(s, 0) != npos;
|
| +}
|
| +
|
| +StringPiece::size_type StringPiece::find(const StringPiece& s,
|
| + size_type pos) const {
|
| if (length_ < 0 || pos > static_cast<size_type>(length_))
|
| return npos;
|
|
|
| const char* result = std::search(ptr_ + pos, ptr_ + length_,
|
| s.ptr_, s.ptr_ + s.length_);
|
| const size_type xpos = result - ptr_;
|
| - return xpos + s.length_ <= length_ ? xpos : npos;
|
| + return xpos + s.length_ <= static_cast<size_type>(length_) ? xpos : npos;
|
| }
|
|
|
| -int StringPiece::find(char c, size_type pos) const {
|
| +StringPiece::size_type StringPiece::find(char c, size_type pos) const {
|
| if (length_ <= 0 || pos >= static_cast<size_type>(length_)) {
|
| return npos;
|
| }
|
| @@ -57,9 +67,10 @@ int StringPiece::find(char c, size_type pos) const {
|
| return result != ptr_ + length_ ? result - ptr_ : npos;
|
| }
|
|
|
| -int StringPiece::rfind(const StringPiece& s, size_type pos) const {
|
| +StringPiece::size_type StringPiece::rfind(const StringPiece& s,
|
| + size_type pos) const {
|
| if (length_ < s.length_) return npos;
|
| - const size_t ulen = length_;
|
| + const size_type ulen = length_;
|
| if (s.length_ == 0) return min(ulen, pos);
|
|
|
| const char* last = ptr_ + min(ulen - s.length_, pos) + s.length_;
|
| @@ -67,9 +78,9 @@ int StringPiece::rfind(const StringPiece& s, size_type pos) const {
|
| return result != last ? result - ptr_ : npos;
|
| }
|
|
|
| -int StringPiece::rfind(char c, size_type pos) const {
|
| +StringPiece::size_type StringPiece::rfind(char c, size_type pos) const {
|
| if (length_ <= 0) return npos;
|
| - for (int i = min(pos, static_cast<size_type>(length_ - 1));
|
| + for (int i = static_cast<int>(min(pos, static_cast<size_type>(length_ - 1)));
|
| i >= 0; --i) {
|
| if (ptr_[i] == c) {
|
| return i;
|
| @@ -79,9 +90,9 @@ int StringPiece::rfind(char c, size_type pos) const {
|
| }
|
|
|
| StringPiece StringPiece::substr(size_type pos, size_type n) const {
|
| - if (pos > length_) pos = length_;
|
| + if (pos > static_cast<size_type>(length_)) pos = static_cast<size_type>(length_);
|
| if (n > length_ - pos) n = length_ - pos;
|
| - return StringPiece(ptr_ + pos, n);
|
| + return StringPiece(ptr_ + pos, static_cast<int>(n));
|
| }
|
|
|
| const StringPiece::size_type StringPiece::npos = size_type(-1);
|
|
|