williamr@4
|
1 |
/*
|
williamr@4
|
2 |
* © Portions copyright (c) 2006-2007 Nokia Corporation. All rights reserved.
|
williamr@4
|
3 |
*
|
williamr@4
|
4 |
* Copyright (c) 1994
|
williamr@4
|
5 |
* Hewlett-Packard Company
|
williamr@4
|
6 |
*
|
williamr@4
|
7 |
* Copyright (c) 1996,1997
|
williamr@4
|
8 |
* Silicon Graphics Computer Systems, Inc.
|
williamr@4
|
9 |
*
|
williamr@4
|
10 |
* Copyright (c) 1997
|
williamr@4
|
11 |
* Moscow Center for SPARC Technology
|
williamr@4
|
12 |
*
|
williamr@4
|
13 |
* Copyright (c) 1999
|
williamr@4
|
14 |
* Boris Fomitchev
|
williamr@4
|
15 |
*
|
williamr@4
|
16 |
* This material is provided "as is", with absolutely no warranty expressed
|
williamr@4
|
17 |
* or implied. Any use is at your own risk.
|
williamr@4
|
18 |
*
|
williamr@4
|
19 |
* Permission to use or copy this software for any purpose is hereby granted
|
williamr@4
|
20 |
* without fee, provided the above notices are retained on all copies.
|
williamr@4
|
21 |
* Permission to modify the code and to distribute modified code is granted,
|
williamr@4
|
22 |
* provided the above notices are retained, and a notice that the code was
|
williamr@4
|
23 |
* modified is included with the above copyright notice.
|
williamr@4
|
24 |
*
|
williamr@4
|
25 |
*/
|
williamr@4
|
26 |
#ifndef _STLP_STRING_C
|
williamr@4
|
27 |
#define _STLP_STRING_C
|
williamr@4
|
28 |
|
williamr@4
|
29 |
#ifndef _STLP_STRING_H
|
williamr@4
|
30 |
# include <stl/_string.h>
|
williamr@4
|
31 |
#endif
|
williamr@4
|
32 |
|
williamr@4
|
33 |
# ifdef _STLP_DEBUG
|
williamr@4
|
34 |
# define basic_string _Nondebug_string
|
williamr@4
|
35 |
# endif
|
williamr@4
|
36 |
|
williamr@4
|
37 |
# if defined (_STLP_USE_OWN_NAMESPACE) || !defined (_STLP_USE_NATIVE_STRING)
|
williamr@4
|
38 |
|
williamr@4
|
39 |
# if defined (_STLP_NESTED_TYPE_PARAM_BUG)
|
williamr@4
|
40 |
# define __size_type__ size_t
|
williamr@4
|
41 |
# define size_type size_t
|
williamr@4
|
42 |
# define iterator _CharT*
|
williamr@4
|
43 |
# else
|
williamr@4
|
44 |
# define __size_type__ _STLP_TYPENAME_ON_RETURN_TYPE basic_string<_CharT,_Traits,_Alloc>::size_type
|
williamr@4
|
45 |
# endif
|
williamr@4
|
46 |
|
williamr@4
|
47 |
_STLP_BEGIN_NAMESPACE
|
williamr@4
|
48 |
|
williamr@4
|
49 |
// ------------------------------------------------------------
|
williamr@4
|
50 |
// Non-inline declarations.
|
williamr@4
|
51 |
|
williamr@4
|
52 |
|
williamr@4
|
53 |
// Change the string's capacity so that it is large enough to hold
|
williamr@4
|
54 |
// at least __res_arg elements, plus the terminating _CharT(). Note that,
|
williamr@4
|
55 |
// if __res_arg < capacity(), this member function may actually decrease
|
williamr@4
|
56 |
// the string's capacity.
|
williamr@4
|
57 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
58 |
_STLP_EXP_DECLSPEC void basic_string<_CharT,_Traits,_Alloc>::reserve(size_type __res_arg) {
|
williamr@4
|
59 |
|
williamr@4
|
60 |
if (__res_arg >= capacity())
|
williamr@4
|
61 |
{
|
williamr@4
|
62 |
if (__res_arg > max_size())
|
williamr@4
|
63 |
this->_M_throw_length_error();
|
williamr@4
|
64 |
|
williamr@4
|
65 |
size_type __n = __res_arg + 1;
|
williamr@4
|
66 |
_STLP_LEAVE_VOLATILE pointer __new_start = this->_M_end_of_storage.allocate(__n);
|
williamr@4
|
67 |
_STLP_LEAVE_VOLATILE pointer __new_finish = __new_start;
|
williamr@4
|
68 |
|
williamr@4
|
69 |
_STLP_TRY {
|
williamr@4
|
70 |
__new_finish = uninitialized_copy(this->_M_start, this->_M_finish, __new_start);
|
williamr@4
|
71 |
_M_construct_null(__new_finish);
|
williamr@4
|
72 |
}
|
williamr@4
|
73 |
_STLP_UNWIND((_STLP_STD::_Destroy(__new_start, __new_finish),
|
williamr@4
|
74 |
this->_M_end_of_storage.deallocate(__new_start, __n)));
|
williamr@4
|
75 |
|
williamr@4
|
76 |
_STLP_STD::_Destroy(this->_M_start, this->_M_finish + 1);
|
williamr@4
|
77 |
this->_M_deallocate_block();
|
williamr@4
|
78 |
this->_M_start = __new_start;
|
williamr@4
|
79 |
this->_M_finish = __new_finish;
|
williamr@4
|
80 |
this->_M_end_of_storage._M_data = __new_start + __n;
|
williamr@4
|
81 |
}
|
williamr@4
|
82 |
}
|
williamr@4
|
83 |
|
williamr@4
|
84 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
85 |
_STLP_EXP_DECLSPEC basic_string<_CharT,_Traits,_Alloc>&
|
williamr@4
|
86 |
basic_string<_CharT,_Traits,_Alloc>::append(size_type __n, _CharT __c)
|
williamr@4
|
87 |
{
|
williamr@4
|
88 |
if (__n > max_size() || size() > max_size() - __n)
|
williamr@4
|
89 |
this->_M_throw_length_error();
|
williamr@4
|
90 |
if (size() + __n > capacity())
|
williamr@4
|
91 |
reserve(size() + (max)(size(), __n));
|
williamr@4
|
92 |
if (__n > 0) {
|
williamr@4
|
93 |
uninitialized_fill_n(this->_M_finish + 1, __n - 1, __c);
|
williamr@4
|
94 |
_STLP_TRY {
|
williamr@4
|
95 |
_M_construct_null(this->_M_finish + __n);
|
williamr@4
|
96 |
}
|
williamr@4
|
97 |
_STLP_UNWIND(_STLP_STD::_Destroy(this->_M_finish + 1, this->_M_finish + __n));
|
williamr@4
|
98 |
_Traits::assign(*end(), __c);
|
williamr@4
|
99 |
this->_M_finish += __n;
|
williamr@4
|
100 |
}
|
williamr@4
|
101 |
return *this;
|
williamr@4
|
102 |
}
|
williamr@4
|
103 |
|
williamr@4
|
104 |
#ifndef _STLP_MEMBER_TEMPLATES
|
williamr@4
|
105 |
|
williamr@4
|
106 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
107 |
_STLP_EXP_DECLSPEC basic_string<_CharT, _Traits, _Alloc>&
|
williamr@4
|
108 |
basic_string<_CharT, _Traits, _Alloc>::append(const _CharT* __first,
|
williamr@4
|
109 |
const _CharT* __last)
|
williamr@4
|
110 |
{
|
williamr@4
|
111 |
if (__first != __last) {
|
williamr@4
|
112 |
const size_type __old_size = size();
|
williamr@4
|
113 |
ptrdiff_t __n = __last - __first;
|
williamr@4
|
114 |
if ((size_type)__n > max_size() || __old_size > max_size() - __n)
|
williamr@4
|
115 |
this->_M_throw_length_error();
|
williamr@4
|
116 |
if (__old_size + __n > capacity()) {
|
williamr@4
|
117 |
const size_type __len = __old_size + (max)(__old_size, (size_t) __n) + 1;
|
williamr@4
|
118 |
pointer __new_start = this->_M_end_of_storage.allocate(__len);
|
williamr@4
|
119 |
_STLP_LEAVE_VOLATILE pointer __new_finish = __new_start;
|
williamr@4
|
120 |
_STLP_TRY {
|
williamr@4
|
121 |
__new_finish = uninitialized_copy(this->_M_start, this->_M_finish, __new_start);
|
williamr@4
|
122 |
__new_finish = uninitialized_copy(__first, __last, __new_finish);
|
williamr@4
|
123 |
_M_construct_null(__new_finish);
|
williamr@4
|
124 |
}
|
williamr@4
|
125 |
_STLP_UNWIND((_STLP_STD::_Destroy(__new_start,__new_finish),
|
williamr@4
|
126 |
this->_M_end_of_storage.deallocate(__new_start,__len)));
|
williamr@4
|
127 |
_STLP_STD::_Destroy(this->_M_start, this->_M_finish + 1);
|
williamr@4
|
128 |
this->_M_deallocate_block();
|
williamr@4
|
129 |
this->_M_start = __new_start;
|
williamr@4
|
130 |
this->_M_finish = __new_finish;
|
williamr@4
|
131 |
this->_M_end_of_storage._M_data = __new_start + __len;
|
williamr@4
|
132 |
}
|
williamr@4
|
133 |
else {
|
williamr@4
|
134 |
const _CharT* __f1 = __first;
|
williamr@4
|
135 |
++__f1;
|
williamr@4
|
136 |
uninitialized_copy(__f1, __last, this->_M_finish + 1);
|
williamr@4
|
137 |
_STLP_TRY {
|
williamr@4
|
138 |
_M_construct_null(this->_M_finish + __n);
|
williamr@4
|
139 |
}
|
williamr@4
|
140 |
_STLP_UNWIND(_STLP_STD::_Destroy(this->_M_finish + 1, this->_M_finish + __n));
|
williamr@4
|
141 |
_Traits::assign(*end(), *__first);
|
williamr@4
|
142 |
this->_M_finish += __n;
|
williamr@4
|
143 |
}
|
williamr@4
|
144 |
}
|
williamr@4
|
145 |
return *this;
|
williamr@4
|
146 |
}
|
williamr@4
|
147 |
|
williamr@4
|
148 |
#endif /* _STLP_MEMBER_TEMPLATES */
|
williamr@4
|
149 |
|
williamr@4
|
150 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
151 |
_STLP_EXP_DECLSPEC basic_string<_CharT,_Traits,_Alloc>&
|
williamr@4
|
152 |
basic_string<_CharT,_Traits,_Alloc>::assign(size_type __n, _CharT __c) {
|
williamr@4
|
153 |
if (__n <= size()) {
|
williamr@4
|
154 |
_Traits::assign(this->_M_start, __n, __c);
|
williamr@4
|
155 |
erase(begin() + __n, end());
|
williamr@4
|
156 |
}
|
williamr@4
|
157 |
else {
|
williamr@4
|
158 |
_Traits::assign(this->_M_start, size(), __c);
|
williamr@4
|
159 |
append(__n - size(), __c);
|
williamr@4
|
160 |
}
|
williamr@4
|
161 |
return *this;
|
williamr@4
|
162 |
}
|
williamr@4
|
163 |
|
williamr@4
|
164 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
165 |
_CharT* basic_string<_CharT,_Traits,_Alloc> ::_M_insert_aux(_CharT* __p,
|
williamr@4
|
166 |
_CharT __c)
|
williamr@4
|
167 |
{
|
williamr@4
|
168 |
pointer __new_pos = __p;
|
williamr@4
|
169 |
if (this->_M_finish + 1 < this->_M_end_of_storage._M_data) {
|
williamr@4
|
170 |
_M_construct_null(this->_M_finish + 1);
|
williamr@4
|
171 |
_Traits::move(__p + 1, __p, this->_M_finish - __p);
|
williamr@4
|
172 |
_Traits::assign(*__p, __c);
|
williamr@4
|
173 |
++this->_M_finish;
|
williamr@4
|
174 |
}
|
williamr@4
|
175 |
else {
|
williamr@4
|
176 |
const size_type __old_len = size();
|
williamr@4
|
177 |
const size_type __len = __old_len +
|
williamr@4
|
178 |
(max)(__old_len, __STATIC_CAST(size_type,1)) + 1;
|
williamr@4
|
179 |
pointer __new_start = this->_M_end_of_storage.allocate(__len);
|
williamr@4
|
180 |
_STLP_LEAVE_VOLATILE pointer __new_finish = __new_start;
|
williamr@4
|
181 |
_STLP_TRY {
|
williamr@4
|
182 |
__new_pos = uninitialized_copy(this->_M_start, __p, __new_start);
|
williamr@4
|
183 |
_Construct(__new_pos, __c);
|
williamr@4
|
184 |
__new_finish = __new_pos + 1;
|
williamr@4
|
185 |
__new_finish = uninitialized_copy(__p, this->_M_finish, __new_finish);
|
williamr@4
|
186 |
_M_construct_null(__new_finish);
|
williamr@4
|
187 |
}
|
williamr@4
|
188 |
_STLP_UNWIND((_STLP_STD::_Destroy(__new_start,__new_finish),
|
williamr@4
|
189 |
this->_M_end_of_storage.deallocate(__new_start,__len)));
|
williamr@4
|
190 |
_STLP_STD::_Destroy(this->_M_start, this->_M_finish + 1);
|
williamr@4
|
191 |
this->_M_deallocate_block();
|
williamr@4
|
192 |
this->_M_start = __new_start;
|
williamr@4
|
193 |
this->_M_finish = __new_finish;
|
williamr@4
|
194 |
this->_M_end_of_storage._M_data = __new_start + __len;
|
williamr@4
|
195 |
}
|
williamr@4
|
196 |
return __new_pos;
|
williamr@4
|
197 |
}
|
williamr@4
|
198 |
|
williamr@4
|
199 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
200 |
_STLP_EXP_DECLSPEC void basic_string<_CharT,_Traits,_Alloc>::insert(iterator __position,
|
williamr@4
|
201 |
size_t __n, _CharT __c)
|
williamr@4
|
202 |
{
|
williamr@4
|
203 |
if (__n != 0) {
|
williamr@4
|
204 |
if (size_type(this->_M_end_of_storage._M_data - this->_M_finish) >= __n + 1) {
|
williamr@4
|
205 |
const size_type __elems_after = this->_M_finish - __position;
|
williamr@4
|
206 |
pointer __old_finish = this->_M_finish;
|
williamr@4
|
207 |
if (__elems_after >= __n) {
|
williamr@4
|
208 |
uninitialized_copy((this->_M_finish - __n) + 1, this->_M_finish + 1,
|
williamr@4
|
209 |
this->_M_finish + 1);
|
williamr@4
|
210 |
this->_M_finish += __n;
|
williamr@4
|
211 |
_Traits::move(__position + __n,
|
williamr@4
|
212 |
__position, (__elems_after - __n) + 1);
|
williamr@4
|
213 |
_Traits::assign(__position, __n, __c);
|
williamr@4
|
214 |
}
|
williamr@4
|
215 |
else {
|
williamr@4
|
216 |
uninitialized_fill_n(this->_M_finish + 1, __n - __elems_after - 1, __c);
|
williamr@4
|
217 |
this->_M_finish += __n - __elems_after;
|
williamr@4
|
218 |
_STLP_TRY {
|
williamr@4
|
219 |
uninitialized_copy(__position, __old_finish + 1, this->_M_finish);
|
williamr@4
|
220 |
this->_M_finish += __elems_after;
|
williamr@4
|
221 |
}
|
williamr@4
|
222 |
_STLP_UNWIND((_STLP_STD::_Destroy(__old_finish + 1, this->_M_finish),
|
williamr@4
|
223 |
this->_M_finish = __old_finish));
|
williamr@4
|
224 |
_Traits::assign(__position, __elems_after + 1, __c);
|
williamr@4
|
225 |
}
|
williamr@4
|
226 |
}
|
williamr@4
|
227 |
else {
|
williamr@4
|
228 |
const size_type __old_size = size();
|
williamr@4
|
229 |
const size_type __len = __old_size + (max)(__old_size, __n) + 1;
|
williamr@4
|
230 |
pointer __new_start = this->_M_end_of_storage.allocate(__len);
|
williamr@4
|
231 |
_STLP_LEAVE_VOLATILE pointer __new_finish = __new_start;
|
williamr@4
|
232 |
_STLP_TRY {
|
williamr@4
|
233 |
__new_finish = uninitialized_copy(this->_M_start, __position, __new_start);
|
williamr@4
|
234 |
__new_finish = uninitialized_fill_n(__new_finish, __n, __c);
|
williamr@4
|
235 |
__new_finish = uninitialized_copy(__position, this->_M_finish,
|
williamr@4
|
236 |
__new_finish);
|
williamr@4
|
237 |
_M_construct_null(__new_finish);
|
williamr@4
|
238 |
}
|
williamr@4
|
239 |
_STLP_UNWIND((_STLP_STD::_Destroy(__new_start,__new_finish),
|
williamr@4
|
240 |
this->_M_end_of_storage.deallocate(__new_start,__len)));
|
williamr@4
|
241 |
_STLP_STD::_Destroy(this->_M_start, this->_M_finish + 1);
|
williamr@4
|
242 |
this->_M_deallocate_block();
|
williamr@4
|
243 |
this->_M_start = __new_start;
|
williamr@4
|
244 |
this->_M_finish = __new_finish;
|
williamr@4
|
245 |
this->_M_end_of_storage._M_data = __new_start + __len;
|
williamr@4
|
246 |
}
|
williamr@4
|
247 |
}
|
williamr@4
|
248 |
}
|
williamr@4
|
249 |
|
williamr@4
|
250 |
#ifndef _STLP_MEMBER_TEMPLATES
|
williamr@4
|
251 |
|
williamr@4
|
252 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
253 |
_STLP_EXP_DECLSPEC void
|
williamr@4
|
254 |
basic_string<_CharT,_Traits,_Alloc>::insert(iterator __position,
|
williamr@4
|
255 |
const _CharT* __first,
|
williamr@4
|
256 |
const _CharT* __last)
|
williamr@4
|
257 |
{
|
williamr@4
|
258 |
if (__first != __last) {
|
williamr@4
|
259 |
const ptrdiff_t __n = __last - __first;
|
williamr@4
|
260 |
if (this->_M_end_of_storage._M_data - this->_M_finish >= __n + 1) {
|
williamr@4
|
261 |
const ptrdiff_t __elems_after = this->_M_finish - __position;
|
williamr@4
|
262 |
pointer __old_finish = this->_M_finish;
|
williamr@4
|
263 |
if (__elems_after >= __n) {
|
williamr@4
|
264 |
uninitialized_copy((this->_M_finish - __n) + 1, this->_M_finish + 1,
|
williamr@4
|
265 |
this->_M_finish + 1);
|
williamr@4
|
266 |
this->_M_finish += __n;
|
williamr@4
|
267 |
_Traits::move(__position + __n,
|
williamr@4
|
268 |
__position, (__elems_after - __n) + 1);
|
williamr@4
|
269 |
_M_copy(__first, __last, __position);
|
williamr@4
|
270 |
}
|
williamr@4
|
271 |
else {
|
williamr@4
|
272 |
const _CharT* __mid = __first;
|
williamr@4
|
273 |
advance(__mid, __elems_after + 1);
|
williamr@4
|
274 |
uninitialized_copy(__mid, __last, this->_M_finish + 1);
|
williamr@4
|
275 |
this->_M_finish += __n - __elems_after;
|
williamr@4
|
276 |
_STLP_TRY {
|
williamr@4
|
277 |
uninitialized_copy(__position, __old_finish + 1, this->_M_finish);
|
williamr@4
|
278 |
this->_M_finish += __elems_after;
|
williamr@4
|
279 |
}
|
williamr@4
|
280 |
_STLP_UNWIND((_STLP_STD::_Destroy(__old_finish + 1, this->_M_finish),
|
williamr@4
|
281 |
this->_M_finish = __old_finish));
|
williamr@4
|
282 |
_M_copy(__first, __mid, __position);
|
williamr@4
|
283 |
}
|
williamr@4
|
284 |
}
|
williamr@4
|
285 |
else {
|
williamr@4
|
286 |
size_type __old_size = size();
|
williamr@4
|
287 |
size_type __len
|
williamr@4
|
288 |
= __old_size + (max)(__old_size, __STATIC_CAST(const size_type,__n)) + 1;
|
williamr@4
|
289 |
pointer __new_start = this->_M_end_of_storage.allocate(__len);
|
williamr@4
|
290 |
_STLP_LEAVE_VOLATILE pointer __new_finish = __new_start;
|
williamr@4
|
291 |
_STLP_TRY {
|
williamr@4
|
292 |
__new_finish = uninitialized_copy(this->_M_start, __position, __new_start);
|
williamr@4
|
293 |
__new_finish = uninitialized_copy(__first, __last, __new_finish);
|
williamr@4
|
294 |
__new_finish
|
williamr@4
|
295 |
= uninitialized_copy(__position, this->_M_finish, __new_finish);
|
williamr@4
|
296 |
_M_construct_null(__new_finish);
|
williamr@4
|
297 |
}
|
williamr@4
|
298 |
_STLP_UNWIND((_STLP_STD::_Destroy(__new_start,__new_finish),
|
williamr@4
|
299 |
this->_M_end_of_storage.deallocate(__new_start,__len)));
|
williamr@4
|
300 |
_STLP_STD::_Destroy(this->_M_start, this->_M_finish + 1);
|
williamr@4
|
301 |
this->_M_deallocate_block();
|
williamr@4
|
302 |
this->_M_start = __new_start;
|
williamr@4
|
303 |
this->_M_finish = __new_finish;
|
williamr@4
|
304 |
this->_M_end_of_storage._M_data = __new_start + __len;
|
williamr@4
|
305 |
}
|
williamr@4
|
306 |
}
|
williamr@4
|
307 |
}
|
williamr@4
|
308 |
|
williamr@4
|
309 |
#endif /* _STLP_MEMBER_TEMPLATES */
|
williamr@4
|
310 |
|
williamr@4
|
311 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
312 |
_STLP_EXP_DECLSPEC basic_string<_CharT,_Traits,_Alloc>&
|
williamr@4
|
313 |
basic_string<_CharT,_Traits,_Alloc>::replace(iterator __first, iterator __last, size_type __n, _CharT __c)
|
williamr@4
|
314 |
{
|
williamr@4
|
315 |
size_type __len = (size_type)(__last - __first);
|
williamr@4
|
316 |
|
williamr@4
|
317 |
if (__len >= __n) {
|
williamr@4
|
318 |
_Traits::assign(__first, __n, __c);
|
williamr@4
|
319 |
erase(__first + __n, __last);
|
williamr@4
|
320 |
}
|
williamr@4
|
321 |
else {
|
williamr@4
|
322 |
_Traits::assign(__first, __len, __c);
|
williamr@4
|
323 |
insert(__last, __n - __len, __c);
|
williamr@4
|
324 |
}
|
williamr@4
|
325 |
return *this;
|
williamr@4
|
326 |
}
|
williamr@4
|
327 |
|
williamr@4
|
328 |
#ifndef _STLP_MEMBER_TEMPLATES
|
williamr@4
|
329 |
|
williamr@4
|
330 |
|
williamr@4
|
331 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
332 |
_STLP_EXP_DECLSPEC basic_string<_CharT,_Traits,_Alloc>&
|
williamr@4
|
333 |
basic_string<_CharT,_Traits,_Alloc> ::replace(iterator __first, iterator __last,
|
williamr@4
|
334 |
const _CharT* __f, const _CharT* __l)
|
williamr@4
|
335 |
{
|
williamr@4
|
336 |
const ptrdiff_t __n = __l - __f;
|
williamr@4
|
337 |
const difference_type __len = __last - __first;
|
williamr@4
|
338 |
if (__len >= __n) {
|
williamr@4
|
339 |
_M_copy(__f, __l, __first);
|
williamr@4
|
340 |
erase(__first + __n, __last);
|
williamr@4
|
341 |
}
|
williamr@4
|
342 |
else {
|
williamr@4
|
343 |
const _CharT* __m = __f + __len;
|
williamr@4
|
344 |
_M_copy(__f, __m, __first);
|
williamr@4
|
345 |
insert(__last, __m, __l);
|
williamr@4
|
346 |
}
|
williamr@4
|
347 |
return *this;
|
williamr@4
|
348 |
}
|
williamr@4
|
349 |
|
williamr@4
|
350 |
#endif /* _STLP_MEMBER_TEMPLATES */
|
williamr@4
|
351 |
|
williamr@4
|
352 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
353 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
354 |
basic_string<_CharT,_Traits,_Alloc> ::find(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
355 |
{
|
williamr@4
|
356 |
#ifndef __SYMBIAN32__ // A different implementation without using search
|
williamr@4
|
357 |
if (__pos + __n > size())
|
williamr@4
|
358 |
return npos;
|
williamr@4
|
359 |
else {
|
williamr@4
|
360 |
const const_pointer __result =
|
williamr@4
|
361 |
_STLP_STD::search((const _CharT*)this->_M_start + __pos, (const _CharT*)this->_M_finish,
|
williamr@4
|
362 |
__s, __s + __n, _Eq_traits<_Traits>());
|
williamr@4
|
363 |
return __result != this->_M_finish ? __result - this->_M_start : npos;
|
williamr@4
|
364 |
}
|
williamr@4
|
365 |
#else
|
williamr@4
|
366 |
const size_type __len = this->size();
|
williamr@4
|
367 |
size_t __tpos = __pos;
|
williamr@4
|
368 |
const _CharT* __data = this->_M_start;
|
williamr@4
|
369 |
while (__tpos + __n <= __len) {
|
williamr@4
|
370 |
if (traits_type::compare(__data + __tpos, __s, __n) == 0)
|
williamr@4
|
371 |
return __tpos;
|
williamr@4
|
372 |
++__tpos;
|
williamr@4
|
373 |
}
|
williamr@4
|
374 |
return npos;
|
williamr@4
|
375 |
#endif //__SYMBIAN32__
|
williamr@4
|
376 |
}
|
williamr@4
|
377 |
|
williamr@4
|
378 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
379 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
380 |
basic_string<_CharT,_Traits,_Alloc> ::find(_CharT __c, size_type __pos) const
|
williamr@4
|
381 |
{
|
williamr@4
|
382 |
if (__pos >= size())
|
williamr@4
|
383 |
return npos;
|
williamr@4
|
384 |
else {
|
williamr@4
|
385 |
const const_pointer __result =
|
williamr@4
|
386 |
_STLP_STD::find_if((const _CharT*)this->_M_start + __pos, (const _CharT*)this->_M_finish,
|
williamr@4
|
387 |
_Eq_char_bound<_Traits>(__c));
|
williamr@4
|
388 |
return __result != this->_M_finish ? __result - this->_M_start : npos;
|
williamr@4
|
389 |
}
|
williamr@4
|
390 |
}
|
williamr@4
|
391 |
|
williamr@4
|
392 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
393 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
394 |
basic_string<_CharT,_Traits,_Alloc> ::rfind(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
395 |
{
|
williamr@4
|
396 |
const size_t __len = size();
|
williamr@4
|
397 |
|
williamr@4
|
398 |
if (__n > __len)
|
williamr@4
|
399 |
return npos;
|
williamr@4
|
400 |
else if (__n == 0)
|
williamr@4
|
401 |
return (min) (__len, __pos);
|
williamr@4
|
402 |
else {
|
williamr@4
|
403 |
const_pointer __last = this->_M_start + (min) (__len - __n, __pos) + __n;
|
williamr@4
|
404 |
const_pointer __result = _STLP_STD::find_end((const_pointer)this->_M_start, __last,
|
williamr@4
|
405 |
__s, __s + __n,
|
williamr@4
|
406 |
_Eq_traits<_Traits>());
|
williamr@4
|
407 |
return __result != __last ? __result - this->_M_start : npos;
|
williamr@4
|
408 |
}
|
williamr@4
|
409 |
}
|
williamr@4
|
410 |
|
williamr@4
|
411 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
412 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
413 |
basic_string<_CharT,_Traits,_Alloc> ::rfind(_CharT __c, size_type __pos) const
|
williamr@4
|
414 |
{
|
williamr@4
|
415 |
const size_type __len = size();
|
williamr@4
|
416 |
|
williamr@4
|
417 |
if (__len < 1)
|
williamr@4
|
418 |
return npos;
|
williamr@4
|
419 |
else {
|
williamr@4
|
420 |
const const_iterator __last = begin() + (min) (__len - 1, __pos) + 1;
|
williamr@4
|
421 |
const_reverse_iterator __rresult =
|
williamr@4
|
422 |
_STLP_STD::find_if(const_reverse_iterator(__last), rend(),
|
williamr@4
|
423 |
_Eq_char_bound<_Traits>(__c));
|
williamr@4
|
424 |
return __rresult != rend() ? (__rresult.base() - 1) - begin() : npos;
|
williamr@4
|
425 |
}
|
williamr@4
|
426 |
}
|
williamr@4
|
427 |
|
williamr@4
|
428 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
429 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
430 |
basic_string<_CharT,_Traits,_Alloc>
|
williamr@4
|
431 |
::find_first_of(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
432 |
{
|
williamr@4
|
433 |
if (__pos >= size())
|
williamr@4
|
434 |
return npos;
|
williamr@4
|
435 |
else {
|
williamr@4
|
436 |
const_iterator __result = __find_first_of(begin() + __pos, end(),
|
williamr@4
|
437 |
__s, __s + __n,
|
williamr@4
|
438 |
_Eq_traits<_Traits>());
|
williamr@4
|
439 |
return __result != end() ? __result - begin() : npos;
|
williamr@4
|
440 |
}
|
williamr@4
|
441 |
}
|
williamr@4
|
442 |
|
williamr@4
|
443 |
|
williamr@4
|
444 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
445 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
446 |
basic_string<_CharT,_Traits,_Alloc>
|
williamr@4
|
447 |
::find_last_of(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
448 |
{
|
williamr@4
|
449 |
const size_type __len = size();
|
williamr@4
|
450 |
|
williamr@4
|
451 |
if (__len < 1)
|
williamr@4
|
452 |
return npos;
|
williamr@4
|
453 |
else {
|
williamr@4
|
454 |
const const_iterator __last = begin() + (min) (__len - 1, __pos) + 1;
|
williamr@4
|
455 |
const const_reverse_iterator __rresult =
|
williamr@4
|
456 |
__find_first_of(const_reverse_iterator(__last), rend(),
|
williamr@4
|
457 |
__s, __s + __n,
|
williamr@4
|
458 |
_Eq_traits<_Traits>());
|
williamr@4
|
459 |
return __rresult != rend() ? (__rresult.base() - 1) - begin() : npos;
|
williamr@4
|
460 |
}
|
williamr@4
|
461 |
}
|
williamr@4
|
462 |
|
williamr@4
|
463 |
|
williamr@4
|
464 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
465 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
466 |
basic_string<_CharT,_Traits,_Alloc> ::find_first_not_of(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
467 |
{
|
williamr@4
|
468 |
typedef typename _Traits::char_type _CharType;
|
williamr@4
|
469 |
if (__pos > size())
|
williamr@4
|
470 |
return npos;
|
williamr@4
|
471 |
else {
|
williamr@4
|
472 |
const_pointer __result = _STLP_STD::find_if((const _CharT*)this->_M_start + __pos,
|
williamr@4
|
473 |
(const _CharT*)this->_M_finish,
|
williamr@4
|
474 |
_Not_within_traits<_Traits>((const _CharType*)__s,
|
williamr@4
|
475 |
(const _CharType*)__s + __n));
|
williamr@4
|
476 |
return __result != this->_M_finish ? __result - this->_M_start : npos;
|
williamr@4
|
477 |
}
|
williamr@4
|
478 |
}
|
williamr@4
|
479 |
|
williamr@4
|
480 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
481 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
482 |
basic_string<_CharT,_Traits,_Alloc> ::find_first_not_of(_CharT __c, size_type __pos) const
|
williamr@4
|
483 |
{
|
williamr@4
|
484 |
if (__pos > size())
|
williamr@4
|
485 |
return npos;
|
williamr@4
|
486 |
else {
|
williamr@4
|
487 |
const_pointer __result = _STLP_STD::find_if((const _CharT*)this->_M_start + __pos, (const _CharT*)this->_M_finish,
|
williamr@4
|
488 |
_Neq_char_bound<_Traits>(__c));
|
williamr@4
|
489 |
return __result != this->_M_finish ? __result - this->_M_start : npos;
|
williamr@4
|
490 |
}
|
williamr@4
|
491 |
}
|
williamr@4
|
492 |
|
williamr@4
|
493 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
494 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
495 |
basic_string<_CharT,_Traits,_Alloc> ::find_last_not_of(const _CharT* __s, size_type __pos, size_type __n) const
|
williamr@4
|
496 |
{
|
williamr@4
|
497 |
typedef typename _Traits::char_type _CharType;
|
williamr@4
|
498 |
const size_type __len = size();
|
williamr@4
|
499 |
|
williamr@4
|
500 |
if (__len < 1)
|
williamr@4
|
501 |
return npos;
|
williamr@4
|
502 |
else {
|
williamr@4
|
503 |
const_iterator __last = begin() + (min) (__len - 1, __pos) + 1;
|
williamr@4
|
504 |
const_reverse_iterator __rlast = const_reverse_iterator(__last);
|
williamr@4
|
505 |
const_reverse_iterator __rresult =
|
williamr@4
|
506 |
_STLP_STD::find_if(__rlast, rend(),
|
williamr@4
|
507 |
_Not_within_traits<_Traits>((const _CharType*)__s,
|
williamr@4
|
508 |
(const _CharType*)__s + __n));
|
williamr@4
|
509 |
return __rresult != rend() ? (__rresult.base() - 1) - begin() : npos;
|
williamr@4
|
510 |
}
|
williamr@4
|
511 |
}
|
williamr@4
|
512 |
|
williamr@4
|
513 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
514 |
_STLP_EXP_DECLSPEC __size_type__
|
williamr@4
|
515 |
basic_string<_CharT, _Traits, _Alloc> ::find_last_not_of(_CharT __c, size_type __pos) const
|
williamr@4
|
516 |
{
|
williamr@4
|
517 |
const size_type __len = size();
|
williamr@4
|
518 |
|
williamr@4
|
519 |
if (__len < 1)
|
williamr@4
|
520 |
return npos;
|
williamr@4
|
521 |
else {
|
williamr@4
|
522 |
const_iterator __last = begin() + (min) (__len - 1, __pos) + 1;
|
williamr@4
|
523 |
const_reverse_iterator __rlast = const_reverse_iterator(__last);
|
williamr@4
|
524 |
const_reverse_iterator __rresult =
|
williamr@4
|
525 |
_STLP_STD::find_if(__rlast, rend(),
|
williamr@4
|
526 |
_Neq_char_bound<_Traits>(__c));
|
williamr@4
|
527 |
return __rresult != rend() ? (__rresult.base() - 1) - begin() : npos;
|
williamr@4
|
528 |
}
|
williamr@4
|
529 |
}
|
williamr@4
|
530 |
|
williamr@4
|
531 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
532 |
void _STLP_CALL _S_string_copy(const basic_string<_CharT,_Traits,_Alloc>& __s,
|
williamr@4
|
533 |
_CharT* __buf,
|
williamr@4
|
534 |
size_t __n)
|
williamr@4
|
535 |
{
|
williamr@4
|
536 |
if (__n > 0) {
|
williamr@4
|
537 |
__n = (min) (__n - 1, __s.size());
|
williamr@4
|
538 |
_STLP_STD::copy(__s.begin(), __s.begin() + __n, __buf);
|
williamr@4
|
539 |
__buf[__n] = _CharT();
|
williamr@4
|
540 |
}
|
williamr@4
|
541 |
}
|
williamr@4
|
542 |
_STLP_END_NAMESPACE
|
williamr@4
|
543 |
|
williamr@4
|
544 |
// _string_fwd has to see clean basic_string
|
williamr@4
|
545 |
# undef basic_string
|
williamr@4
|
546 |
|
williamr@4
|
547 |
# if !defined (_STLP_LINK_TIME_INSTANTIATION)
|
williamr@4
|
548 |
# include <stl/_string_fwd.c>
|
williamr@4
|
549 |
# endif
|
williamr@4
|
550 |
|
williamr@4
|
551 |
# ifdef _STLP_DEBUG
|
williamr@4
|
552 |
# define basic_string _Nondebug_string
|
williamr@4
|
553 |
# endif
|
williamr@4
|
554 |
|
williamr@4
|
555 |
# include <stl/_range_errors.h>
|
williamr@4
|
556 |
_STLP_BEGIN_NAMESPACE
|
williamr@4
|
557 |
|
williamr@4
|
558 |
// _String_base methods
|
williamr@4
|
559 |
template <class _Tp, class _Alloc>
|
williamr@4
|
560 |
void _String_base<_Tp,_Alloc>::_M_throw_length_error() const {
|
williamr@4
|
561 |
__stl_throw_length_error("basic_string");
|
williamr@4
|
562 |
}
|
williamr@4
|
563 |
|
williamr@4
|
564 |
template <class _Tp, class _Alloc>
|
williamr@4
|
565 |
void _String_base<_Tp, _Alloc>::_M_throw_out_of_range() const {
|
williamr@4
|
566 |
__stl_throw_out_of_range("basic_string");
|
williamr@4
|
567 |
}
|
williamr@4
|
568 |
|
williamr@4
|
569 |
template <class _Tp, class _Alloc>
|
williamr@4
|
570 |
void _String_base<_Tp, _Alloc>::_M_allocate_block(size_t __n) {
|
williamr@4
|
571 |
if ((__n <= (max_size()+1)) && (__n>0)){
|
williamr@4
|
572 |
_M_start = _M_end_of_storage.allocate(__n);
|
williamr@4
|
573 |
_M_finish = _M_start;
|
williamr@4
|
574 |
_M_end_of_storage._M_data = _M_start + __n;
|
williamr@4
|
575 |
}
|
williamr@4
|
576 |
else
|
williamr@4
|
577 |
_M_throw_length_error();
|
williamr@4
|
578 |
}
|
williamr@4
|
579 |
|
williamr@4
|
580 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
581 |
_STLP_EXP_DECLSPEC basic_string<_CharT, _Traits, _Alloc>::basic_string()
|
williamr@4
|
582 |
: _String_base<_CharT,_Alloc>(allocator_type())
|
williamr@4
|
583 |
{
|
williamr@4
|
584 |
this->_M_start = this->_M_end_of_storage.allocate(8);
|
williamr@4
|
585 |
this->_M_finish = this->_M_start;
|
williamr@4
|
586 |
this->_M_end_of_storage._M_data = this->_M_start + 8;
|
williamr@4
|
587 |
_M_terminate_string();
|
williamr@4
|
588 |
_STLP_POP_CLEANUP_ITEM
|
williamr@4
|
589 |
}
|
williamr@4
|
590 |
|
williamr@4
|
591 |
|
williamr@4
|
592 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
593 |
_STLP_EXP_DECLSPEC basic_string<_CharT, _Traits, _Alloc>::basic_string(const _CharT* __s,
|
williamr@4
|
594 |
const allocator_type& __a)
|
williamr@4
|
595 |
: _String_base<_CharT,_Alloc>(__a)
|
williamr@4
|
596 |
{
|
williamr@4
|
597 |
_STLP_FIX_LITERAL_BUG(__s)
|
williamr@4
|
598 |
_M_range_initialize(__s, __s + traits_type::length(__s));
|
williamr@4
|
599 |
_STLP_POP_CLEANUP_ITEM
|
williamr@4
|
600 |
}
|
williamr@4
|
601 |
|
williamr@4
|
602 |
|
williamr@4
|
603 |
template <class _CharT, class _Traits, class _Alloc>
|
williamr@4
|
604 |
_STLP_EXP_DECLSPEC basic_string<_CharT, _Traits, _Alloc>::basic_string(const basic_string<_CharT, _Traits, _Alloc> & __s)
|
williamr@4
|
605 |
: _String_base<_CharT,_Alloc>(__s.get_allocator())
|
williamr@4
|
606 |
{
|
williamr@4
|
607 |
_M_range_initialize(__s._M_start, __s._M_finish);
|
williamr@4
|
608 |
_STLP_POP_CLEANUP_ITEM
|
williamr@4
|
609 |
}
|
williamr@4
|
610 |
|
williamr@4
|
611 |
# if defined ( __SUNPRO_CC) && ! defined(_STLP_STATIC_CONST_INIT_BUG)
|
williamr@4
|
612 |
template <class _CharT, class _Traits, class _Alloc> const size_t basic_string<_CharT, _Traits, _Alloc>::npos;
|
williamr@4
|
613 |
# endif
|
williamr@4
|
614 |
|
williamr@4
|
615 |
_STLP_END_NAMESPACE
|
williamr@4
|
616 |
|
williamr@4
|
617 |
# undef basic_string
|
williamr@4
|
618 |
# undef __size_type__
|
williamr@4
|
619 |
# undef size_type
|
williamr@4
|
620 |
# undef iterator
|
williamr@4
|
621 |
# endif /* NATIVE */
|
williamr@4
|
622 |
|
williamr@4
|
623 |
#endif /* _STLP_STRING_C */
|
williamr@4
|
624 |
|
williamr@4
|
625 |
// Local Variables:
|
williamr@4
|
626 |
// mode:C++
|
williamr@4
|
627 |
// End:
|