1 // © 2016 and later: Unicode, Inc. and others.
2 // License & terms of use: http://www.unicode.org/copyright.html
3 // Copyright (C) 2009-2013, International Business Machines
4 // Corporation and others. All Rights Reserved.
6 // Copyright 2004 and onwards Google Inc.
8 // Author: wilsonh@google.com (Wilson Hsieh)
11 #include "unicode/utypes.h"
12 #include "unicode/stringpiece.h"
18 StringPiece::StringPiece(const char* str
)
19 : ptr_(str
), length_((str
== nullptr) ? 0 : static_cast<int32_t>(uprv_strlen(str
))) { }
21 StringPiece::StringPiece(const StringPiece
& x
, int32_t pos
) {
24 } else if (pos
> x
.length_
) {
28 length_
= x
.length_
- pos
;
31 StringPiece::StringPiece(const StringPiece
& x
, int32_t pos
, int32_t len
) {
34 } else if (pos
> x
.length_
) {
39 } else if (len
> x
.length_
- pos
) {
40 len
= x
.length_
- pos
;
46 void StringPiece::set(const char* str
) {
49 length_
= static_cast<int32_t>(uprv_strlen(str
));
54 int32_t StringPiece::find(StringPiece needle
, int32_t offset
) {
55 if (length() == 0 && needle
.length() == 0) {
58 // TODO: Improve to be better than O(N^2)?
59 for (int32_t i
= offset
; i
< length(); i
++) {
61 for (; j
< needle
.length(); i
++, j
++) {
62 if (data()[i
] != needle
.data()[j
]) {
73 int32_t StringPiece::compare(StringPiece other
) {
75 for (; i
< length(); i
++) {
76 if (i
== other
.length()) {
81 char b
= other
.data()[i
];
88 if (i
< other
.length()) {
95 U_EXPORT UBool U_EXPORT2
96 operator==(const StringPiece
& x
, const StringPiece
& y
) {
97 int32_t len
= x
.size();
98 if (len
!= y
.size()) {
104 const char* p
= x
.data();
105 const char* p2
= y
.data();
106 // Test last byte in case strings share large common prefix
108 if (p
[len
] != p2
[len
]) return false;
109 // At this point we can, but don't have to, ignore the last byte.
110 return uprv_memcmp(p
, p2
, len
) == 0;
114 const int32_t StringPiece::npos
= 0x7fffffff;