memory.c 10.5 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27
/*
 * Copyright 2010 Piotr Caban for CodeWeavers
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
 */

#include "config.h"

#include <stdarg.h>
#include <limits.h>

#include "msvcp90.h"

#include "windef.h"
#include "winbase.h"
28

29 30

/* ?address@?$allocator@D@std@@QBEPADAAD@Z */
31
/* ?address@?$allocator@D@std@@QEBAPEADAEAD@Z */
32
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_address, 8)
33
char* __thiscall MSVCP_allocator_char_address(void *this, char *ptr)
34 35 36 37 38
{
    return ptr;
}

/* ?address@?$allocator@D@std@@QBEPBDABD@Z */
39
/* ?address@?$allocator@D@std@@QEBAPEBDAEBD@Z */
40
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_const_address, 8)
41
const char* __thiscall MSVCP_allocator_char_const_address(void *this, const char *ptr)
42 43 44 45 46
{
    return ptr;
}

/* ??0?$allocator@D@std@@QAE@XZ */
47
/* ??0?$allocator@D@std@@QEAA@XZ */
48
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_ctor, 4)
49
void* __thiscall MSVCP_allocator_char_ctor(void *this)
50 51 52 53 54
{
    return this;
}

/* ??0?$allocator@D@std@@QAE@ABV01@@Z */
55
/* ??0?$allocator@D@std@@QEAA@AEBV01@@Z */
56
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_copy_ctor, 8)
57
void* __thiscall MSVCP_allocator_char_copy_ctor(void *this, const void *copy)
58 59 60 61 62
{
    return this;
}

/* ??4?$allocator@D@std@@QAEAAV01@ABV01@@Z */
63
/* ??4?$allocator@D@std@@QEAAAEAV01@AEBV01@@Z */
64
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_assign, 8)
65
void* __thiscall MSVCP_allocator_char_assign(void *this, const void *assign)
66 67 68 69 70
{
    return this;
}

/* ?deallocate@?$allocator@D@std@@QAEXPADI@Z */
71
/* ?deallocate@?$allocator@D@std@@QEAAXPEAD_K@Z */
72
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_deallocate, 12)
73
void __thiscall MSVCP_allocator_char_deallocate(void *this, char *ptr, MSVCP_size_t size)
74 75 76 77 78
{
    MSVCRT_operator_delete(ptr);
}

/* ?allocate@?$allocator@D@std@@QAEPADI@Z */
79
/* ?allocate@?$allocator@D@std@@QEAAPEAD_K@Z */
80
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_allocate, 8)
81
char* __thiscall MSVCP_allocator_char_allocate(void *this, MSVCP_size_t count)
82
{
83
    return MSVCRT_operator_new(count);
84 85 86
}

/* ?allocate@?$allocator@D@std@@QAEPADIPBX@Z */
87
/* ?allocate@?$allocator@D@std@@QEAAPEAD_KPEBX@Z */
88
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_allocate_hint, 12)
89
char* __thiscall MSVCP_allocator_char_allocate_hint(void *this,
90
        MSVCP_size_t count, const void *hint)
91 92 93 94 95 96
{
    /* Native ignores hint */
    return MSVCP_allocator_char_allocate(this, count);
}

/* ?construct@?$allocator@D@std@@QAEXPADABD@Z */
97
/* ?construct@?$allocator@D@std@@QEAAXPEADAEBD@Z */
98
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_construct, 12)
99
void __thiscall MSVCP_allocator_char_construct(void *this, char *ptr, const char *val)
100 101 102 103 104
{
    *ptr = *val;
}

/* ?destroy@?$allocator@D@std@@QAEXPAD@Z */
105
/* ?destroy@?$allocator@D@std@@QEAAXPEAD@Z */
106
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_destroy, 8)
107
void __thiscall MSVCP_allocator_char_destroy(void *this, char *ptr)
108 109 110 111
{
}

/* ?max_size@?$allocator@D@std@@QBEIXZ */
112
/* ?max_size@?$allocator@D@std@@QEBA_KXZ */
113
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_char_max_size, 4)
114
MSVCP_size_t __thiscall MSVCP_allocator_char_max_size(const void *this)
115 116 117
{
    return UINT_MAX/sizeof(char);
}
118 119 120 121 122 123


