Refactors the memnew_placement.

With this commit the macro `memnew_placement` uses the standard memory
placement syntax: `new (mem) TheClass()`, and removes the outdated and
not used syntax:
```
_ALWAYS_INLINE_ void *operator new(size_t p_size, void *p_pointer, size_t check, const char *p_description) {
```

Thanks to this change, the function `memnew_placement` call is compatible with
any class, and can also initialize classes with non-empty constructor:
```
// This is valid, like before.
memnew_placement(mem, Variant);

// This works too:
memnew_placement(mem, Variant(123));
```
This commit is contained in:
AndreaCatania 2021-08-11 13:09:54 +02:00
parent 6882280308
commit 98ceb60eb4
5 changed files with 76 additions and 88 deletions

View File

@ -74,8 +74,6 @@ static void gdnative_variant_destroy(GDNativeVariantPtr p_self) {
// variant type // variant type
#define memnew_placement_custom(m_placement, m_class, m_constr) _post_initialize(new (m_placement, sizeof(m_class), "") m_constr)
static void gdnative_variant_call(GDNativeVariantPtr p_self, const GDNativeStringNamePtr p_method, const GDNativeVariantPtr *p_args, const GDNativeInt p_argcount, GDNativeVariantPtr r_return, GDNativeCallError *r_error) { static void gdnative_variant_call(GDNativeVariantPtr p_self, const GDNativeStringNamePtr p_method, const GDNativeVariantPtr *p_args, const GDNativeInt p_argcount, GDNativeVariantPtr r_return, GDNativeCallError *r_error) {
Variant *self = (Variant *)p_self; Variant *self = (Variant *)p_self;
const StringName *method = (const StringName *)p_method; const StringName *method = (const StringName *)p_method;
@ -83,7 +81,7 @@ static void gdnative_variant_call(GDNativeVariantPtr p_self, const GDNativeStrin
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
self->call(*method, args, p_argcount, ret, error); self->call(*method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (GDNativeCallErrorType)(error.error); r_error->error = (GDNativeCallErrorType)(error.error);
@ -99,7 +97,7 @@ static void gdnative_variant_call_static(GDNativeVariantType p_type, const GDNat
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
Variant::call_static(type, *method, args, p_argcount, ret, error); Variant::call_static(type, *method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (GDNativeCallErrorType)error.error; r_error->error = (GDNativeCallErrorType)error.error;
@ -164,7 +162,7 @@ static void gdnative_variant_get(const GDNativeVariantPtr p_self, const GDNative
const Variant *key = (const Variant *)p_key; const Variant *key = (const Variant *)p_key;
bool valid; bool valid;
memnew_placement_custom(r_ret, Variant, Variant(self->get(*key, &valid))); memnew_placement(r_ret, Variant(self->get(*key, &valid)));
*r_valid = valid; *r_valid = valid;
} }
@ -173,7 +171,7 @@ static void gdnative_variant_get_named(const GDNativeVariantPtr p_self, const GD
const StringName *key = (const StringName *)p_key; const StringName *key = (const StringName *)p_key;
bool valid; bool valid;
memnew_placement_custom(r_ret, Variant, Variant(self->get_named(*key, valid))); memnew_placement(r_ret, Variant(self->get_named(*key, valid)));
*r_valid = valid; *r_valid = valid;
} }
@ -182,7 +180,7 @@ static void gdnative_variant_get_keyed(const GDNativeVariantPtr p_self, const GD
const Variant *key = (const Variant *)p_key; const Variant *key = (const Variant *)p_key;
bool valid; bool valid;
memnew_placement_custom(r_ret, Variant, Variant(self->get_keyed(*key, valid))); memnew_placement(r_ret, Variant(self->get_keyed(*key, valid)));
*r_valid = valid; *r_valid = valid;
} }
@ -191,7 +189,7 @@ static void gdnative_variant_get_indexed(const GDNativeVariantPtr p_self, GDNati
bool valid; bool valid;
bool oob; bool oob;
memnew_placement_custom(r_ret, Variant, Variant(self->get_indexed(p_index, valid, oob))); memnew_placement(r_ret, Variant(self->get_indexed(p_index, valid, oob)));
*r_valid = valid; *r_valid = valid;
*r_oob = oob; *r_oob = oob;
} }
@ -222,7 +220,7 @@ static void gdnative_variant_iter_get(const GDNativeVariantPtr p_self, GDNativeV
Variant *iter = (Variant *)r_iter; Variant *iter = (Variant *)r_iter;
bool valid; bool valid;
memnew_placement_custom(r_ret, Variant, Variant(self->iter_next(*iter, valid))); memnew_placement(r_ret, Variant(self->iter_next(*iter, valid)));
*r_valid = valid; *r_valid = valid;
} }
@ -254,12 +252,12 @@ static void gdnative_variant_interpolate(const GDNativeVariantPtr p_a, const GDN
static void gdnative_variant_duplicate(const GDNativeVariantPtr p_self, GDNativeVariantPtr r_ret, GDNativeBool p_deep) { static void gdnative_variant_duplicate(const GDNativeVariantPtr p_self, GDNativeVariantPtr r_ret, GDNativeBool p_deep) {
const Variant *self = (const Variant *)p_self; const Variant *self = (const Variant *)p_self;
memnew_placement_custom(r_ret, Variant, Variant(self->duplicate(p_deep))); memnew_placement(r_ret, Variant(self->duplicate(p_deep)));
} }
static void gdnative_variant_stringify(const GDNativeVariantPtr p_self, GDNativeStringPtr r_ret) { static void gdnative_variant_stringify(const GDNativeVariantPtr p_self, GDNativeStringPtr r_ret) {
const Variant *self = (const Variant *)p_self; const Variant *self = (const Variant *)p_self;
memnew_placement_custom(r_ret, String, String(*self)); memnew_placement(r_ret, String(*self));
} }
static GDNativeVariantType gdnative_variant_get_type(const GDNativeVariantPtr p_self) { static GDNativeVariantType gdnative_variant_get_type(const GDNativeVariantPtr p_self) {
@ -288,7 +286,7 @@ static GDNativeBool gdnative_variant_has_key(const GDNativeVariantPtr p_self, co
static void gdnative_variant_get_type_name(GDNativeVariantType p_type, GDNativeStringPtr r_ret) { static void gdnative_variant_get_type_name(GDNativeVariantType p_type, GDNativeStringPtr r_ret) {
String name = Variant::get_type_name((Variant::Type)p_type); String name = Variant::get_type_name((Variant::Type)p_type);
memnew_placement_custom(r_ret, String, String(name)); memnew_placement(r_ret, String(name));
} }
static GDNativeBool gdnative_variant_can_convert(GDNativeVariantType p_from, GDNativeVariantType p_to) { static GDNativeBool gdnative_variant_can_convert(GDNativeVariantType p_from, GDNativeVariantType p_to) {
@ -508,7 +506,7 @@ static GDNativePtrKeyedChecker gdnative_variant_get_ptr_keyed_checker(GDNativeVa
return (GDNativePtrKeyedChecker)Variant::get_member_ptr_keyed_checker(Variant::Type(p_type)); return (GDNativePtrKeyedChecker)Variant::get_member_ptr_keyed_checker(Variant::Type(p_type));
} }
static void gdnative_variant_get_constant_value(GDNativeVariantType p_type, const char *p_constant, GDNativeVariantPtr r_ret) { static void gdnative_variant_get_constant_value(GDNativeVariantType p_type, const char *p_constant, GDNativeVariantPtr r_ret) {
memnew_placement_custom(r_ret, Variant, Variant(Variant::get_constant_value(Variant::Type(p_type), p_constant))); memnew_placement(r_ret, Variant(Variant::get_constant_value(Variant::Type(p_type), p_constant)));
} }
static GDNativePtrUtilityFunction gdnative_variant_get_ptr_utility_function(const char *p_function, GDNativeInt p_hash) { static GDNativePtrUtilityFunction gdnative_variant_get_ptr_utility_function(const char *p_function, GDNativeInt p_hash) {
StringName function = p_function; StringName function = p_function;

View File

@ -35,6 +35,7 @@
#include "core/templates/safe_refcount.h" #include "core/templates/safe_refcount.h"
#include <stddef.h> #include <stddef.h>
#include <new>
#ifndef PAD_ALIGN #ifndef PAD_ALIGN
#define PAD_ALIGN 16 //must always be greater than this at much #define PAD_ALIGN 16 //must always be greater than this at much
@ -92,15 +93,8 @@ _ALWAYS_INLINE_ T *_post_initialize(T *p_obj) {
#define memnew(m_class) _post_initialize(new ("") m_class) #define memnew(m_class) _post_initialize(new ("") m_class)
_ALWAYS_INLINE_ void *operator new(size_t p_size, void *p_pointer, size_t check, const char *p_description) {
//void *failptr=0;
//ERR_FAIL_COND_V( check < p_size , failptr); /** bug, or strange compiler, most likely */
return p_pointer;
}
#define memnew_allocator(m_class, m_allocator) _post_initialize(new (m_allocator::alloc) m_class) #define memnew_allocator(m_class, m_allocator) _post_initialize(new (m_allocator::alloc) m_class)
#define memnew_placement(m_placement, m_class) _post_initialize(new (m_placement, sizeof(m_class), "") m_class) #define memnew_placement(m_placement, m_class) _post_initialize(new (m_placement) m_class)
_ALWAYS_INLINE_ bool predelete_handler(void *) { _ALWAYS_INLINE_ bool predelete_handler(void *) {
return true; return true;
@ -140,7 +134,7 @@ void memdelete_allocator(T *p_class) {
#define memnew_arr(m_class, m_count) memnew_arr_template<m_class>(m_count) #define memnew_arr(m_class, m_count) memnew_arr_template<m_class>(m_count)
template <typename T> template <typename T>
T *memnew_arr_template(size_t p_elements, const char *p_descr = "") { T *memnew_arr_template(size_t p_elements) {
if (p_elements == 0) { if (p_elements == 0) {
return nullptr; return nullptr;
} }
@ -158,7 +152,7 @@ T *memnew_arr_template(size_t p_elements, const char *p_descr = "") {
/* call operator new */ /* call operator new */
for (size_t i = 0; i < p_elements; i++) { for (size_t i = 0; i < p_elements; i++) {
new (&elems[i], sizeof(T), p_descr) T; new (&elems[i]) T;
} }
} }

View File

@ -232,7 +232,7 @@ uint32_t CowData<T>::_copy_on_write() {
uint32_t *mem_new = (uint32_t *)Memory::alloc_static(_get_alloc_size(current_size), true); uint32_t *mem_new = (uint32_t *)Memory::alloc_static(_get_alloc_size(current_size), true);
new (mem_new - 2, sizeof(uint32_t), "") SafeNumeric<uint32_t>(1); //refcount new (mem_new - 2) SafeNumeric<uint32_t>(1); //refcount
*(mem_new - 1) = current_size; //size *(mem_new - 1) = current_size; //size
T *_data = (T *)(mem_new); T *_data = (T *)(mem_new);
@ -286,14 +286,14 @@ Error CowData<T>::resize(int p_size) {
uint32_t *ptr = (uint32_t *)Memory::alloc_static(alloc_size, true); uint32_t *ptr = (uint32_t *)Memory::alloc_static(alloc_size, true);
ERR_FAIL_COND_V(!ptr, ERR_OUT_OF_MEMORY); ERR_FAIL_COND_V(!ptr, ERR_OUT_OF_MEMORY);
*(ptr - 1) = 0; //size, currently none *(ptr - 1) = 0; //size, currently none
new (ptr - 2, sizeof(uint32_t), "") SafeNumeric<uint32_t>(1); //refcount new (ptr - 2) SafeNumeric<uint32_t>(1); //refcount
_ptr = (T *)ptr; _ptr = (T *)ptr;
} else { } else {
uint32_t *_ptrnew = (uint32_t *)Memory::realloc_static(_ptr, alloc_size, true); uint32_t *_ptrnew = (uint32_t *)Memory::realloc_static(_ptr, alloc_size, true);
ERR_FAIL_COND_V(!_ptrnew, ERR_OUT_OF_MEMORY); ERR_FAIL_COND_V(!_ptrnew, ERR_OUT_OF_MEMORY);
new (_ptrnew - 2, sizeof(uint32_t), "") SafeNumeric<uint32_t>(rc); //refcount new (_ptrnew - 2) SafeNumeric<uint32_t>(rc); //refcount
_ptr = (T *)(_ptrnew); _ptr = (T *)(_ptrnew);
} }
@ -323,7 +323,7 @@ Error CowData<T>::resize(int p_size) {
if (alloc_size != current_alloc_size) { if (alloc_size != current_alloc_size) {
uint32_t *_ptrnew = (uint32_t *)Memory::realloc_static(_ptr, alloc_size, true); uint32_t *_ptrnew = (uint32_t *)Memory::realloc_static(_ptr, alloc_size, true);
ERR_FAIL_COND_V(!_ptrnew, ERR_OUT_OF_MEMORY); ERR_FAIL_COND_V(!_ptrnew, ERR_OUT_OF_MEMORY);
new (_ptrnew - 2, sizeof(uint32_t), "") SafeNumeric<uint32_t>(rc); //refcount new (_ptrnew - 2) SafeNumeric<uint32_t>(rc); //refcount
_ptr = (T *)(_ptrnew); _ptr = (T *)(_ptrnew);
} }

View File

@ -51,8 +51,6 @@ static_assert(sizeof(godot_packed_color_array) == sizeof(PackedColorArray), "Pac
extern "C" { extern "C" {
#endif #endif
#define memnew_placement_custom(m_placement, m_class, m_constr) _post_initialize(new (m_placement, sizeof(m_class), "") m_constr)
// byte // byte
void GDAPI godot_packed_byte_array_new(godot_packed_byte_array *p_self) { void GDAPI godot_packed_byte_array_new(godot_packed_byte_array *p_self) {

View File

@ -48,8 +48,6 @@ static_assert(sizeof(godot_variant) == sizeof(Variant), "Variant size mismatch")
#pragma GCC optimize("-O0") #pragma GCC optimize("-O0")
#endif #endif
#define memnew_placement_custom(m_placement, m_class, m_constr) _post_initialize(new (m_placement, sizeof(m_class), "") m_constr)
#if defined(__arm__) && defined(__GNUC__) && !defined(__clang__) && \ #if defined(__arm__) && defined(__GNUC__) && !defined(__clang__) && \
(__GNUC__ == 6 || (__GNUC__ == 7 && __GNUC_MINOR__ < 4) || (__GNUC__ == 8 && __GNUC_MINOR__ < 1)) (__GNUC__ == 6 || (__GNUC__ == 7 && __GNUC_MINOR__ < 4) || (__GNUC__ == 8 && __GNUC_MINOR__ < 1))
#pragma GCC pop_options #pragma GCC pop_options
@ -70,131 +68,131 @@ void GDAPI godot_variant_new_nil(godot_variant *r_dest) {
void GDAPI godot_variant_new_bool(godot_variant *r_dest, const godot_bool p_b) { void GDAPI godot_variant_new_bool(godot_variant *r_dest, const godot_bool p_b) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
memnew_placement_custom(dest, Variant, Variant(p_b)); memnew_placement(dest, Variant(p_b));
} }
void GDAPI godot_variant_new_int(godot_variant *r_dest, const godot_int p_i) { void GDAPI godot_variant_new_int(godot_variant *r_dest, const godot_int p_i) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
memnew_placement_custom(dest, Variant, Variant(p_i)); memnew_placement(dest, Variant(p_i));
} }
void GDAPI godot_variant_new_float(godot_variant *r_dest, const godot_float p_r) { void GDAPI godot_variant_new_float(godot_variant *r_dest, const godot_float p_r) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
memnew_placement_custom(dest, Variant, Variant(p_r)); memnew_placement(dest, Variant(p_r));
} }
void GDAPI godot_variant_new_string(godot_variant *r_dest, const godot_string *p_s) { void GDAPI godot_variant_new_string(godot_variant *r_dest, const godot_string *p_s) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const String *s = (const String *)p_s; const String *s = (const String *)p_s;
memnew_placement_custom(dest, Variant, Variant(*s)); memnew_placement(dest, Variant(*s));
} }
void GDAPI godot_variant_new_string_name(godot_variant *r_dest, const godot_string_name *p_s) { void GDAPI godot_variant_new_string_name(godot_variant *r_dest, const godot_string_name *p_s) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const StringName *s = (const StringName *)p_s; const StringName *s = (const StringName *)p_s;
memnew_placement_custom(dest, Variant, Variant(*s)); memnew_placement(dest, Variant(*s));
} }
void GDAPI godot_variant_new_vector2(godot_variant *r_dest, const godot_vector2 *p_v2) { void GDAPI godot_variant_new_vector2(godot_variant *r_dest, const godot_vector2 *p_v2) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Vector2 *v2 = (const Vector2 *)p_v2; const Vector2 *v2 = (const Vector2 *)p_v2;
memnew_placement_custom(dest, Variant, Variant(*v2)); memnew_placement(dest, Variant(*v2));
} }
void GDAPI godot_variant_new_vector2i(godot_variant *r_dest, const godot_vector2i *p_v2) { void GDAPI godot_variant_new_vector2i(godot_variant *r_dest, const godot_vector2i *p_v2) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Vector2i *v2 = (const Vector2i *)p_v2; const Vector2i *v2 = (const Vector2i *)p_v2;
memnew_placement_custom(dest, Variant, Variant(*v2)); memnew_placement(dest, Variant(*v2));
} }
void GDAPI godot_variant_new_rect2(godot_variant *r_dest, const godot_rect2 *p_rect2) { void GDAPI godot_variant_new_rect2(godot_variant *r_dest, const godot_rect2 *p_rect2) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Rect2 *rect2 = (const Rect2 *)p_rect2; const Rect2 *rect2 = (const Rect2 *)p_rect2;
memnew_placement_custom(dest, Variant, Variant(*rect2)); memnew_placement(dest, Variant(*rect2));
} }
void GDAPI godot_variant_new_rect2i(godot_variant *r_dest, const godot_rect2i *p_rect2) { void GDAPI godot_variant_new_rect2i(godot_variant *r_dest, const godot_rect2i *p_rect2) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Rect2i *rect2 = (const Rect2i *)p_rect2; const Rect2i *rect2 = (const Rect2i *)p_rect2;
memnew_placement_custom(dest, Variant, Variant(*rect2)); memnew_placement(dest, Variant(*rect2));
} }
void GDAPI godot_variant_new_vector3(godot_variant *r_dest, const godot_vector3 *p_v3) { void GDAPI godot_variant_new_vector3(godot_variant *r_dest, const godot_vector3 *p_v3) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Vector3 *v3 = (const Vector3 *)p_v3; const Vector3 *v3 = (const Vector3 *)p_v3;
memnew_placement_custom(dest, Variant, Variant(*v3)); memnew_placement(dest, Variant(*v3));
} }
void GDAPI godot_variant_new_vector3i(godot_variant *r_dest, const godot_vector3i *p_v3) { void GDAPI godot_variant_new_vector3i(godot_variant *r_dest, const godot_vector3i *p_v3) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Vector3i *v3 = (const Vector3i *)p_v3; const Vector3i *v3 = (const Vector3i *)p_v3;
memnew_placement_custom(dest, Variant, Variant(*v3)); memnew_placement(dest, Variant(*v3));
} }
void GDAPI godot_variant_new_transform2d(godot_variant *r_dest, const godot_transform2d *p_t2d) { void GDAPI godot_variant_new_transform2d(godot_variant *r_dest, const godot_transform2d *p_t2d) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Transform2D *t2d = (const Transform2D *)p_t2d; const Transform2D *t2d = (const Transform2D *)p_t2d;
memnew_placement_custom(dest, Variant, Variant(*t2d)); memnew_placement(dest, Variant(*t2d));
} }
void GDAPI godot_variant_new_plane(godot_variant *r_dest, const godot_plane *p_plane) { void GDAPI godot_variant_new_plane(godot_variant *r_dest, const godot_plane *p_plane) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Plane *plane = (const Plane *)p_plane; const Plane *plane = (const Plane *)p_plane;
memnew_placement_custom(dest, Variant, Variant(*plane)); memnew_placement(dest, Variant(*plane));
} }
void GDAPI godot_variant_new_quaternion(godot_variant *r_dest, const godot_quaternion *p_quaternion) { void GDAPI godot_variant_new_quaternion(godot_variant *r_dest, const godot_quaternion *p_quaternion) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Quaternion *quaternion = (const Quaternion *)p_quaternion; const Quaternion *quaternion = (const Quaternion *)p_quaternion;
memnew_placement_custom(dest, Variant, Variant(*quaternion)); memnew_placement(dest, Variant(*quaternion));
} }
void GDAPI godot_variant_new_aabb(godot_variant *r_dest, const godot_aabb *p_aabb) { void GDAPI godot_variant_new_aabb(godot_variant *r_dest, const godot_aabb *p_aabb) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const AABB *aabb = (const AABB *)p_aabb; const AABB *aabb = (const AABB *)p_aabb;
memnew_placement_custom(dest, Variant, Variant(*aabb)); memnew_placement(dest, Variant(*aabb));
} }
void GDAPI godot_variant_new_basis(godot_variant *r_dest, const godot_basis *p_basis) { void GDAPI godot_variant_new_basis(godot_variant *r_dest, const godot_basis *p_basis) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Basis *basis = (const Basis *)p_basis; const Basis *basis = (const Basis *)p_basis;
memnew_placement_custom(dest, Variant, Variant(*basis)); memnew_placement(dest, Variant(*basis));
} }
void GDAPI godot_variant_new_transform3d(godot_variant *r_dest, const godot_transform3d *p_trans) { void GDAPI godot_variant_new_transform3d(godot_variant *r_dest, const godot_transform3d *p_trans) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Transform3D *trans = (const Transform3D *)p_trans; const Transform3D *trans = (const Transform3D *)p_trans;
memnew_placement_custom(dest, Variant, Variant(*trans)); memnew_placement(dest, Variant(*trans));
} }
void GDAPI godot_variant_new_color(godot_variant *r_dest, const godot_color *p_color) { void GDAPI godot_variant_new_color(godot_variant *r_dest, const godot_color *p_color) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Color *color = (const Color *)p_color; const Color *color = (const Color *)p_color;
memnew_placement_custom(dest, Variant, Variant(*color)); memnew_placement(dest, Variant(*color));
} }
void GDAPI godot_variant_new_node_path(godot_variant *r_dest, const godot_node_path *p_np) { void GDAPI godot_variant_new_node_path(godot_variant *r_dest, const godot_node_path *p_np) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const NodePath *np = (const NodePath *)p_np; const NodePath *np = (const NodePath *)p_np;
memnew_placement_custom(dest, Variant, Variant(*np)); memnew_placement(dest, Variant(*np));
} }
void GDAPI godot_variant_new_rid(godot_variant *r_dest, const godot_rid *p_rid) { void GDAPI godot_variant_new_rid(godot_variant *r_dest, const godot_rid *p_rid) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const RID *rid = (const RID *)p_rid; const RID *rid = (const RID *)p_rid;
memnew_placement_custom(dest, Variant, Variant(*rid)); memnew_placement(dest, Variant(*rid));
} }
void GDAPI godot_variant_new_callable(godot_variant *r_dest, const godot_callable *p_cb) { void GDAPI godot_variant_new_callable(godot_variant *r_dest, const godot_callable *p_cb) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Callable *cb = (const Callable *)p_cb; const Callable *cb = (const Callable *)p_cb;
memnew_placement_custom(dest, Variant, Variant(*cb)); memnew_placement(dest, Variant(*cb));
} }
void GDAPI godot_variant_new_signal(godot_variant *r_dest, const godot_signal *p_signal) { void GDAPI godot_variant_new_signal(godot_variant *r_dest, const godot_signal *p_signal) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Signal *signal = (const Signal *)p_signal; const Signal *signal = (const Signal *)p_signal;
memnew_placement_custom(dest, Variant, Variant(*signal)); memnew_placement(dest, Variant(*signal));
} }
void GDAPI godot_variant_new_object(godot_variant *r_dest, const godot_object *p_obj) { void GDAPI godot_variant_new_object(godot_variant *r_dest, const godot_object *p_obj) {
@ -206,81 +204,81 @@ void GDAPI godot_variant_new_object(godot_variant *r_dest, const godot_object *p
ref = REF(ref_counted); ref = REF(ref_counted);
} }
if (!ref.is_null()) { if (!ref.is_null()) {
memnew_placement_custom(dest, Variant, Variant(ref)); memnew_placement(dest, Variant(ref));
} else { } else {
#if defined(DEBUG_METHODS_ENABLED) #if defined(DEBUG_METHODS_ENABLED)
if (ref_counted) { if (ref_counted) {
ERR_PRINT("RefCounted object has 0 refcount in godot_variant_new_object - you lost it somewhere."); ERR_PRINT("RefCounted object has 0 refcount in godot_variant_new_object - you lost it somewhere.");
} }
#endif #endif
memnew_placement_custom(dest, Variant, Variant(obj)); memnew_placement(dest, Variant(obj));
} }
} }
void GDAPI godot_variant_new_dictionary(godot_variant *r_dest, const godot_dictionary *p_dict) { void GDAPI godot_variant_new_dictionary(godot_variant *r_dest, const godot_dictionary *p_dict) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Dictionary *dict = (const Dictionary *)p_dict; const Dictionary *dict = (const Dictionary *)p_dict;
memnew_placement_custom(dest, Variant, Variant(*dict)); memnew_placement(dest, Variant(*dict));
} }
void GDAPI godot_variant_new_array(godot_variant *r_dest, const godot_array *p_arr) { void GDAPI godot_variant_new_array(godot_variant *r_dest, const godot_array *p_arr) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const Array *arr = (const Array *)p_arr; const Array *arr = (const Array *)p_arr;
memnew_placement_custom(dest, Variant, Variant(*arr)); memnew_placement(dest, Variant(*arr));
} }
void GDAPI godot_variant_new_packed_byte_array(godot_variant *r_dest, const godot_packed_byte_array *p_pba) { void GDAPI godot_variant_new_packed_byte_array(godot_variant *r_dest, const godot_packed_byte_array *p_pba) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedByteArray *pba = (const PackedByteArray *)p_pba; const PackedByteArray *pba = (const PackedByteArray *)p_pba;
memnew_placement_custom(dest, Variant, Variant(*pba)); memnew_placement(dest, Variant(*pba));
} }
void GDAPI godot_variant_new_packed_int32_array(godot_variant *r_dest, const godot_packed_int32_array *p_pia) { void GDAPI godot_variant_new_packed_int32_array(godot_variant *r_dest, const godot_packed_int32_array *p_pia) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedInt32Array *pia = (const PackedInt32Array *)p_pia; const PackedInt32Array *pia = (const PackedInt32Array *)p_pia;
memnew_placement_custom(dest, Variant, Variant(*pia)); memnew_placement(dest, Variant(*pia));
} }
void GDAPI godot_variant_new_packed_int64_array(godot_variant *r_dest, const godot_packed_int64_array *p_pia) { void GDAPI godot_variant_new_packed_int64_array(godot_variant *r_dest, const godot_packed_int64_array *p_pia) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedInt64Array *pia = (const PackedInt64Array *)p_pia; const PackedInt64Array *pia = (const PackedInt64Array *)p_pia;
memnew_placement_custom(dest, Variant, Variant(*pia)); memnew_placement(dest, Variant(*pia));
} }
void GDAPI godot_variant_new_packed_float32_array(godot_variant *r_dest, const godot_packed_float32_array *p_pra) { void GDAPI godot_variant_new_packed_float32_array(godot_variant *r_dest, const godot_packed_float32_array *p_pra) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedFloat32Array *pra = (const PackedFloat32Array *)p_pra; const PackedFloat32Array *pra = (const PackedFloat32Array *)p_pra;
memnew_placement_custom(dest, Variant, Variant(*pra)); memnew_placement(dest, Variant(*pra));
} }
void GDAPI godot_variant_new_packed_float64_array(godot_variant *r_dest, const godot_packed_float64_array *p_pra) { void GDAPI godot_variant_new_packed_float64_array(godot_variant *r_dest, const godot_packed_float64_array *p_pra) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedFloat64Array *pra = (const PackedFloat64Array *)p_pra; const PackedFloat64Array *pra = (const PackedFloat64Array *)p_pra;
memnew_placement_custom(dest, Variant, Variant(*pra)); memnew_placement(dest, Variant(*pra));
} }
void GDAPI godot_variant_new_packed_string_array(godot_variant *r_dest, const godot_packed_string_array *p_psa) { void GDAPI godot_variant_new_packed_string_array(godot_variant *r_dest, const godot_packed_string_array *p_psa) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedStringArray *psa = (const PackedStringArray *)p_psa; const PackedStringArray *psa = (const PackedStringArray *)p_psa;
memnew_placement_custom(dest, Variant, Variant(*psa)); memnew_placement(dest, Variant(*psa));
} }
void GDAPI godot_variant_new_packed_vector2_array(godot_variant *r_dest, const godot_packed_vector2_array *p_pv2a) { void GDAPI godot_variant_new_packed_vector2_array(godot_variant *r_dest, const godot_packed_vector2_array *p_pv2a) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedVector2Array *pv2a = (const PackedVector2Array *)p_pv2a; const PackedVector2Array *pv2a = (const PackedVector2Array *)p_pv2a;
memnew_placement_custom(dest, Variant, Variant(*pv2a)); memnew_placement(dest, Variant(*pv2a));
} }
void GDAPI godot_variant_new_packed_vector3_array(godot_variant *r_dest, const godot_packed_vector3_array *p_pv3a) { void GDAPI godot_variant_new_packed_vector3_array(godot_variant *r_dest, const godot_packed_vector3_array *p_pv3a) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedVector3Array *pv3a = (const PackedVector3Array *)p_pv3a; const PackedVector3Array *pv3a = (const PackedVector3Array *)p_pv3a;
memnew_placement_custom(dest, Variant, Variant(*pv3a)); memnew_placement(dest, Variant(*pv3a));
} }
void GDAPI godot_variant_new_packed_color_array(godot_variant *r_dest, const godot_packed_color_array *p_pca) { void GDAPI godot_variant_new_packed_color_array(godot_variant *r_dest, const godot_packed_color_array *p_pca) {
Variant *dest = (Variant *)r_dest; Variant *dest = (Variant *)r_dest;
const PackedColorArray *pca = (const PackedColorArray *)p_pca; const PackedColorArray *pca = (const PackedColorArray *)p_pca;
memnew_placement_custom(dest, Variant, Variant(*pca)); memnew_placement(dest, Variant(*pca));
} }
godot_bool GDAPI godot_variant_as_bool(const godot_variant *p_self) { godot_bool GDAPI godot_variant_as_bool(const godot_variant *p_self) {
@ -568,7 +566,7 @@ void GDAPI godot_variant_call(godot_variant *p_self, const godot_string_name *p_
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
self->call(*method, args, p_argcount, ret, error); self->call(*method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (godot_variant_call_error_error)error.error; r_error->error = (godot_variant_call_error_error)error.error;
@ -584,7 +582,7 @@ void GDAPI godot_variant_call_with_cstring(godot_variant *p_self, const char *p_
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
self->call(method, args, p_argcount, ret, error); self->call(method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (godot_variant_call_error_error)error.error; r_error->error = (godot_variant_call_error_error)error.error;
@ -600,7 +598,7 @@ void GDAPI godot_variant_call_static(godot_variant_type p_type, const godot_stri
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
Variant::call_static(type, *method, args, p_argcount, ret, error); Variant::call_static(type, *method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (godot_variant_call_error_error)error.error; r_error->error = (godot_variant_call_error_error)error.error;
@ -616,7 +614,7 @@ void GDAPI godot_variant_call_static_with_cstring(godot_variant_type p_type, con
Variant ret; Variant ret;
Callable::CallError error; Callable::CallError error;
Variant::call_static(type, method, args, p_argcount, ret, error); Variant::call_static(type, method, args, p_argcount, ret, error);
memnew_placement_custom(r_return, Variant, Variant(ret)); memnew_placement(r_return, Variant(ret));
if (r_error) { if (r_error) {
r_error->error = (godot_variant_call_error_error)error.error; r_error->error = (godot_variant_call_error_error)error.error;
@ -679,7 +677,7 @@ godot_variant GDAPI godot_variant_get(const godot_variant *p_self, const godot_v
ret = self->get(*key, r_valid); ret = self->get(*key, r_valid);
godot_variant result; godot_variant result;
memnew_placement_custom(&result, Variant, Variant(ret)); memnew_placement(&result, Variant(ret));
return result; return result;
} }
@ -690,7 +688,7 @@ godot_variant GDAPI godot_variant_get_named(const godot_variant *p_self, const g
ret = self->get_named(*key, *r_valid); ret = self->get_named(*key, *r_valid);
godot_variant result; godot_variant result;
memnew_placement_custom(&result, Variant, Variant(ret)); memnew_placement(&result, Variant(ret));
return result; return result;
} }
@ -701,7 +699,7 @@ godot_variant GDAPI godot_variant_get_named_with_cstring(const godot_variant *p_
ret = self->get_named(*key, *r_valid); ret = self->get_named(*key, *r_valid);
godot_variant result; godot_variant result;
memnew_placement_custom(&result, Variant, Variant(ret)); memnew_placement(&result, Variant(ret));
return result; return result;
} }
@ -712,7 +710,7 @@ godot_variant GDAPI godot_variant_get_keyed(const godot_variant *p_self, const g
ret = self->get_keyed(*key, *r_valid); ret = self->get_keyed(*key, *r_valid);
godot_variant result; godot_variant result;
memnew_placement_custom(&result, Variant, Variant(ret)); memnew_placement(&result, Variant(ret));
return result; return result;
} }
@ -722,7 +720,7 @@ godot_variant GDAPI godot_variant_get_indexed(const godot_variant *p_self, godot
ret = self->get_indexed(p_index, *r_valid, *r_oob); ret = self->get_indexed(p_index, *r_valid, *r_oob);
godot_variant result; godot_variant result;
memnew_placement_custom(&result, Variant, Variant(ret)); memnew_placement(&result, Variant(ret));
return result; return result;
} }
@ -747,7 +745,7 @@ godot_variant GDAPI godot_variant_iter_get(const godot_variant *p_self, godot_va
Variant result = self->iter_next(*iter, *r_valid); Variant result = self->iter_next(*iter, *r_valid);
godot_variant ret; godot_variant ret;
memnew_placement_custom(&ret, Variant, Variant(result)); memnew_placement(&ret, Variant(result));
return ret; return ret;
} }
@ -781,7 +779,7 @@ godot_variant GDAPI godot_variant_duplicate(const godot_variant *p_self, godot_b
const Variant *self = (const Variant *)p_self; const Variant *self = (const Variant *)p_self;
Variant result = self->duplicate(p_deep); Variant result = self->duplicate(p_deep);
godot_variant ret; godot_variant ret;
memnew_placement_custom(&ret, Variant, Variant(result)); memnew_placement(&ret, Variant(result));
return ret; return ret;
} }
@ -789,7 +787,7 @@ godot_string GDAPI godot_variant_stringify(const godot_variant *p_self) {
const Variant *self = (const Variant *)p_self; const Variant *self = (const Variant *)p_self;
String result = *self; String result = *self;
godot_string ret; godot_string ret;
memnew_placement_custom(&ret, String, String(result)); memnew_placement(&ret, String(result));
return ret; return ret;
} }
@ -811,7 +809,7 @@ godot_variant_type GDAPI godot_variant_get_operator_return_type(godot_variant_op
godot_string GDAPI godot_variant_get_operator_name(godot_variant_operator p_operator) { godot_string GDAPI godot_variant_get_operator_name(godot_variant_operator p_operator) {
String op_name = Variant::get_operator_name((Variant::Operator)p_operator); String op_name = Variant::get_operator_name((Variant::Operator)p_operator);
godot_string ret; godot_string ret;
memnew_placement_custom(&ret, String, String(op_name)); memnew_placement(&ret, String(op_name));
return ret; return ret;
} }
@ -916,7 +914,7 @@ void GDAPI godot_variant_get_builtin_method_list(godot_variant_type p_type, godo
Variant::get_builtin_method_list((Variant::Type)p_type, &list); Variant::get_builtin_method_list((Variant::Type)p_type, &list);
int i = 0; int i = 0;
for (const StringName &E : list) { for (const StringName &E : list) {
memnew_placement_custom(&r_list[i], StringName, StringName(E)); memnew_placement(&r_list[i], StringName(E));
} }
} }
@ -971,7 +969,7 @@ void GDAPI godot_variant_get_member_list(godot_variant_type p_type, godot_string
Variant::get_member_list((Variant::Type)p_type, &members); Variant::get_member_list((Variant::Type)p_type, &members);
int i = 0; int i = 0;
for (const StringName &E : members) { for (const StringName &E : members) {
memnew_placement_custom(&r_list[i++], StringName, StringName(E)); memnew_placement(&r_list[i++], StringName(E));
} }
} }
@ -1076,7 +1074,7 @@ void GDAPI godot_variant_get_constants_list(godot_variant_type p_type, godot_str
int i = 0; int i = 0;
Variant::get_constants_for_type((Variant::Type)p_type, &constants); Variant::get_constants_for_type((Variant::Type)p_type, &constants);
for (const StringName &E : constants) { for (const StringName &E : constants) {
memnew_placement_custom(&r_list[i++], StringName, StringName(E)); memnew_placement(&r_list[i++], StringName(E));
} }
} }
@ -1091,14 +1089,14 @@ bool GDAPI godot_variant_has_constant_with_cstring(godot_variant_type p_type, co
godot_variant GDAPI godot_variant_get_constant_value(godot_variant_type p_type, const godot_string_name *p_constant) { godot_variant GDAPI godot_variant_get_constant_value(godot_variant_type p_type, const godot_string_name *p_constant) {
Variant constant = Variant::get_constant_value((Variant::Type)p_type, *((const StringName *)p_constant)); Variant constant = Variant::get_constant_value((Variant::Type)p_type, *((const StringName *)p_constant));
godot_variant ret; godot_variant ret;
memnew_placement_custom(&ret, Variant, Variant(constant)); memnew_placement(&ret, Variant(constant));
return ret; return ret;
} }
godot_variant GDAPI godot_variant_get_constant_value_with_cstring(godot_variant_type p_type, const char *p_constant) { godot_variant GDAPI godot_variant_get_constant_value_with_cstring(godot_variant_type p_type, const char *p_constant) {
Variant constant = Variant::get_constant_value((Variant::Type)p_type, StringName(p_constant)); Variant constant = Variant::get_constant_value((Variant::Type)p_type, StringName(p_constant));
godot_variant ret; godot_variant ret;
memnew_placement_custom(&ret, Variant, Variant(constant)); memnew_placement(&ret, Variant(constant));
return ret; return ret;
} }
@ -1183,14 +1181,14 @@ godot_variant_type GDAPI godot_variant_get_utility_function_argument_type_with_c
godot_string GDAPI godot_variant_get_utility_function_argument_name(const godot_string_name *p_function, int p_argument) { godot_string GDAPI godot_variant_get_utility_function_argument_name(const godot_string_name *p_function, int p_argument) {
String argument_name = Variant::get_utility_function_argument_name(*((const StringName *)p_function), p_argument); String argument_name = Variant::get_utility_function_argument_name(*((const StringName *)p_function), p_argument);
godot_string ret; godot_string ret;
memnew_placement_custom(&ret, String, String(argument_name)); memnew_placement(&ret, String(argument_name));
return ret; return ret;
} }
godot_string GDAPI godot_variant_get_utility_function_argument_name_with_cstring(const char *p_function, int p_argument) { godot_string GDAPI godot_variant_get_utility_function_argument_name_with_cstring(const char *p_function, int p_argument) {
String argument_name = Variant::get_utility_function_argument_name(StringName(p_function), p_argument); String argument_name = Variant::get_utility_function_argument_name(StringName(p_function), p_argument);
godot_string ret; godot_string ret;
memnew_placement_custom(&ret, String, String(argument_name)); memnew_placement(&ret, String(argument_name));
return ret; return ret;
} }
@ -1228,7 +1226,7 @@ void GDAPI godot_variant_get_utility_function_list(godot_string_name *r_function
Variant::get_utility_function_list(&functions); Variant::get_utility_function_list(&functions);
for (const StringName &E : functions) { for (const StringName &E : functions) {
memnew_placement_custom(func++, StringName, StringName(E)); memnew_placement(func++, StringName(E));
} }
} }
@ -1258,7 +1256,7 @@ bool GDAPI godot_variant_has_key(const godot_variant *p_self, const godot_varian
godot_string GDAPI godot_variant_get_type_name(godot_variant_type p_type) { godot_string GDAPI godot_variant_get_type_name(godot_variant_type p_type) {
String name = Variant::get_type_name((Variant::Type)p_type); String name = Variant::get_type_name((Variant::Type)p_type);
godot_string ret; godot_string ret;
memnew_placement_custom(&ret, String, String(name)); memnew_placement(&ret, String(name));
return ret; return ret;
} }