2 * Copyright 2010 Piotr Caban for CodeWeavers
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Lesser General Public
6 * License as published by the Free Software Foundation; either
7 * version 2.1 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Lesser General Public License for more details.
14 * You should have received a copy of the GNU Lesser General Public
15 * License along with this library; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
28 #include "wine/debug.h"
29 WINE_DEFAULT_DEBUG_CHANNEL(msvcp90);
31 /* char_traits<char> */
32 /* ?assign@?$char_traits@D@std@@SAXAADABD@Z */
33 /* ?assign@?$char_traits@D@std@@SAXAEADAEBD@Z */
34 void CDECL MSVCP_char_traits_char_assign(char *ch, const char *assign)
39 /* ?eq@?$char_traits@D@std@@SA_NABD0@Z */
40 /* ?eq@?$char_traits@D@std@@SA_NAEBD0@Z */
41 MSVCP_BOOL CDECL MSVCP_char_traits_char_eq(const char *ch1, const char *ch2)
46 /* ?lt@?$char_traits@D@std@@SA_NABD0@Z */
47 /* ?lt@?$char_traits@D@std@@SA_NAEBD0@Z */
48 MSVCP_BOOL CDECL MSVCP_char_traits_lt(const char *ch1, const char *ch2)
53 /* ?compare@?$char_traits@D@std@@SAHPBD0I@Z */
54 /* ?compare@?$char_traits@D@std@@SAHPEBD0_K@Z */
55 int CDECL MSVCP_char_traits_char_compare(
56 const char *s1, const char *s2, size_t count)
58 int ret = memcmp(s1, s2, count);
59 return (ret>0 ? 1 : (ret<0 ? -1 : 0));
62 /* ?length@?$char_traits@D@std@@SAIPBD@Z */
63 /* ?length@?$char_traits@D@std@@SA_KPEBD@Z */
64 size_t CDECL MSVCP_char_traits_char_length(const char *str)
69 /* ?_Copy_s@?$char_traits@D@std@@SAPADPADIPBDI@Z */
70 /* ?_Copy_s@?$char_traits@D@std@@SAPEADPEAD_KPEBD1@Z */
71 char* CDECL MSVCP_char_traits_char__Copy_s(char *dest,
72 size_t size, const char *src, size_t count)
74 if(!dest || !src || size<count) {
77 _invalid_parameter(NULL, NULL, NULL, 0, 0);
81 return memcpy(dest, src, count);
84 /* ?copy@?$char_traits@D@std@@SAPADPADPBDI@Z */
85 /* ?copy@?$char_traits@D@std@@SAPEADPEADPEBD_K@Z */
86 char* CDECL MSVCP_char_traits_char_copy(
87 char *dest, const char *src, size_t count)
89 return MSVCP_char_traits_char__Copy_s(dest, count, src, count);
92 /* ?find@?$char_traits@D@std@@SAPBDPBDIABD@Z */
93 /* ?find@?$char_traits@D@std@@SAPEBDPEBD_KAEBD@Z */
94 const char * CDECL MSVCP_char_traits_char_find(
95 const char *str, size_t range, const char *c)
97 return memchr(str, *c, range);
100 /* ?_Move_s@?$char_traits@D@std@@SAPADPADIPBDI@Z */
101 /* ?_Move_s@?$char_traits@D@std@@SAPEADPEAD_KPEBD1@Z */
102 char* CDECL MSVCP_char_traits_char__Move_s(char *dest,
103 size_t size, const char *src, size_t count)
105 if(!dest || !src || size<count) {
108 _invalid_parameter(NULL, NULL, NULL, 0, 0);
112 return memmove(dest, src, count);
115 /* ?move@?$char_traits@D@std@@SAPADPADPBDI@Z */
116 /* ?move@?$char_traits@D@std@@SAPEADPEADPEBD_K@Z */
117 char* CDECL MSVCP_char_traits_char_move(
118 char *dest, const char *src, size_t count)
120 return MSVCP_char_traits_char__Move_s(dest, count, src, count);
123 /* ?assign@?$char_traits@D@std@@SAPADPADID@Z */
124 /* ?assign@?$char_traits@D@std@@SAPEADPEAD_KD@Z */
125 char* CDECL MSVCP_char_traits_char_assignn(char *str, size_t num, char c)
127 return memset(str, c, num);
130 /* ?to_char_type@?$char_traits@D@std@@SADABH@Z */
131 /* ?to_char_type@?$char_traits@D@std@@SADAEBH@Z */
132 char CDECL MSVCP_char_traits_char_to_char_type(const int *i)
137 /* ?to_int_type@?$char_traits@D@std@@SAHABD@Z */
138 /* ?to_int_type@?$char_traits@D@std@@SAHAEBD@Z */
139 int CDECL MSVCP_char_traits_char_to_int_type(const char *ch)
144 /* ?eq_int_type@?$char_traits@D@std@@SA_NABH0@Z */
145 /* ?eq_int_type@?$char_traits@D@std@@SA_NAEBH0@Z */
146 MSVCP_BOOL CDECL MSVCP_char_traits_char_eq_int_type(const int *i1, const int *i2)
151 /* ?eof@?$char_traits@D@std@@SAHXZ */
152 int CDECL MSVCP_char_traits_char_eof(void)
157 /* ?not_eof@?$char_traits@D@std@@SAHABH@Z */
158 /* ?not_eof@?$char_traits@D@std@@SAHAEBH@Z */
159 int CDECL MSVCP_char_traits_char_not_eof(int *in)
161 return (*in==EOF ? !EOF : *in);
165 /* char_traits<wchar_t> */
166 /* ?assign@?$char_traits@_W@std@@SAXAA_WAB_W@Z */
167 /* ?assign@?$char_traits@_W@std@@SAXAEA_WAEB_W@Z */
168 void CDECL MSVCP_char_traits_wchar_assign(wchar_t *ch,
169 const wchar_t *assign)
174 /* ?eq@?$char_traits@_W@std@@SA_NAB_W0@Z */
175 /* ?eq@?$char_traits@_W@std@@SA_NAEB_W0@Z */
176 MSVCP_BOOL CDECL MSVCP_char_traits_wchar_eq(wchar_t *ch1, wchar_t *ch2)
181 /* ?lt@?$char_traits@_W@std@@SA_NAB_W0@Z */
182 /* ?lt@?$char_traits@_W@std@@SA_NAEB_W0@Z */
183 MSVCP_BOOL CDECL MSVCP_char_traits_wchar_lt(const wchar_t *ch1,
189 /* ?compare@?$char_traits@_W@std@@SAHPB_W0I@Z */
190 /* ?compare@?$char_traits@_W@std@@SAHPEB_W0_K@Z */
191 int CDECL MSVCP_char_traits_wchar_compare(const wchar_t *s1,
192 const wchar_t *s2, size_t count)
194 int ret = memcmp(s1, s2, sizeof(wchar_t[count]));
195 return (ret>0 ? 1 : (ret<0 ? -1 : 0));
198 /* ?length@?$char_traits@_W@std@@SAIPB_W@Z */
199 /* ?length@?$char_traits@_W@std@@SA_KPEB_W@Z */
200 size_t CDECL MSVCP_char_traits_wchar_length(const wchar_t *str)
202 return wcslen((WCHAR*)str);
205 /* ?_Copy_s@?$char_traits@_W@std@@SAPA_WPA_WIPB_WI@Z */
206 /* ?_Copy_s@?$char_traits@_W@std@@SAPEA_WPEA_W_KPEB_W1@Z */
207 wchar_t* CDECL MSVCP_char_traits_wchar__Copy_s(wchar_t *dest,
208 size_t size, const wchar_t *src, size_t count)
210 if(!dest || !src || size<count) {
213 _invalid_parameter(NULL, NULL, NULL, 0, 0);
217 return memcpy(dest, src, sizeof(wchar_t[count]));
220 /* ?copy@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
221 /* ?copy@?$char_traits@_W@std@@SAPEA_WPEA_WPEB_W_K@Z */
222 wchar_t* CDECL MSVCP_char_traits_wchar_copy(wchar_t *dest,
223 const wchar_t *src, size_t count)
225 return MSVCP_char_traits_wchar__Copy_s(dest, count, src, count);
228 /* ?find@?$char_traits@_W@std@@SAPB_WPB_WIAB_W@Z */
229 /* ?find@?$char_traits@_W@std@@SAPEB_WPEB_W_KAEB_W@Z */
230 const wchar_t* CDECL MSVCP_char_traits_wchar_find(
231 const wchar_t *str, size_t range, const wchar_t *c)
235 for(i=0; i<range; i++)
242 /* ?_Move_s@?$char_traits@_W@std@@SAPA_WPA_WIPB_WI@Z */
243 /* ?_Move_s@?$char_traits@_W@std@@SAPEA_WPEA_W_KPEB_W1@Z */
244 wchar_t* CDECL MSVCP_char_traits_wchar__Move_s(wchar_t *dest,
245 size_t size, const wchar_t *src, size_t count)
247 if(!dest || !src || size<count) {
250 _invalid_parameter(NULL, NULL, NULL, 0, 0);
254 return memmove(dest, src, sizeof(WCHAR[count]));
257 /* ?move@?$char_traits@_W@std@@SAPA_WPA_WPB_WI@Z */
258 /* ?move@?$char_traits@_W@std@@SAPEA_WPEA_WPEB_W_K@Z */
259 wchar_t* CDECL MSVCP_char_traits_wchar_move(wchar_t *dest,
260 const wchar_t *src, size_t count)
262 return MSVCP_char_traits_wchar__Move_s(dest, count, src, count);
265 /* ?assign@?$char_traits@_W@std@@SAPA_WPA_WI_W@Z */
266 /* ?assign@?$char_traits@_W@std@@SAPEA_WPEA_W_K_W@Z */
267 wchar_t* CDECL MSVCP_char_traits_wchar_assignn(wchar_t *str,
268 size_t num, wchar_t c)
278 /* ?to_char_type@?$char_traits@_W@std@@SA_WABG@Z */
279 /* ?to_char_type@?$char_traits@_W@std@@SA_WAEBG@Z */
280 wchar_t CDECL MSVCP_char_traits_wchar_to_char_type(const unsigned short *i)
285 /* ?to_int_type@?$char_traits@_W@std@@SAGAB_W@Z */
286 /* ?to_int_type@?$char_traits@_W@std@@SAGAEB_W@Z */
287 unsigned short CDECL MSVCP_char_traits_wchar_to_int_type(const wchar_t *ch)
292 /* ?eq_int_type@?$char_traits@_W@std@@SA_NABG0@Z */
293 /* ?eq_int_type@?$char_traits@_W@std@@SA_NAEBG0@Z */
294 MSVCP_BOOL CDECL MSVCP_char_traits_wchar_eq_int_tpe(const unsigned short *i1,
295 const unsigned short *i2)
300 /* ?eof@?$char_traits@_W@std@@SAGXZ */
301 unsigned short CDECL MSVCP_char_traits_wchar_eof(void)
306 /* ?not_eof@?$char_traits@_W@std@@SAGABG@Z */
307 /* ?not_eof@?$char_traits@_W@std@@SAGAEBG@Z */
308 unsigned short CDECL MSVCP_char_traits_wchar_not_eof(const unsigned short *in)
310 return (*in==WEOF ? !WEOF : *in);
314 /* char_traits<unsigned short> */
315 /* ?assign@?$char_traits@G@std@@SAXAAGABG@Z */
316 /* ?assign@?$char_traits@G@std@@SAXAEAGAEBG@Z */
317 void CDECL MSVCP_char_traits_short_assign(unsigned short *ch,
318 const unsigned short *assign)
323 /* ?eq@?$char_traits@G@std@@SA_NABG0@Z */
324 /* ?eq@?$char_traits@G@std@@SA_NAEBG0@Z */
325 MSVCP_BOOL CDECL MSVCP_char_traits_short_eq(const unsigned short *ch1,
326 const unsigned short *ch2)
331 /* ?lt@?$char_traits@G@std@@SA_NABG0@Z */
332 /* ?lt@?$char_traits@G@std@@SA_NAEBG0@Z */
333 MSVCP_BOOL CDECL MSVCP_char_traits_short_lt(const unsigned short *ch1,
334 const unsigned short *ch2)
339 /* ?compare@?$char_traits@G@std@@SAHPBG0I@Z */
340 /* ?compare@?$char_traits@G@std@@SAHPEBG0_K@Z */
341 int CDECL MSVCP_char_traits_short_compare(const unsigned short *s1,
342 const unsigned short *s2, size_t count)
346 for(i=0; i<count; i++)
348 return (s1[i] < s2[i] ? -1 : 1);
353 /* ?length@?$char_traits@G@std@@SAIPBG@Z */
354 /* ?length@?$char_traits@G@std@@SA_KPEBG@Z */
355 size_t CDECL MSVCP_char_traits_short_length(const unsigned short *str)
359 for(len=0; str[len]; len++);
364 /* ?_Copy_s@?$char_traits@G@std@@SAPAGPAGIPBGI@Z */
365 /* ?_Copy_s@?$char_traits@G@std@@SAPEAGPEAG_KPEBG1@Z */
366 unsigned short * CDECL MSVCP_char_traits_short__Copy_s(unsigned short *dest,
367 size_t size, const unsigned short *src, size_t count)
370 _invalid_parameter(NULL, NULL, NULL, 0, 0);
374 return memcpy(dest, src, sizeof(unsigned short[count]));
377 /* ?copy@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
378 /* ?copy@?$char_traits@G@std@@SAPEAGPEAGPEBG_K@Z */
379 unsigned short* CDECL MSVCP_char_traits_short_copy(unsigned short *dest,
380 const unsigned short *src, size_t count)
382 return MSVCP_char_traits_short__Copy_s(dest, count, src, count);
385 /* ?find@?$char_traits@G@std@@SAPBGPBGIABG@Z */
386 /* ?find@?$char_traits@G@std@@SAPEBGPEBG_KAEBG@Z */
387 const unsigned short* CDECL MSVCP_char_traits_short_find(
388 const unsigned short *str, size_t range, const unsigned short *c)
392 for(i=0; i<range; i++)
399 /* ?_Move_s@?$char_traits@G@std@@SAPAGPAGIPBGI@Z */
400 /* ?_Move_s@?$char_traits@G@std@@SAPEAGPEAG_KPEBG1@Z */
401 unsigned short* CDECL MSVCP_char_traits_short__Move_s(unsigned short *dest,
402 size_t size, const unsigned short *src, size_t count)
405 _invalid_parameter(NULL, NULL, NULL, 0, 0);
409 return memmove(dest, src, sizeof(unsigned short[count]));
412 /* ?move@?$char_traits@G@std@@SAPAGPAGPBGI@Z */
413 /* ?move@?$char_traits@G@std@@SAPEAGPEAGPEBG_K@Z */
414 unsigned short* CDECL MSVCP_char_traits_short_move(unsigned short *dest,
415 const unsigned short *src, size_t count)
417 return MSVCP_char_traits_short__Move_s(dest, count, src, count);
420 /* ?assign@?$char_traits@G@std@@SAPAGPAGIG@Z */
421 /* ?assign@?$char_traits@G@std@@SAPEAGPEAG_KG@Z */
422 unsigned short* CDECL MSVCP_char_traits_short_assignn(unsigned short *str,
423 size_t num, unsigned short c)
433 /* ?to_char_type@?$char_traits@G@std@@SAGABG@Z */
434 /* ?to_char_type@?$char_traits@G@std@@SAGAEBG@Z */
435 unsigned short CDECL MSVCP_char_traits_short_to_char_type(const unsigned short *i)
440 /* ?to_int_type@?$char_traits@G@std@@SAGABG@Z */
441 /* ?to_int_type@?$char_traits@G@std@@SAGAEBG@Z */
442 unsigned short CDECL MSVCP_char_traits_short_to_int_type(const unsigned short *ch)
447 /* ?eq_int_type@?$char_traits@G@std@@SA_NABG0@Z */
448 /* ?eq_int_type@?$char_traits@G@std@@SA_NAEBG0@Z */
449 MSVCP_BOOL CDECL MSVCP_char_traits_short_eq_int_type(unsigned short *i1,
455 /* ?eof@?$char_traits@G@std@@SAGXZ */
456 unsigned short CDECL MSVCP_char_traits_short_eof(void)
461 /* ?not_eof@?$char_traits@G@std@@SAGABG@Z */
462 /* ?not_eof@?$char_traits@G@std@@SAGAEBG@Z */
463 unsigned short CDECL MSVCP_char_traits_short_not_eof(const unsigned short *in)
465 return (*in==(unsigned short)-1 ? 0 : *in);
470 /* ?_Xlen@_String_base@std@@SAXXZ */
471 void CDECL MSVCP__String_base_Xlen(void)
473 static const char msg[] = "string too long";
476 throw_exception(EXCEPTION_LENGTH_ERROR, msg);
479 /* ?_Xran@_String_base@std@@SAXXZ */
480 void CDECL MSVCP__String_base_Xran(void)
482 static const char msg[] = "invalid string position";
485 throw_exception(EXCEPTION_OUT_OF_RANGE, msg);
488 /* ?_Xinvarg@_String_base@std@@SAXXZ */
489 void CDECL MSVCP__String_base_Xinvarg(void)
491 static const char msg[] = "invalid string argument";
494 throw_exception(EXCEPTION_INVALID_ARGUMENT, msg);
498 /* basic_string<char, char_traits<char>, allocator<char>> */
499 /* ?npos@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@2IB */
500 /* ?npos@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@2_KB */
501 const size_t MSVCP_basic_string_char_npos = -1;
503 /* Internal: basic_string_char_ptr - return pointer to stored string */
504 static char* basic_string_char_ptr(basic_string_char *this)
506 if(this->res == BUF_SIZE_CHAR-1)
507 return this->data.buf;
508 return this->data.ptr;
511 /* Internal: basic_string_char_const_ptr - returns const pointer to stored string */
512 static const char* basic_string_char_const_ptr(const basic_string_char *this)
514 if(this->res == BUF_SIZE_CHAR-1)
515 return this->data.buf;
516 return this->data.ptr;
519 /* Internal: basic_string_char_eos - sets string length, puts '\0' on the end */
520 static void basic_string_char_eos(basic_string_char *this, size_t len)
522 static const char nullbyte = '\0';
525 MSVCP_char_traits_char_assign(basic_string_char_ptr(this)+len, &nullbyte);
528 /* Internal: basic_string_char_inside - checks if given pointer points inside stored string */
529 static MSVCP_BOOL basic_string_char_inside(
530 basic_string_char *this, const char *ptr)
532 char *cstr = basic_string_char_ptr(this);
534 return (ptr<cstr || ptr>=cstr+this->size) ? FALSE : TRUE;
537 /* Internal: basic_string_char_tidy - initialize basic_string buffer, deallocates data */
538 /* Caution: new_size have to be smaller than BUF_SIZE_CHAR */
539 static void basic_string_char_tidy(basic_string_char *this,
540 MSVCP_BOOL built, size_t new_size)
542 if(built && BUF_SIZE_CHAR<=this->res) {
543 char *ptr = this->data.ptr;
546 MSVCP_char_traits_char__Copy_s(this->data.buf, BUF_SIZE_CHAR, ptr, new_size);
547 MSVCP_allocator_char_deallocate(this->allocator, ptr, this->res+1);
550 this->res = BUF_SIZE_CHAR-1;
551 basic_string_char_eos(this, new_size);
554 /* Internal: basic_string_char_grow - changes size of internal buffer */
555 static MSVCP_BOOL basic_string_char_grow(
556 basic_string_char *this, size_t new_size, MSVCP_BOOL trim)
558 if(this->res < new_size) {
559 size_t new_res = new_size;
564 if(new_res/3 < this->res/2)
565 new_res = this->res + this->res/2;
567 ptr = MSVCP_allocator_char_allocate(this->allocator, new_res);
569 ptr = MSVCP_allocator_char_allocate(this->allocator, new_size+1);
573 ERR("Out of memory\n");
574 basic_string_char_tidy(this, TRUE, 0);
578 MSVCP_char_traits_char__Copy_s(ptr, new_size,
579 basic_string_char_ptr(this), this->size);
580 basic_string_char_tidy(this, TRUE, 0);
581 this->data.ptr = ptr;
582 this->res = new_size;
583 basic_string_char_eos(this, this->size);
584 } else if(trim && new_size < BUF_SIZE_CHAR)
585 basic_string_char_tidy(this, TRUE,
586 new_size<this->size ? new_size : this->size);
587 else if(new_size == 0)
588 basic_string_char_eos(this, 0);
593 /* ?erase@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAEAAV12@II@Z */
594 /* ?erase@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAAAEAV12@_K0@Z */
595 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_erase, 12)
596 basic_string_char* __thiscall MSVCP_basic_string_char_erase(
597 basic_string_char *this, size_t pos, size_t len)
599 TRACE("%p %lu %lu\n", this, (unsigned long)pos, (unsigned long)len);
601 if(pos > this->size) {
602 MSVCP__String_base_Xran();
606 if(len > this->size-pos)
607 len = this->size-pos;
610 MSVCP_char_traits_char__Move_s(basic_string_char_ptr(this)+pos,
611 this->res-pos, basic_string_char_ptr(this)+pos+len,
613 basic_string_char_eos(this, this->size-len);
619 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAEAAV12@ABV12@II@Z */
620 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAAAEAV12@AEBV12@_K1@Z */
621 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_assign_substr, 16)
622 basic_string_char* __thiscall MSVCP_basic_string_char_assign_substr(
623 basic_string_char *this, const basic_string_char *assign,
624 size_t pos, size_t len)
626 TRACE("%p %p %lu %lu\n", this, assign, (unsigned long)pos, (unsigned long)len);
628 if(assign->size < pos) {
629 MSVCP__String_base_Xran();
633 if(len > assign->size-pos)
634 len = assign->size-pos;
637 MSVCP_basic_string_char_erase(this, pos+len, MSVCP_basic_string_char_npos);
638 MSVCP_basic_string_char_erase(this, 0, pos);
639 } else if(basic_string_char_grow(this, len, FALSE)) {
640 MSVCP_char_traits_char__Copy_s(basic_string_char_ptr(this),
641 this->res, basic_string_char_const_ptr(assign)+pos, len);
642 basic_string_char_eos(this, len);
648 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAEAAV12@ABV12@@Z */
649 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAAAEAV12@AEBV12@@Z */
650 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_assign, 8)
651 basic_string_char* __thiscall MSVCP_basic_string_char_assign(
652 basic_string_char *this, const basic_string_char *assign)
654 return MSVCP_basic_string_char_assign_substr(this, assign,
655 0, MSVCP_basic_string_char_npos);
658 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAEAAV12@PBDI@Z */
659 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAAAEAV12@PEBD_K@Z */
660 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_assign_cstr_len, 12)
661 basic_string_char* __thiscall MSVCP_basic_string_char_assign_cstr_len(
662 basic_string_char *this, const char *str, size_t len)
664 TRACE("%p %s %lu\n", this, debugstr_a(str), (unsigned long)len);
666 if(basic_string_char_inside(this, str))
667 return MSVCP_basic_string_char_assign_substr(this, this,
668 str-basic_string_char_ptr(this), len);
669 else if(basic_string_char_grow(this, len, FALSE)) {
670 MSVCP_char_traits_char__Copy_s(basic_string_char_ptr(this),
671 this->res, str, len);
672 basic_string_char_eos(this, len);
678 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAEAAV12@PBD@Z */
679 /* ?assign@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAAAEAV12@PEBD@Z */
680 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_assign_cstr, 8)
681 basic_string_char* __thiscall MSVCP_basic_string_char_assign_cstr(
682 basic_string_char *this, const char *str)
684 return MSVCP_basic_string_char_assign_cstr_len(this, str,
685 MSVCP_char_traits_char_length(str));
688 /* ?c_str@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QBEPBDXZ */
689 /* ?c_str@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEBAPEBDXZ */
690 /* ?data@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QBEPBDXZ */
691 /* ?data@?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEBAPEBDXZ */
692 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_c_str, 4)
693 const char* __thiscall MSVCP_basic_string_char_c_str(basic_string_char *this)
696 return basic_string_char_const_ptr(this);
699 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@XZ */
700 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAA@XZ */
701 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_ctor, 4)
702 basic_string_char* __thiscall MSVCP_basic_string_char_ctor(basic_string_char *this)
706 basic_string_char_tidy(this, FALSE, 0);
710 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@ABV01@@Z */
711 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAA@AEBV01@@Z */
712 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_copy_ctor, 8)
713 basic_string_char* __thiscall MSVCP_basic_string_char_copy_ctor(
714 basic_string_char *this, const basic_string_char *copy)
716 TRACE("%p %p\n", this, copy);
718 basic_string_char_tidy(this, FALSE, 0);
719 MSVCP_basic_string_char_assign(this, copy);
723 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@PBD@Z */
724 /* ??0?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAA@PEBD@Z */
725 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_ctor_cstr, 8)
726 basic_string_char* __thiscall MSVCP_basic_string_char_ctor_cstr(
727 basic_string_char *this, const char *str)
729 TRACE("%p %s\n", this, debugstr_a(str));
731 basic_string_char_tidy(this, FALSE, 0);
732 MSVCP_basic_string_char_assign_cstr(this, str);
736 /* ??1?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QAE@XZ */
737 /* ??1?$basic_string@DU?$char_traits@D@std@@V?$allocator@D@2@@std@@QEAA@XZ */
738 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_char_dtor, 4)
739 void __thiscall MSVCP_basic_string_char_dtor(basic_string_char *this)
742 basic_string_char_tidy(this, TRUE, 0);
746 /* basic_string<wchar_t, char_traits<wchar_t>, allocator<wchar_t>> */
747 /* ?npos@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@2IB */
748 /* ?npos@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@2_KB */
749 const size_t MSVCP_basic_string_wchar_npos = -1;
751 /* Internal: basic_string_wchar_ptr - return pointer to stored string */
752 static wchar_t* basic_string_wchar_ptr(basic_string_wchar *this)
754 if(this->res == BUF_SIZE_WCHAR-1)
755 return this->data.buf;
756 return this->data.ptr;
759 /* Internal: basic_string_wchar_const_ptr - returns const pointer to stored string */
760 static const wchar_t* basic_string_wchar_const_ptr(const basic_string_wchar *this)
762 if(this->res == BUF_SIZE_WCHAR-1)
763 return this->data.buf;
764 return this->data.ptr;
767 /* Internal: basic_string_wchar_eos - sets string length, puts '\0' on the end */
768 static void basic_string_wchar_eos(basic_string_wchar *this, size_t len)
770 static const wchar_t nullbyte_w = '\0';
773 MSVCP_char_traits_wchar_assign(basic_string_wchar_ptr(this)+len, &nullbyte_w);
776 /* Internal: basic_string_char_inside - checks if given pointer points inside stored string */
777 static MSVCP_BOOL basic_string_wchar_inside(
778 basic_string_wchar *this, const wchar_t *ptr)
780 wchar_t *cstr = basic_string_wchar_ptr(this);
782 return (ptr<cstr || ptr>=cstr+this->size) ? FALSE : TRUE;
785 /* Internal: basic_string_char_tidy - initialize basic_string buffer, deallocates data */
786 /* Caution: new_size have to be smaller than BUF_SIZE_WCHAR */
787 static void basic_string_wchar_tidy(basic_string_wchar *this,
788 MSVCP_BOOL built, size_t new_size)
790 if(built && BUF_SIZE_WCHAR<=this->res) {
791 wchar_t *ptr = this->data.ptr;
794 MSVCP_char_traits_wchar__Copy_s(this->data.buf, BUF_SIZE_WCHAR, ptr, new_size);
795 MSVCP_allocator_wchar_deallocate(this->allocator, ptr, this->res+1);
798 this->res = BUF_SIZE_WCHAR-1;
799 basic_string_wchar_eos(this, new_size);
802 /* Internal: basic_string_wchar_grow - changes size of internal buffer */
803 static MSVCP_BOOL basic_string_wchar_grow(
804 basic_string_wchar *this, size_t new_size, MSVCP_BOOL trim)
806 if(this->res < new_size) {
807 size_t new_res = new_size;
812 if(new_res/3 < this->res/2)
813 new_res = this->res + this->res/2;
815 ptr = MSVCP_allocator_wchar_allocate(this->allocator, new_res);
817 ptr = MSVCP_allocator_wchar_allocate(this->allocator, new_size+1);
821 ERR("Out of memory\n");
822 basic_string_wchar_tidy(this, TRUE, 0);
826 MSVCP_char_traits_wchar__Copy_s(ptr, new_size,
827 basic_string_wchar_ptr(this), this->size);
828 basic_string_wchar_tidy(this, TRUE, 0);
829 this->data.ptr = ptr;
830 this->res = new_size;
831 basic_string_wchar_eos(this, this->size);
832 } else if(trim && new_size < BUF_SIZE_WCHAR)
833 basic_string_wchar_tidy(this, TRUE,
834 new_size<this->size ? new_size : this->size);
835 else if(new_size == 0)
836 basic_string_wchar_eos(this, 0);
841 /* ?erase@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAEAAV12@II@Z */
842 /* ?erase@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAAAEAV12@_K0@Z */
843 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_erase, 12)
844 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_erase(
845 basic_string_wchar *this, size_t pos, size_t len)
847 TRACE("%p %lu %lu\n", this, (unsigned long)pos, (unsigned long)len);
849 if(pos > this->size) {
850 MSVCP__String_base_Xran();
854 if(len > this->size-pos)
855 len = this->size-pos;
858 MSVCP_char_traits_wchar__Move_s(basic_string_wchar_ptr(this)+pos,
859 this->res-pos, basic_string_wchar_ptr(this)+pos+len,
861 basic_string_wchar_eos(this, this->size-len);
867 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAEAAV12@ABV12@II@Z */
868 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAAAEAV12@AEBV12@_K1@Z */
869 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_assign_substr, 16)
870 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_assign_substr(
871 basic_string_wchar *this, const basic_string_wchar *assign,
872 size_t pos, size_t len)
874 TRACE("%p %p %lu %lu\n", this, assign, (unsigned long)pos, (unsigned long)len);
876 if(assign->size < pos) {
877 MSVCP__String_base_Xran();
881 if(len > assign->size-pos)
882 len = assign->size-pos;
885 MSVCP_basic_string_wchar_erase(this, pos+len, MSVCP_basic_string_wchar_npos);
886 MSVCP_basic_string_wchar_erase(this, 0, pos);
887 } else if(basic_string_wchar_grow(this, len, FALSE)) {
888 MSVCP_char_traits_wchar__Copy_s(basic_string_wchar_ptr(this),
889 this->res, basic_string_wchar_const_ptr(assign)+pos, len);
890 basic_string_wchar_eos(this, len);
896 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAEAAV12@ABV12@@Z */
897 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAAAEAV12@AEBV12@@Z */
898 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_assign, 8)
899 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_assign(
900 basic_string_wchar *this, const basic_string_wchar *assign)
902 return MSVCP_basic_string_wchar_assign_substr(this, assign,
903 0, MSVCP_basic_string_wchar_npos);
906 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAEAAV12@PB_WI@Z */
907 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAAAEAV12@PEB_W_K@Z */
908 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_assign_cstr_len, 12)
909 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_assign_cstr_len(
910 basic_string_wchar *this, const wchar_t *str, size_t len)
912 TRACE("%p %s %lu\n", this, debugstr_w(str), (unsigned long)len);
914 if(basic_string_wchar_inside(this, str))
915 return MSVCP_basic_string_wchar_assign_substr(this, this,
916 str-basic_string_wchar_ptr(this), len);
917 else if(basic_string_wchar_grow(this, len, FALSE)) {
918 MSVCP_char_traits_wchar__Copy_s(basic_string_wchar_ptr(this),
919 this->res, str, len);
920 basic_string_wchar_eos(this, len);
926 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAEAAV12@PB_W@Z */
927 /* ?assign@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAAAEAV12@PEB_W@Z */
928 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_assign_cstr, 8)
929 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_assign_cstr(
930 basic_string_wchar *this, const wchar_t *str)
932 return MSVCP_basic_string_wchar_assign_cstr_len(this, str,
933 MSVCP_char_traits_wchar_length(str));
936 /* ?c_str@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QBEPB_WXZ */
937 /* ?c_str@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEBAPEB_WXZ */
938 /* ?data@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QBEPB_WXZ */
939 /* ?data@?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEBAPEB_WXZ */
940 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_c_str, 4)
941 const wchar_t* __thiscall MSVCP_basic_string_wchar_c_str(basic_string_wchar *this)
944 return basic_string_wchar_const_ptr(this);
947 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAE@XZ */
948 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAA@XZ */
949 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_ctor, 4)
950 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_ctor(basic_string_wchar *this)
954 basic_string_wchar_tidy(this, FALSE, 0);
958 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAE@ABV01@@Z */
959 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAA@AEBV01@@Z */
960 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_copy_ctor, 8)
961 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_copy_ctor(
962 basic_string_wchar *this, const basic_string_wchar *copy)
964 TRACE("%p %p\n", this, copy);
966 basic_string_wchar_tidy(this, FALSE, 0);
967 MSVCP_basic_string_wchar_assign(this, copy);
971 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAE@PB_W@Z */
972 /* ??0?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAA@PEB_W@Z */
973 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_ctor_cstr, 8)
974 basic_string_wchar* __thiscall MSVCP_basic_string_wchar_ctor_cstr(
975 basic_string_wchar *this, const wchar_t *str)
977 TRACE("%p %s\n", this, debugstr_w(str));
979 basic_string_wchar_tidy(this, FALSE, 0);
980 MSVCP_basic_string_wchar_assign_cstr(this, str);
984 /* ??1?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QAE@XZ */
985 /* ??1?$basic_string@_WU?$char_traits@_W@std@@V?$allocator@_W@2@@std@@QEAA@XZ */
986 DEFINE_THISCALL_WRAPPER(MSVCP_basic_string_wchar_dtor, 4)
987 void __thiscall MSVCP_basic_string_wchar_dtor(basic_string_wchar *this)
990 basic_string_wchar_tidy(this, TRUE, 0);