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
22 typedef unsigned char MSVCP_bool
;
23 typedef SIZE_T MSVCP_size_t
;
24 typedef SSIZE_T streamoff
;
25 typedef SSIZE_T streamsize
;
27 void __cdecl
_invalid_parameter(const wchar_t*, const wchar_t*,
28 const wchar_t*, unsigned int, uintptr_t);
29 BOOL __cdecl
__uncaught_exception(void);
31 extern void* (__cdecl
*MSVCRT_operator_new
)(MSVCP_size_t
);
32 extern void (__cdecl
*MSVCRT_operator_delete
)(void*);
33 extern void* (__cdecl
*MSVCRT_set_new_handler
)(void*);
35 /* Copied from dlls/msvcrt/cpp.c */
36 #ifdef __i386__ /* thiscall functions are i386-specific */
38 #define THISCALL(func) __thiscall_ ## func
39 #define THISCALL_NAME(func) __ASM_NAME("__thiscall_" #func)
40 #define __thiscall __stdcall
41 #define DEFINE_THISCALL_WRAPPER(func,args) \
42 extern void THISCALL(func)(void); \
43 __ASM_GLOBAL_FUNC(__thiscall_ ## func, \
47 "jmp " __ASM_NAME(#func) __ASM_STDCALL(args) )
50 #define THISCALL(func) func
51 #define THISCALL_NAME(func) __ASM_NAME(#func)
52 #define __thiscall __cdecl
53 #define DEFINE_THISCALL_WRAPPER(func,args) /* nothing */
59 #define VTABLE_ADD_FUNC(name) "\t.quad " THISCALL_NAME(name) "\n"
61 #define __ASM_VTABLE(name,funcs) \
64 "\t.quad " __ASM_NAME(#name "_rtti") "\n" \
65 "\t.globl " __ASM_NAME("MSVCP_" #name "_vtable") "\n" \
66 __ASM_NAME("MSVCP_" #name "_vtable") ":\n" \
67 "\t.quad " THISCALL_NAME(MSVCP_ ## name ## _vector_dtor) "\n" \
72 #define VTABLE_ADD_FUNC(name) "\t.long " THISCALL_NAME(name) "\n"
74 #define __ASM_VTABLE(name,funcs) \
77 "\t.long " __ASM_NAME(#name "_rtti") "\n" \
78 "\t.globl " __ASM_NAME("MSVCP_" #name "_vtable") "\n" \
79 __ASM_NAME("MSVCP_" #name "_vtable") ":\n" \
80 "\t.long " THISCALL_NAME(MSVCP_ ## name ## _vector_dtor) "\n" \
85 #define DEFINE_RTTI_DATA(name, off, base_classes, cl1, cl2, cl3, cl4, cl5, cl6, cl7, cl8, cl9, mangled_name) \
86 static const type_info name ## _type_info = { \
87 &MSVCP_type_info_vtable, \
92 static const rtti_base_descriptor name ## _rtti_base_descriptor = { \
99 static const rtti_base_array name ## _rtti_base_array = { \
101 &name ## _rtti_base_descriptor, \
114 static const rtti_object_hierarchy name ## _hierarchy = { \
118 &name ## _rtti_base_array \
121 const rtti_object_locator name ## _rtti = { \
125 &name ## _type_info, \
126 &name ## _hierarchy \
129 #define DEFINE_RTTI_DATA0(name, off, mangled_name) \
130 DEFINE_RTTI_DATA(name, off, 0, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, mangled_name)
131 #define DEFINE_RTTI_DATA1(name, off, cl1, mangled_name) \
132 DEFINE_RTTI_DATA(name, off, 1, cl1, NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL, mangled_name)
133 #define DEFINE_RTTI_DATA2(name, off, cl1, cl2, mangled_name) \
134 DEFINE_RTTI_DATA(name, off, 2, cl1, cl2, NULL, NULL, NULL, NULL, NULL, NULL, NULL, mangled_name)
135 #define DEFINE_RTTI_DATA3(name, off, cl1, cl2, cl3, mangled_name) \
136 DEFINE_RTTI_DATA(name, off, 3, cl1, cl2, cl3, NULL, NULL, NULL, NULL, NULL, NULL, mangled_name)
137 #define DEFINE_RTTI_DATA4(name, off, cl1, cl2, cl3, cl4, mangled_name) \
138 DEFINE_RTTI_DATA(name, off, 4, cl1, cl2, cl3, cl4, NULL, NULL, NULL, NULL, NULL, mangled_name)
139 #define DEFINE_RTTI_DATA8(name, off, cl1, cl2, cl3, cl4, cl5, cl6, cl7, cl8, mangled_name) \
140 DEFINE_RTTI_DATA(name, off, 8, cl1, cl2, cl3, cl4, cl5, cl6, cl7, cl8, NULL, mangled_name)
141 #define DEFINE_RTTI_DATA9(name, off, cl1, cl2, cl3, cl4, cl5, cl6, cl7, cl8, cl9, mangled_name) \
142 DEFINE_RTTI_DATA(name, off, 9, cl1, cl2, cl3, cl4, cl5, cl6, cl7, cl8, cl9, mangled_name)
146 #define CALL_VTBL_FUNC(this, off, ret, type, args) ((ret (WINAPI*)type)&vtbl_wrapper_##off)args
148 extern void *vtbl_wrapper_0
;
149 extern void *vtbl_wrapper_4
;
150 extern void *vtbl_wrapper_8
;
151 extern void *vtbl_wrapper_12
;
152 extern void *vtbl_wrapper_16
;
153 extern void *vtbl_wrapper_20
;
154 extern void *vtbl_wrapper_24
;
155 extern void *vtbl_wrapper_28
;
156 extern void *vtbl_wrapper_32
;
157 extern void *vtbl_wrapper_36
;
158 extern void *vtbl_wrapper_40
;
159 extern void *vtbl_wrapper_44
;
160 extern void *vtbl_wrapper_48
;
161 extern void *vtbl_wrapper_52
;
162 extern void *vtbl_wrapper_56
;
163 extern void *vtbl_wrapper_60
;
167 #define CALL_VTBL_FUNC(this, off, ret, type, args) ((ret (__cdecl***)type)this)[0][off/4]args
171 /* exception object */
172 typedef void (*vtable_ptr
)(void);
173 typedef struct __exception
175 const vtable_ptr
*vtable
;
176 char *name
; /* Name of this exception, always a new copy for each object */
177 int do_free
; /* Whether to free 'name' in our dtor */
180 /* Internal: throws selected exception */
181 typedef enum __exception_type
{
185 EXCEPTION_LOGIC_ERROR
,
186 EXCEPTION_LENGTH_ERROR
,
187 EXCEPTION_OUT_OF_RANGE
,
188 EXCEPTION_INVALID_ARGUMENT
,
189 EXCEPTION_RUNTIME_ERROR
,
192 void throw_exception(exception_type
, const char *);
195 typedef struct __type_info
197 const vtable_ptr
*vtable
;
198 char *name
; /* Unmangled name, allocated lazily */
199 char mangled
[128]; /* Variable length, but we declare it large enough for static RTTI */
202 extern const vtable_ptr MSVCP_type_info_vtable
;
204 /* offsets for computing the this pointer */
207 int this_offset
; /* offset of base class this pointer from start of object */
208 int vbase_descr
; /* offset of virtual base class descriptor */
209 int vbase_offset
; /* offset of this pointer offset in virtual base class descriptor */
212 typedef struct _rtti_base_descriptor
214 const type_info
*type_descriptor
;
215 int num_base_classes
;
216 this_ptr_offsets offsets
; /* offsets for computing the this pointer */
217 unsigned int attributes
;
218 } rtti_base_descriptor
;
220 typedef struct _rtti_base_array
222 const rtti_base_descriptor
*bases
[10]; /* First element is the class itself */
225 typedef struct _rtti_object_hierarchy
227 unsigned int signature
;
228 unsigned int attributes
;
229 int array_len
; /* Size of the array pointed to by 'base_classes' */
230 const rtti_base_array
*base_classes
;
231 } rtti_object_hierarchy
;
233 typedef struct _rtti_object_locator
235 unsigned int signature
;
236 int base_class_offset
;
238 const type_info
*type_descriptor
;
239 const rtti_object_hierarchy
*type_hierarchy
;
240 } rtti_object_locator
;
242 /* basic_string<char, char_traits<char>, allocator<char>> */
243 #define BUF_SIZE_CHAR 16
244 typedef struct _basic_string_char
248 char buf
[BUF_SIZE_CHAR
];
255 basic_string_char
* __stdcall
MSVCP_basic_string_char_ctor_cstr(basic_string_char
*, const char*);
256 basic_string_char
* __stdcall
MSVCP_basic_string_char_copy_ctor(basic_string_char
*, const basic_string_char
*);
257 void __stdcall
MSVCP_basic_string_char_dtor(basic_string_char
*);
258 const char* __stdcall
MSVCP_basic_string_char_c_str(const basic_string_char
*);
259 void __thiscall
MSVCP_basic_string_char_clear(basic_string_char
*);
260 basic_string_char
* __thiscall
MSVCP_basic_string_char_append_ch(basic_string_char
*, char);
261 MSVCP_size_t __thiscall
MSVCP_basic_string_char_length(const basic_string_char
*);
263 #define BUF_SIZE_WCHAR 8
264 typedef struct _basic_string_wchar
268 wchar_t buf
[BUF_SIZE_WCHAR
];
273 } basic_string_wchar
;
275 basic_string_wchar
* __stdcall
MSVCP_basic_string_wchar_ctor_cstr(basic_string_wchar
*, const wchar_t*);
277 char* __stdcall
MSVCP_allocator_char_allocate(void*, MSVCP_size_t
);
278 void __stdcall
MSVCP_allocator_char_deallocate(void*, char*, MSVCP_size_t
);
279 MSVCP_size_t __stdcall
MSVCP_allocator_char_max_size(void*);
280 wchar_t* __stdcall
MSVCP_allocator_wchar_allocate(void*, MSVCP_size_t
);
281 void __stdcall
MSVCP_allocator_wchar_deallocate(void*, wchar_t*, MSVCP_size_t
);
282 MSVCP_size_t __stdcall
MSVCP_allocator_wchar_max_size(void*);
284 /* class locale::facet */
286 const vtable_ptr
*vtable
;
295 } codecvt_base_result
;
304 /* class codecvt_base */
309 /* class codecvt<char> */
314 MSVCP_bool __thiscall
codecvt_base_always_noconv(const codecvt_base
*);
315 int __thiscall
codecvt_char_unshift(const codecvt_char
*, int*, char*, char*, char**);
316 int __thiscall
codecvt_char_out(const codecvt_char
*, int*, const char*,
317 const char*, const char**, char*, char*, char**);
318 int __thiscall
codecvt_char_in(const codecvt_char
*, int*, const char*,
319 const char*, const char**, char*, char*, char**);
320 int __thiscall
codecvt_base_max_length(const codecvt_base
*);
327 /* class codecvt<wchar> */
333 /* class ctype_base */
338 /* class ctype<char> */
344 MSVCP_bool __thiscall
ctype_char_is_ch(const ctype_char
*, short, char);
345 char __thiscall
ctype_char_narrow_ch(const ctype_char
*, char, char);
346 char __thiscall
ctype_char_widen_ch(const ctype_char
*, char);
348 /* class ctype<wchar> */
355 char __thiscall
ctype_wchar_narrow_ch(const ctype_wchar
*, wchar_t, char);
356 wchar_t __thiscall
ctype_wchar_widen_ch(const ctype_wchar
*, char);
361 struct _locale__Locimp
*ptr
;
364 locale
* __thiscall
locale_ctor(locale
*);
365 locale
* __thiscall
locale_copy_ctor(locale
*, const locale
*);
366 locale
* __thiscall
locale_operator_assign(locale
*, const locale
*);
367 void __thiscall
locale_dtor(locale
*);
368 void free_locale(void);
369 codecvt_char
* codecvt_char_use_facet(const locale
*);
370 codecvt_char
* codecvt_char_use_facet(const locale
*);
371 ctype_char
* ctype_char_use_facet(const locale
*);
372 ctype_wchar
* ctype_wchar_use_facet(const locale
*);
379 #define _LOCK_LOCALE 0
380 #define _LOCK_MALLOC 1
381 #define _LOCK_STREAM 2
382 #define _LOCK_DEBUG 3
385 void init_lockit(void);
386 void free_lockit(void);
387 _Lockit
* __thiscall
_Lockit_ctor_locktype(_Lockit
*, int);
388 void __thiscall
_Lockit_dtor(_Lockit
*);
395 mutex
* __thiscall
mutex_ctor(mutex
*);
396 void __thiscall
mutex_dtor(mutex
*);
397 void __thiscall
mutex_lock(mutex
*);
398 void __thiscall
mutex_unlock(mutex
*);
401 FMTFLAG_skipws
= 0x0001,
402 FMTFLAG_unitbuf
= 0x0002,
403 FMTFLAG_uppercase
= 0x0004,
404 FMTFLAG_showbase
= 0x0008,
405 FMTFLAG_showpoint
= 0x0010,
406 FMTFLAG_showpos
= 0x0020,
407 FMTFLAG_left
= 0x0040,
408 FMTFLAG_right
= 0x0080,
409 FMTFLAG_internal
= 0x0100,
410 FMTFLAG_dec
= 0x0200,
411 FMTFLAG_oct
= 0x0400,
412 FMTFLAG_hex
= 0x0800,
413 FMTFLAG_scientific
= 0x1000,
414 FMTFLAG_fixed
= 0x2000,
415 FMTFLAG_hexfloat
= 0x3000,
416 FMTFLAG_boolalpha
= 0x4000,
417 FMTFLAG_stdio
= 0x8000,
418 FMTFLAG_adjustfield
= FMTFLAG_left
|FMTFLAG_right
|FMTFLAG_internal
,
419 FMTFLAG_basefield
= FMTFLAG_dec
|FMTFLAG_oct
|FMTFLAG_hex
,
420 FMTFLAG_floadfield
= FMTFLAG_scientific
|FMTFLAG_fixed
,
421 FMTFLAG_mask
= 0xffff
429 OPENMODE_trunc
= 0x10,
430 OPENMODE__Nocreate
= 0x40,
431 OPENMODE__Noreplace
= 0x80,
432 OPENMODE_binary
= 0x20,
444 IOSTATE_goodbit
= 0x00,
445 IOSTATE_eofbit
= 0x01,
446 IOSTATE_failbit
= 0x02,
447 IOSTATE_badbit
= 0x04,
448 IOSTATE__Hardfail
= 0x10,
452 typedef struct _iosarray
{
453 struct _iosarray
*next
;
466 typedef void (CDECL
*IOS_BASE_event_callback
)(IOS_BASE_event
, struct _ios_base
*, int);
467 typedef struct _fnarray
{
468 struct _fnarray
*next
;
470 IOS_BASE_event_callback event_handler
;
474 typedef struct _ios_base
{
475 const vtable_ptr
*vtable
;
482 IOS_BASE_iosarray
*arr
;
483 IOS_BASE_fnarray
*calls
;
487 /* class basic_streambuf<char> */
489 const vtable_ptr
*vtable
;
504 } basic_streambuf_char
;
506 int __thiscall
basic_streambuf_char_sgetc(basic_streambuf_char
*);
507 int __thiscall
basic_streambuf_char_sbumpc(basic_streambuf_char
*);
509 /* class basic_streambuf<wchar> */
511 const vtable_ptr
*vtable
;
526 } basic_streambuf_wchar
;