blob: afbc2edc506f48a9a6a0f9851a6daa34fe95044e [file] [log] [blame]
The Android Open Source Projectcbb10112009-03-03 19:31:44 -08001/*
2 * Copyright (C) 2005 The Android Open Source Project
3 *
4 * Licensed under the Apache License, Version 2.0 (the "License");
5 * you may not use this file except in compliance with the License.
6 * You may obtain a copy of the License at
7 *
8 * http://www.apache.org/licenses/LICENSE-2.0
9 *
10 * Unless required by applicable law or agreed to in writing, software
11 * distributed under the License is distributed on an "AS IS" BASIS,
12 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 * See the License for the specific language governing permissions and
14 * limitations under the License.
15 */
16
17#ifndef ANDROID_STRING16_H
18#define ANDROID_STRING16_H
19
Samuel Tan9ac4e002016-02-16 14:20:05 -080020#include <string> // for std::string
21
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080022#include <utils/Errors.h>
Samuel Tan9ac4e002016-02-16 14:20:05 -080023#include <utils/String8.h>
Jeff Brown9a0a76d2012-03-16 14:45:49 -070024#include <utils/TypeHelpers.h>
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080025
26// ---------------------------------------------------------------------------
27
28extern "C" {
29
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080030}
31
32// ---------------------------------------------------------------------------
33
34namespace android {
35
Kenny Root9a2d83e2009-12-04 09:38:48 -080036// ---------------------------------------------------------------------------
37
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080038class String8;
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080039
Steven Morelandb8f152d2017-12-18 16:14:13 -080040// DO NOT USE: please use std::u16string
41
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080042//! This is a string holding UTF-16 characters.
43class String16
44{
45public:
Mathias Agopian4485d0d2013-05-08 16:04:13 -070046 /* use String16(StaticLinkage) if you're statically linking against
47 * libutils and declaring an empty static String16, e.g.:
48 *
49 * static String16 sAStaticEmptyString(String16::kEmptyString);
50 * static String16 sAnotherStaticEmptyString(sAStaticEmptyString);
51 */
52 enum StaticLinkage { kEmptyString };
53
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080054 String16();
Mathias Agopian4485d0d2013-05-08 16:04:13 -070055 explicit String16(StaticLinkage);
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080056 String16(const String16& o);
57 String16(const String16& o,
58 size_t len,
59 size_t begin=0);
60 explicit String16(const char16_t* o);
61 explicit String16(const char16_t* o, size_t len);
62 explicit String16(const String8& o);
63 explicit String16(const char* o);
64 explicit String16(const char* o, size_t len);
65
66 ~String16();
Samuel Tanf9d16ef2016-02-16 15:17:10 -080067
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080068 inline const char16_t* string() const;
Samuel Tanf9d16ef2016-02-16 15:17:10 -080069
Steven Moreland2aac3352017-03-10 22:31:08 -080070private:
Samuel Tan9ac4e002016-02-16 14:20:05 -080071 static inline std::string std_string(const String16& str);
Steven Moreland2aac3352017-03-10 22:31:08 -080072public:
Sergio Girod2529f22015-09-23 16:22:59 +010073 size_t size() const;
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080074 void setTo(const String16& other);
75 status_t setTo(const char16_t* other);
76 status_t setTo(const char16_t* other, size_t len);
77 status_t setTo(const String16& other,
78 size_t len,
79 size_t begin=0);
Samuel Tanf9d16ef2016-02-16 15:17:10 -080080
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080081 status_t append(const String16& other);
82 status_t append(const char16_t* other, size_t len);
Samuel Tanf9d16ef2016-02-16 15:17:10 -080083
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080084 inline String16& operator=(const String16& other);
Samuel Tanf9d16ef2016-02-16 15:17:10 -080085
The Android Open Source Projectcbb10112009-03-03 19:31:44 -080086 inline String16& operator+=(const String16& other);
87 inline String16 operator+(const String16& other) const;
88
89 status_t insert(size_t pos, const char16_t* chrs);
90 status_t insert(size_t pos,
91 const char16_t* chrs, size_t len);
92
93 ssize_t findFirst(char16_t c) const;
94 ssize_t findLast(char16_t c) const;
95
96 bool startsWith(const String16& prefix) const;
97 bool startsWith(const char16_t* prefix) const;
Samuel Tanf9d16ef2016-02-16 15:17:10 -080098
Michael Wright5bacef32016-05-09 14:43:31 +010099 bool contains(const char16_t* chrs) const;
100
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800101 status_t makeLower();
102
103 status_t replaceAll(char16_t replaceThis,
104 char16_t withThis);
105
106 status_t remove(size_t len, size_t begin=0);
107
108 inline int compare(const String16& other) const;
109
110 inline bool operator<(const String16& other) const;
111 inline bool operator<=(const String16& other) const;
112 inline bool operator==(const String16& other) const;
113 inline bool operator!=(const String16& other) const;
114 inline bool operator>=(const String16& other) const;
115 inline bool operator>(const String16& other) const;
Samuel Tanf9d16ef2016-02-16 15:17:10 -0800116
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800117 inline bool operator<(const char16_t* other) const;
118 inline bool operator<=(const char16_t* other) const;
119 inline bool operator==(const char16_t* other) const;
120 inline bool operator!=(const char16_t* other) const;
121 inline bool operator>=(const char16_t* other) const;
122 inline bool operator>(const char16_t* other) const;
Samuel Tanf9d16ef2016-02-16 15:17:10 -0800123
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800124 inline operator const char16_t*() const;
Samuel Tanf9d16ef2016-02-16 15:17:10 -0800125
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800126private:
127 const char16_t* mString;
128};
129
Jeff Brown9a0a76d2012-03-16 14:45:49 -0700130// String16 can be trivially moved using memcpy() because moving does not
131// require any change to the underlying SharedBuffer contents or reference count.
132ANDROID_TRIVIAL_MOVE_TRAIT(String16)
133
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800134// ---------------------------------------------------------------------------
135// No user servicable parts below.
136
137inline int compare_type(const String16& lhs, const String16& rhs)
138{
139 return lhs.compare(rhs);
140}
141
142inline int strictly_order_type(const String16& lhs, const String16& rhs)
143{
144 return compare_type(lhs, rhs) < 0;
145}
146
147inline const char16_t* String16::string() const
148{
149 return mString;
150}
151
Samuel Tan9ac4e002016-02-16 14:20:05 -0800152inline std::string String16::std_string(const String16& str)
153{
154 return std::string(String8(str).string());
155}
156
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800157inline String16& String16::operator=(const String16& other)
158{
159 setTo(other);
160 return *this;
161}
162
163inline String16& String16::operator+=(const String16& other)
164{
165 append(other);
166 return *this;
167}
168
169inline String16 String16::operator+(const String16& other) const
170{
Josiah Gaskin9ee3fc42011-08-16 15:16:04 -0700171 String16 tmp(*this);
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800172 tmp += other;
173 return tmp;
174}
175
176inline int String16::compare(const String16& other) const
177{
178 return strzcmp16(mString, size(), other.mString, other.size());
179}
180
181inline bool String16::operator<(const String16& other) const
182{
183 return strzcmp16(mString, size(), other.mString, other.size()) < 0;
184}
185
186inline bool String16::operator<=(const String16& other) const
187{
188 return strzcmp16(mString, size(), other.mString, other.size()) <= 0;
189}
190
191inline bool String16::operator==(const String16& other) const
192{
Brad Fitzpatrick9d589aa2010-10-20 17:06:28 -0700193 return strzcmp16(mString, size(), other.mString, other.size()) == 0;
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800194}
195
196inline bool String16::operator!=(const String16& other) const
197{
198 return strzcmp16(mString, size(), other.mString, other.size()) != 0;
199}
200
201inline bool String16::operator>=(const String16& other) const
202{
203 return strzcmp16(mString, size(), other.mString, other.size()) >= 0;
204}
205
206inline bool String16::operator>(const String16& other) const
207{
208 return strzcmp16(mString, size(), other.mString, other.size()) > 0;
209}
210
211inline bool String16::operator<(const char16_t* other) const
212{
213 return strcmp16(mString, other) < 0;
214}
215
216inline bool String16::operator<=(const char16_t* other) const
217{
218 return strcmp16(mString, other) <= 0;
219}
220
221inline bool String16::operator==(const char16_t* other) const
222{
223 return strcmp16(mString, other) == 0;
224}
225
226inline bool String16::operator!=(const char16_t* other) const
227{
228 return strcmp16(mString, other) != 0;
229}
230
231inline bool String16::operator>=(const char16_t* other) const
232{
233 return strcmp16(mString, other) >= 0;
234}
235
236inline bool String16::operator>(const char16_t* other) const
237{
238 return strcmp16(mString, other) > 0;
239}
240
241inline String16::operator const char16_t*() const
242{
243 return mString;
244}
245
Pirama Arumuga Nainareab48ce2018-04-10 14:31:29 -0700246} // namespace android
The Android Open Source Projectcbb10112009-03-03 19:31:44 -0800247
248// ---------------------------------------------------------------------------
249
250#endif // ANDROID_STRING16_H