/* allocator<wchar_t> */
/* ?address@?$allocator@_W@std@@QBEPA_WAA_W@Z */
/* ?address@?$allocator@_W@std@@QEBAPEA_WAEA_W@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_address, 8)
124
wchar_t* __thiscall MSVCP_allocator_wchar_address(void *this, wchar_t *ptr)
125 126 127 128 129 130 131
{
    return ptr;
}

/* ?address@?$allocator@_W@std@@QBEPB_WAB_W@Z */
/* ?address@?$allocator@_W@std@@QEBAPEB_WAEB_W@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_const_address, 8)
132
const wchar_t* __thiscall MSVCP_allocator_wchar_const_address(void *this, const wchar_t *ptr)
133 134 135 136 137 138 139
{
    return ptr;
}

/* ??0?$allocator@_W@std@@QAE@XZ */
/* ??0?$allocator@_W@std@@QEAA@XZ */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_ctor, 4)
140
void* __thiscall MSVCP_allocator_wchar_ctor(void *this)
141 142 143 144 145 146 147
{
    return this;
}

/* ??0?$allocator@_W@std@@QAE@ABV01@@Z */
/* ??0?$allocator@_W@std@@QEAA@AEBV01@@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_copy_ctor, 8)
148
void* __thiscall MSVCP_allocator_wchar_copy_ctor(void *this, void *copy)
149 150 151 152 153 154 155
{
    return this;
}

/* ??4?$allocator@_W@std@@QAEAAV01@ABV01@@Z */
/* ??4?$allocator@_W@std@@QEAAAEAV01@AEBV01@@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_assign, 8)
156
void* __thiscall MSVCP_allocator_wchar_assign(void *this, void *assign)
157 158 159 160 161 162 163
{
    return this;
}

/* ?deallocate@?$allocator@_W@std@@QAEXPA_WI@Z */
/* ?deallocate@?$allocator@_W@std@@QEAAXPEA_W_K@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_deallocate, 12)
164
void __thiscall MSVCP_allocator_wchar_deallocate(void *this,
165
        wchar_t *ptr, MSVCP_size_t size)
166 167 168 169 170 171 172
{
    MSVCRT_operator_delete(ptr);
}

/* ?allocate@?$allocator@_W@std@@QAEPA_WI@Z */
/* ?allocate@?$allocator@_W@std@@QEAAPEA_W_K@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_allocate, 8)
173
wchar_t* __thiscall MSVCP_allocator_wchar_allocate(void *this, MSVCP_size_t count)
174 175 176 177 178 179
{
    if(UINT_MAX/count < sizeof(wchar_t)) {
        throw_exception(EXCEPTION_BAD_ALLOC, NULL);
        return NULL;
    }

180
    return MSVCRT_operator_new(count * sizeof(wchar_t));
181 182 183 184 185
}

/* ?allocate@?$allocator@_W@std@@QAEPA_WIPBX@Z */
/* ?allocate@?$allocator@_W@std@@QEAAPEA_W_KPEBX@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_allocate_hint, 12)
186
wchar_t* __thiscall MSVCP_allocator_wchar_allocate_hint(void *this,
187
        MSVCP_size_t count, const void *hint)
188 189 190 191 192 193 194
{
    return MSVCP_allocator_wchar_allocate(this, count);
}

/* ?construct@?$allocator@_W@std@@QAEXPA_WAB_W@Z */
/* ?construct@?$allocator@_W@std@@QEAAXPEA_WAEB_W@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_construct, 12)
195
void __thiscall MSVCP_allocator_wchar_construct(void *this,
196 197 198 199 200 201 202 203
        wchar_t *ptr, const wchar_t *val)
{
    *ptr = *val;
}

/* ?destroy@?$allocator@_W@std@@QAEXPA_W@Z */
/* ?destroy@?$allocator@_W@std@@QEAAXPEA_W@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_destroy, 8)
204
void __thiscall MSVCP_allocator_wchar_destroy(void *this, char *ptr)
205 206 207 208 209 210
{
}

/* ?max_size@?$allocator@_W@std@@QBEIXZ */
/* ?max_size@?$allocator@_W@std@@QEBA_KXZ */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_wchar_max_size, 4)
211
MSVCP_size_t __thiscall MSVCP_allocator_wchar_max_size(const void *this)
212 213 214
{
    return UINT_MAX/sizeof(wchar_t);
}
215 216 217 218 219

/* allocator<unsigned short> */
/* ?address@?$allocator@G@std@@QBEPAGAAG@Z */
/* ?address@?$allocator@G@std@@QEBAPEAGAEAG@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_address, 8)
220
unsigned short* __thiscall MSVCP_allocator_short_address(
221 222 223 224 225 226 227 228
        void *this, unsigned short *ptr)
{
    return ptr;
}

/* ?address@?$allocator@G@std@@QBEPBGABG@Z */
/* ?address@?$allocator@G@std@@QEBAPEBGAEBG@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_const_address, 8)
229
const unsigned short* __thiscall MSVCP_allocator_short_const_address(
230 231 232 233 234 235 236 237
        void *this, const unsigned short *ptr)
{
    return ptr;
}

/* ??0?$allocator@G@std@@QAE@XZ */
/* ??0?$allocator@G@std@@QEAA@XZ */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_ctor, 4)
238
void* __thiscall MSVCP_allocator_short_ctor(void *this)
239 240 241 242 243 244 245
{
    return this;
}

/* ??0?$allocator@G@std@@QAE@ABV01@@Z */
/* ??0?$allocator@G@std@@QEAA@AEBV01@@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_copy_ctor, 8)
246
void* __thiscall MSVCP_allocator_short_copy_ctor(void *this, void *copy)
247 248 249 250 251 252 253
{
    return this;
}

/* ??4?$allocator@G@std@@QAEAAV01@ABV01@@Z */
/* ??4?$allocator@G@std@@QEAAAEAV01@AEBV01@@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_assign, 8)
254
void* __thiscall MSVCP_allocator_short_assign(void *this, void *assign)
255 256 257 258 259 260 261
{
    return this;
}

/* ?deallocate@?$allocator@G@std@@QAEXPAGI@Z */
/* ?deallocate@?$allocator@G@std@@QEAAXPEAG_K@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_deallocate, 12)
262
void __thiscall MSVCP_allocator_short_deallocate(void *this,
263
        unsigned short *ptr, MSVCP_size_t size)
264 265 266 267 268 269 270
{
    MSVCRT_operator_delete(ptr);
}

/* ?allocate@?$allocator@G@std@@QAEPAGI@Z */
/* ?allocate@?$allocator@G@std@@QEAAPEAG_K@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_allocate, 8)
271
unsigned short* __thiscall MSVCP_allocator_short_allocate(
272
        void *this, MSVCP_size_t count)
273 274 275 276 277 278
{
    if(UINT_MAX/count < sizeof(unsigned short)) {
        throw_exception(EXCEPTION_BAD_ALLOC, NULL);
        return NULL;
    }

279
    return MSVCRT_operator_new(count * sizeof(unsigned short));
280 281 282 283 284
}

/* ?allocate@?$allocator@G@std@@QAEPAGIPBX@Z */
/* ?allocate@?$allocator@G@std@@QEAAPEAG_KPEBX@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_allocate_hint, 12)
285
unsigned short* __thiscall MSVCP_allocator_short_allocate_hint(
286
        void *this, MSVCP_size_t count, const void *hint)
287 288 289 290 291 292 293
{
    return MSVCP_allocator_short_allocate(this, count);
}

/* ?construct@?$allocator@G@std@@QAEXPAGABG@Z */
/* ?construct@?$allocator@G@std@@QEAAXPEAGAEBG@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_construct, 12)
294
void __thiscall MSVCP_allocator_short_construct(void *this,
295 296 297 298 299 300 301 302
        unsigned short *ptr, unsigned short *val)
{
    *ptr = *val;
}

/* ?destroy@?$allocator@G@std@@QAEXPAG@Z */
/* ?destroy@?$allocator@G@std@@QEAAXPEAG@Z */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_destroy, 8)
303
void __thiscall MSVCP_allocator_short_destroy(void *this, MSVCP_size_t *ptr)
304 305 306 307 308 309
{
}

/* ?max_size@?$allocator@G@std@@QBEIXZ */
/* ?max_size@?$allocator@G@std@@QEBA_KXZ */
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_short_max_size, 4)
310
MSVCP_size_t __thiscall MSVCP_allocator_short_max_size(void *this)
311 312 313
{
    return UINT_MAX/sizeof(unsigned short);
}
314 315 316 317

/* allocator<void> */
/* ??0?$allocator@X@std@@QAE@XZ */
/* ??0?$allocator@X@std@@QEAA@XZ */
318
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_void_ctor, 4)
319
void* __thiscall MSVCP_allocator_void_ctor(void *this)
320 321 322 323 324 325
{
    return this;
}

/* ??0?$allocator@X@std@@QAE@ABV01@@Z */
/* ??0?$allocator@X@std@@QEAA@AEBV01@@Z */
326
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_void_copy_ctor, 8)
327
void* __thiscall MSVCP_allocator_void_copy_ctor(void *this, void *copy)
328 329 330 331 332 333
{
    return this;
}

/* ??4?$allocator@X@std@@QAEAAV01@ABV01@@Z */
/* ??4?$allocator@X@std@@QEAAAEAV01@AEBV01@@Z */
334
DEFINE_THISCALL_WRAPPER(MSVCP_allocator_void_assign, 8)
335
void* __thiscall MSVCP_allocator_void_assign(void *this, void *assign)
336 337 338
{
    return this;
}