summaryrefslogtreecommitdiffstats
path: root/core/extension/gdextension_interface.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'core/extension/gdextension_interface.cpp')
-rw-r--r--core/extension/gdextension_interface.cpp597
1 files changed, 305 insertions, 292 deletions
diff --git a/core/extension/gdextension_interface.cpp b/core/extension/gdextension_interface.cpp
index 2bedb623e4..7fbf2d00a1 100644
--- a/core/extension/gdextension_interface.cpp
+++ b/core/extension/gdextension_interface.cpp
@@ -31,6 +31,7 @@
#include "gdextension_interface.h"
#include "core/config/engine.h"
+#include "core/extension/gdextension.h"
#include "core/io/file_access.h"
#include "core/io/xml_parser.h"
#include "core/object/class_db.h"
@@ -40,16 +41,28 @@
#include "core/variant/variant.h"
#include "core/version.h"
+// Core interface functions.
+GDExtensionInterfaceFunctionPtr gdextension_get_proc_address(const char *p_name) {
+ return GDExtension::get_interface_function(p_name);
+}
+
+static void gdextension_get_godot_version(GDExtensionGodotVersion *r_godot_version) {
+ r_godot_version->major = VERSION_MAJOR;
+ r_godot_version->minor = VERSION_MINOR;
+ r_godot_version->patch = VERSION_PATCH;
+ r_godot_version->string = VERSION_FULL_NAME;
+}
+
// Memory Functions
-static void *gdextension_alloc(size_t p_size) {
+static void *gdextension_mem_alloc(size_t p_size) {
return memalloc(p_size);
}
-static void *gdextension_realloc(void *p_mem, size_t p_size) {
+static void *gdextension_mem_realloc(void *p_mem, size_t p_size) {
return memrealloc(p_mem, p_size);
}
-static void gdextension_free(void *p_mem) {
+static void gdextension_mem_free(void *p_mem) {
memfree(p_mem);
}
@@ -80,10 +93,10 @@ uint64_t gdextension_get_native_struct_size(GDExtensionConstStringNamePtr p_name
// Variant functions
-static void gdextension_variant_new_copy(GDExtensionVariantPtr r_dest, GDExtensionConstVariantPtr p_src) {
+static void gdextension_variant_new_copy(GDExtensionUninitializedVariantPtr r_dest, GDExtensionConstVariantPtr p_src) {
memnew_placement(reinterpret_cast<Variant *>(r_dest), Variant(*reinterpret_cast<const Variant *>(p_src)));
}
-static void gdextension_variant_new_nil(GDExtensionVariantPtr r_dest) {
+static void gdextension_variant_new_nil(GDExtensionUninitializedVariantPtr r_dest) {
memnew_placement(reinterpret_cast<Variant *>(r_dest), Variant);
}
static void gdextension_variant_destroy(GDExtensionVariantPtr p_self) {
@@ -92,14 +105,14 @@ static void gdextension_variant_destroy(GDExtensionVariantPtr p_self) {
// variant type
-static void gdextension_variant_call(GDExtensionVariantPtr p_self, GDExtensionConstStringNamePtr p_method, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_argcount, GDExtensionVariantPtr r_return, GDExtensionCallError *r_error) {
+static void gdextension_variant_call(GDExtensionVariantPtr p_self, GDExtensionConstStringNamePtr p_method, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_argcount, GDExtensionUninitializedVariantPtr r_return, GDExtensionCallError *r_error) {
Variant *self = (Variant *)p_self;
const StringName method = *reinterpret_cast<const StringName *>(p_method);
const Variant **args = (const Variant **)p_args;
- Variant ret;
Callable::CallError error;
- self->callp(method, args, p_argcount, ret, error);
- memnew_placement(r_return, Variant(ret));
+ memnew_placement(r_return, Variant);
+ Variant *ret = reinterpret_cast<Variant *>(r_return);
+ self->callp(method, args, p_argcount, *ret, error);
if (r_error) {
r_error->error = (GDExtensionCallErrorType)(error.error);
@@ -108,14 +121,14 @@ static void gdextension_variant_call(GDExtensionVariantPtr p_self, GDExtensionCo
}
}
-static void gdextension_variant_call_static(GDExtensionVariantType p_type, GDExtensionConstStringNamePtr p_method, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_argcount, GDExtensionVariantPtr r_return, GDExtensionCallError *r_error) {
+static void gdextension_variant_call_static(GDExtensionVariantType p_type, GDExtensionConstStringNamePtr p_method, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_argcount, GDExtensionUninitializedVariantPtr r_return, GDExtensionCallError *r_error) {
Variant::Type type = (Variant::Type)p_type;
const StringName method = *reinterpret_cast<const StringName *>(p_method);
const Variant **args = (const Variant **)p_args;
- Variant ret;
Callable::CallError error;
- Variant::call_static(type, method, args, p_argcount, ret, error);
- memnew_placement(r_return, Variant(ret));
+ memnew_placement(r_return, Variant);
+ Variant *ret = reinterpret_cast<Variant *>(r_return);
+ Variant::call_static(type, method, args, p_argcount, *ret, error);
if (r_error) {
r_error->error = (GDExtensionCallErrorType)error.error;
@@ -124,12 +137,13 @@ static void gdextension_variant_call_static(GDExtensionVariantType p_type, GDExt
}
}
-static void gdextension_variant_evaluate(GDExtensionVariantOperator p_op, GDExtensionConstVariantPtr p_a, GDExtensionConstVariantPtr p_b, GDExtensionVariantPtr r_return, GDExtensionBool *r_valid) {
+static void gdextension_variant_evaluate(GDExtensionVariantOperator p_op, GDExtensionConstVariantPtr p_a, GDExtensionConstVariantPtr p_b, GDExtensionUninitializedVariantPtr r_return, GDExtensionBool *r_valid) {
Variant::Operator op = (Variant::Operator)p_op;
const Variant *a = (const Variant *)p_a;
const Variant *b = (const Variant *)p_b;
- Variant *ret = (Variant *)r_return;
bool valid;
+ memnew_placement(r_return, Variant);
+ Variant *ret = reinterpret_cast<Variant *>(r_return);
Variant::evaluate(op, *a, *b, *ret, valid);
*r_valid = valid;
}
@@ -175,7 +189,7 @@ static void gdextension_variant_set_indexed(GDExtensionVariantPtr p_self, GDExte
*r_oob = oob;
}
-static void gdextension_variant_get(GDExtensionConstVariantPtr p_self, GDExtensionConstVariantPtr p_key, GDExtensionVariantPtr r_ret, GDExtensionBool *r_valid) {
+static void gdextension_variant_get(GDExtensionConstVariantPtr p_self, GDExtensionConstVariantPtr p_key, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool *r_valid) {
const Variant *self = (const Variant *)p_self;
const Variant *key = (const Variant *)p_key;
@@ -184,7 +198,7 @@ static void gdextension_variant_get(GDExtensionConstVariantPtr p_self, GDExtensi
*r_valid = valid;
}
-static void gdextension_variant_get_named(GDExtensionConstVariantPtr p_self, GDExtensionConstStringNamePtr p_key, GDExtensionVariantPtr r_ret, GDExtensionBool *r_valid) {
+static void gdextension_variant_get_named(GDExtensionConstVariantPtr p_self, GDExtensionConstStringNamePtr p_key, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool *r_valid) {
const Variant *self = (const Variant *)p_self;
const StringName *key = (const StringName *)p_key;
@@ -193,7 +207,7 @@ static void gdextension_variant_get_named(GDExtensionConstVariantPtr p_self, GDE
*r_valid = valid;
}
-static void gdextension_variant_get_keyed(GDExtensionConstVariantPtr p_self, GDExtensionConstVariantPtr p_key, GDExtensionVariantPtr r_ret, GDExtensionBool *r_valid) {
+static void gdextension_variant_get_keyed(GDExtensionConstVariantPtr p_self, GDExtensionConstVariantPtr p_key, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool *r_valid) {
const Variant *self = (const Variant *)p_self;
const Variant *key = (const Variant *)p_key;
@@ -202,7 +216,7 @@ static void gdextension_variant_get_keyed(GDExtensionConstVariantPtr p_self, GDE
*r_valid = valid;
}
-static void gdextension_variant_get_indexed(GDExtensionConstVariantPtr p_self, GDExtensionInt p_index, GDExtensionVariantPtr r_ret, GDExtensionBool *r_valid, GDExtensionBool *r_oob) {
+static void gdextension_variant_get_indexed(GDExtensionConstVariantPtr p_self, GDExtensionInt p_index, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool *r_valid, GDExtensionBool *r_oob) {
const Variant *self = (const Variant *)p_self;
bool valid;
@@ -213,9 +227,10 @@ static void gdextension_variant_get_indexed(GDExtensionConstVariantPtr p_self, G
}
/// Iteration.
-static GDExtensionBool gdextension_variant_iter_init(GDExtensionConstVariantPtr p_self, GDExtensionVariantPtr r_iter, GDExtensionBool *r_valid) {
+static GDExtensionBool gdextension_variant_iter_init(GDExtensionConstVariantPtr p_self, GDExtensionUninitializedVariantPtr r_iter, GDExtensionBool *r_valid) {
const Variant *self = (const Variant *)p_self;
- Variant *iter = (Variant *)r_iter;
+ memnew_placement(r_iter, Variant);
+ Variant *iter = reinterpret_cast<Variant *>(r_iter);
bool valid;
bool ret = self->iter_init(*iter, valid);
@@ -233,7 +248,7 @@ static GDExtensionBool gdextension_variant_iter_next(GDExtensionConstVariantPtr
return ret;
}
-static void gdextension_variant_iter_get(GDExtensionConstVariantPtr p_self, GDExtensionVariantPtr r_iter, GDExtensionVariantPtr r_ret, GDExtensionBool *r_valid) {
+static void gdextension_variant_iter_get(GDExtensionConstVariantPtr p_self, GDExtensionVariantPtr r_iter, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool *r_valid) {
const Variant *self = (const Variant *)p_self;
Variant *iter = (Variant *)r_iter;
@@ -264,12 +279,12 @@ static GDExtensionBool gdextension_variant_booleanize(GDExtensionConstVariantPtr
return self->booleanize();
}
-static void gdextension_variant_duplicate(GDExtensionConstVariantPtr p_self, GDExtensionVariantPtr r_ret, GDExtensionBool p_deep) {
+static void gdextension_variant_duplicate(GDExtensionConstVariantPtr p_self, GDExtensionUninitializedVariantPtr r_ret, GDExtensionBool p_deep) {
const Variant *self = (const Variant *)p_self;
memnew_placement(r_ret, Variant(self->duplicate(p_deep)));
}
-static void gdextension_variant_stringify(GDExtensionConstVariantPtr p_self, GDExtensionStringPtr r_ret) {
+static void gdextension_variant_stringify(GDExtensionConstVariantPtr p_self, GDExtensionUninitializedVariantPtr r_ret) {
const Variant *self = (const Variant *)p_self;
memnew_placement(r_ret, String(*self));
}
@@ -298,7 +313,7 @@ static GDExtensionBool gdextension_variant_has_key(GDExtensionConstVariantPtr p_
return ret;
}
-static void gdextension_variant_get_type_name(GDExtensionVariantType p_type, GDExtensionStringPtr r_ret) {
+static void gdextension_variant_get_type_name(GDExtensionVariantType p_type, GDExtensionUninitializedVariantPtr r_ret) {
String name = Variant::get_type_name((Variant::Type)p_type);
memnew_placement(r_ret, String(name));
}
@@ -395,7 +410,7 @@ static GDExtensionVariantFromTypeConstructorFunc gdextension_get_variant_from_ty
ERR_FAIL_V_MSG(nullptr, "Getting Variant conversion function with invalid type");
}
-static GDExtensionTypeFromVariantConstructorFunc gdextension_get_type_from_variant_constructor(GDExtensionVariantType p_type) {
+static GDExtensionTypeFromVariantConstructorFunc gdextension_get_variant_to_type_constructor(GDExtensionVariantType p_type) {
switch (p_type) {
case GDEXTENSION_VARIANT_TYPE_BOOL:
return VariantTypeConstructor<bool>::type_from_variant;
@@ -498,11 +513,12 @@ static GDExtensionPtrConstructor gdextension_variant_get_ptr_constructor(GDExten
static GDExtensionPtrDestructor gdextension_variant_get_ptr_destructor(GDExtensionVariantType p_type) {
return (GDExtensionPtrDestructor)Variant::get_ptr_destructor(Variant::Type(p_type));
}
-static void gdextension_variant_construct(GDExtensionVariantType p_type, GDExtensionVariantPtr p_base, const GDExtensionConstVariantPtr *p_args, int32_t p_argument_count, GDExtensionCallError *r_error) {
- memnew_placement(p_base, Variant);
+static void gdextension_variant_construct(GDExtensionVariantType p_type, GDExtensionUninitializedVariantPtr r_base, const GDExtensionConstVariantPtr *p_args, int32_t p_argument_count, GDExtensionCallError *r_error) {
+ memnew_placement(r_base, Variant);
+ Variant *base = reinterpret_cast<Variant *>(r_base);
Callable::CallError error;
- Variant::construct(Variant::Type(p_type), *(Variant *)p_base, (const Variant **)p_args, p_argument_count, error);
+ Variant::construct(Variant::Type(p_type), *base, (const Variant **)p_args, p_argument_count, error);
if (r_error) {
r_error->error = (GDExtensionCallErrorType)(error.error);
@@ -533,7 +549,7 @@ static GDExtensionPtrKeyedGetter gdextension_variant_get_ptr_keyed_getter(GDExte
static GDExtensionPtrKeyedChecker gdextension_variant_get_ptr_keyed_checker(GDExtensionVariantType p_type) {
return (GDExtensionPtrKeyedChecker)Variant::get_member_ptr_keyed_checker(Variant::Type(p_type));
}
-static void gdextension_variant_get_constant_value(GDExtensionVariantType p_type, GDExtensionConstStringNamePtr p_constant, GDExtensionVariantPtr r_ret) {
+static void gdextension_variant_get_constant_value(GDExtensionVariantType p_type, GDExtensionConstStringNamePtr p_constant, GDExtensionUninitializedVariantPtr r_ret) {
StringName constant = *reinterpret_cast<const StringName *>(p_constant);
memnew_placement(r_ret, Variant(Variant::get_constant_value(Variant::Type(p_type), constant)));
}
@@ -549,77 +565,67 @@ static GDExtensionPtrUtilityFunction gdextension_variant_get_ptr_utility_functio
//string helpers
-static void gdextension_string_new_with_latin1_chars(GDExtensionStringPtr r_dest, const char *p_contents) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
- *dest = String(p_contents);
+static void gdextension_string_new_with_latin1_chars(GDExtensionUninitializedStringPtr r_dest, const char *p_contents) {
+ memnew_placement(r_dest, String(p_contents));
}
-static void gdextension_string_new_with_utf8_chars(GDExtensionStringPtr r_dest, const char *p_contents) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
+static void gdextension_string_new_with_utf8_chars(GDExtensionUninitializedStringPtr r_dest, const char *p_contents) {
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf8(p_contents);
}
-static void gdextension_string_new_with_utf16_chars(GDExtensionStringPtr r_dest, const char16_t *p_contents) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
+static void gdextension_string_new_with_utf16_chars(GDExtensionUninitializedStringPtr r_dest, const char16_t *p_contents) {
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf16(p_contents);
}
-static void gdextension_string_new_with_utf32_chars(GDExtensionStringPtr r_dest, const char32_t *p_contents) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
- *dest = String((const char32_t *)p_contents);
+static void gdextension_string_new_with_utf32_chars(GDExtensionUninitializedStringPtr r_dest, const char32_t *p_contents) {
+ memnew_placement(r_dest, String((const char32_t *)p_contents));
}
-static void gdextension_string_new_with_wide_chars(GDExtensionStringPtr r_dest, const wchar_t *p_contents) {
- String *dest = (String *)r_dest;
+static void gdextension_string_new_with_wide_chars(GDExtensionUninitializedStringPtr r_dest, const wchar_t *p_contents) {
if constexpr (sizeof(wchar_t) == 2) {
// wchar_t is 16 bit, parse.
- memnew_placement(dest, String);
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf16((const char16_t *)p_contents);
} else {
// wchar_t is 32 bit, copy.
- memnew_placement(dest, String);
- *dest = String((const char32_t *)p_contents);
+ memnew_placement(r_dest, String((const char32_t *)p_contents));
}
}
-static void gdextension_string_new_with_latin1_chars_and_len(GDExtensionStringPtr r_dest, const char *p_contents, GDExtensionInt p_size) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
- *dest = String(p_contents, p_size);
+static void gdextension_string_new_with_latin1_chars_and_len(GDExtensionUninitializedStringPtr r_dest, const char *p_contents, GDExtensionInt p_size) {
+ memnew_placement(r_dest, String(p_contents, p_size));
}
-static void gdextension_string_new_with_utf8_chars_and_len(GDExtensionStringPtr r_dest, const char *p_contents, GDExtensionInt p_size) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
+static void gdextension_string_new_with_utf8_chars_and_len(GDExtensionUninitializedStringPtr r_dest, const char *p_contents, GDExtensionInt p_size) {
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf8(p_contents, p_size);
}
-static void gdextension_string_new_with_utf16_chars_and_len(GDExtensionStringPtr r_dest, const char16_t *p_contents, GDExtensionInt p_size) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
+static void gdextension_string_new_with_utf16_chars_and_len(GDExtensionUninitializedStringPtr r_dest, const char16_t *p_contents, GDExtensionInt p_size) {
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf16(p_contents, p_size);
}
-static void gdextension_string_new_with_utf32_chars_and_len(GDExtensionStringPtr r_dest, const char32_t *p_contents, GDExtensionInt p_size) {
- String *dest = (String *)r_dest;
- memnew_placement(dest, String);
- *dest = String((const char32_t *)p_contents, p_size);
+static void gdextension_string_new_with_utf32_chars_and_len(GDExtensionUninitializedStringPtr r_dest, const char32_t *p_contents, GDExtensionInt p_size) {
+ memnew_placement(r_dest, String((const char32_t *)p_contents, p_size));
}
-static void gdextension_string_new_with_wide_chars_and_len(GDExtensionStringPtr r_dest, const wchar_t *p_contents, GDExtensionInt p_size) {
- String *dest = (String *)r_dest;
+static void gdextension_string_new_with_wide_chars_and_len(GDExtensionUninitializedStringPtr r_dest, const wchar_t *p_contents, GDExtensionInt p_size) {
if constexpr (sizeof(wchar_t) == 2) {
// wchar_t is 16 bit, parse.
- memnew_placement(dest, String);
+ memnew_placement(r_dest, String);
+ String *dest = reinterpret_cast<String *>(r_dest);
dest->parse_utf16((const char16_t *)p_contents, p_size);
} else {
// wchar_t is 32 bit, copy.
- memnew_placement(dest, String);
- *dest = String((const char32_t *)p_contents, p_size);
+ memnew_placement(r_dest, String((const char32_t *)p_contents, p_size));
}
}
@@ -680,13 +686,17 @@ static GDExtensionInt gdextension_string_to_wide_chars(GDExtensionConstStringPtr
static char32_t *gdextension_string_operator_index(GDExtensionStringPtr p_self, GDExtensionInt p_index) {
String *self = (String *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->length() + 1, nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->length() + 1)) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const char32_t *gdextension_string_operator_index_const(GDExtensionConstStringPtr p_self, GDExtensionInt p_index) {
const String *self = (const String *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->length() + 1, nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->length() + 1)) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
@@ -747,121 +757,161 @@ static int64_t gdextension_worker_thread_pool_add_native_task(GDExtensionObjectP
static uint8_t *gdextension_packed_byte_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedByteArray *self = (PackedByteArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const uint8_t *gdextension_packed_byte_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedByteArray *self = (const PackedByteArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
static GDExtensionTypePtr gdextension_packed_color_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedColorArray *self = (PackedColorArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptrw()[p_index];
}
static GDExtensionTypePtr gdextension_packed_color_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedColorArray *self = (const PackedColorArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptr()[p_index];
}
static float *gdextension_packed_float32_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedFloat32Array *self = (PackedFloat32Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const float *gdextension_packed_float32_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedFloat32Array *self = (const PackedFloat32Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
static double *gdextension_packed_float64_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedFloat64Array *self = (PackedFloat64Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const double *gdextension_packed_float64_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedFloat64Array *self = (const PackedFloat64Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
static int32_t *gdextension_packed_int32_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedInt32Array *self = (PackedInt32Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const int32_t *gdextension_packed_int32_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedInt32Array *self = (const PackedInt32Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
static int64_t *gdextension_packed_int64_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedInt64Array *self = (PackedInt64Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptrw()[p_index];
}
static const int64_t *gdextension_packed_int64_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedInt64Array *self = (const PackedInt64Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return &self->ptr()[p_index];
}
static GDExtensionStringPtr gdextension_packed_string_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedStringArray *self = (PackedStringArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionStringPtr)&self->ptrw()[p_index];
}
static GDExtensionStringPtr gdextension_packed_string_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedStringArray *self = (const PackedStringArray *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionStringPtr)&self->ptr()[p_index];
}
static GDExtensionTypePtr gdextension_packed_vector2_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedVector2Array *self = (PackedVector2Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptrw()[p_index];
}
static GDExtensionTypePtr gdextension_packed_vector2_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedVector2Array *self = (const PackedVector2Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptr()[p_index];
}
static GDExtensionTypePtr gdextension_packed_vector3_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
PackedVector3Array *self = (PackedVector3Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptrw()[p_index];
}
static GDExtensionTypePtr gdextension_packed_vector3_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const PackedVector3Array *self = (const PackedVector3Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionTypePtr)&self->ptr()[p_index];
}
static GDExtensionVariantPtr gdextension_array_operator_index(GDExtensionTypePtr p_self, GDExtensionInt p_index) {
Array *self = (Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionVariantPtr)&self->operator[](p_index);
}
static GDExtensionVariantPtr gdextension_array_operator_index_const(GDExtensionConstTypePtr p_self, GDExtensionInt p_index) {
const Array *self = (const Array *)p_self;
- ERR_FAIL_INDEX_V(p_index, self->size(), nullptr);
+ if (unlikely(p_index < 0 || p_index >= self->size())) {
+ return nullptr;
+ }
return (GDExtensionVariantPtr)&self->operator[](p_index);
}
@@ -892,14 +942,13 @@ static GDExtensionVariantPtr gdextension_dictionary_operator_index_const(GDExten
/* OBJECT API */
-static void gdextension_object_method_bind_call(GDExtensionMethodBindPtr p_method_bind, GDExtensionObjectPtr p_instance, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_arg_count, GDExtensionVariantPtr r_return, GDExtensionCallError *r_error) {
+static void gdextension_object_method_bind_call(GDExtensionMethodBindPtr p_method_bind, GDExtensionObjectPtr p_instance, const GDExtensionConstVariantPtr *p_args, GDExtensionInt p_arg_count, GDExtensionUninitializedVariantPtr r_return, GDExtensionCallError *r_error) {
const MethodBind *mb = reinterpret_cast<const MethodBind *>(p_method_bind);
Object *o = (Object *)p_instance;
const Variant **args = (const Variant **)p_args;
Callable::CallError error;
- Variant ret = mb->call(o, args, p_arg_count, error);
- memnew_placement(r_return, Variant(ret));
+ memnew_placement(r_return, Variant(mb->call(o, args, p_arg_count, error)));
if (r_error) {
r_error->error = (GDExtensionCallErrorType)(error.error);
@@ -943,6 +992,19 @@ static GDExtensionObjectPtr gdextension_object_get_instance_from_id(GDObjectInst
return (GDExtensionObjectPtr)ObjectDB::get_instance(ObjectID(p_instance_id));
}
+static GDExtensionBool gdextension_object_get_class_name(GDExtensionConstObjectPtr p_object, GDExtensionClassLibraryPtr p_library, GDExtensionUninitializedStringNamePtr r_class_name) {
+ if (!p_object) {
+ return false;
+ }
+ const Object *o = (const Object *)p_object;
+
+ memnew_placement(r_class_name, StringName);
+ StringName *class_name = reinterpret_cast<StringName *>(r_class_name);
+ *class_name = o->get_class_name_for_extension((GDExtension *)p_library);
+
+ return true;
+}
+
static GDExtensionObjectPtr gdextension_object_cast_to(GDExtensionConstObjectPtr p_object, void *p_class_tag) {
if (!p_object) {
return nullptr;
@@ -984,7 +1046,12 @@ static GDExtensionScriptInstancePtr gdextension_script_instance_create(const GDE
static GDExtensionMethodBindPtr gdextension_classdb_get_method_bind(GDExtensionConstStringNamePtr p_classname, GDExtensionConstStringNamePtr p_methodname, GDExtensionInt p_hash) {
const StringName classname = *reinterpret_cast<const StringName *>(p_classname);
const StringName methodname = *reinterpret_cast<const StringName *>(p_methodname);
- MethodBind *mb = ClassDB::get_method(classname, methodname);
+ bool exists = false;
+ MethodBind *mb = ClassDB::get_method_with_compatibility(classname, methodname, p_hash, &exists);
+ if (!mb && exists) {
+ ERR_PRINT("Method '" + classname + "." + methodname + "' has changed and no compatibility fallback has been provided. Please open an issue.");
+ return nullptr;
+ }
ERR_FAIL_COND_V(!mb, nullptr);
if (mb->get_hash() != p_hash) {
ERR_PRINT("Hash mismatch for method '" + classname + "." + methodname + "'.");
@@ -1004,204 +1071,150 @@ static void *gdextension_classdb_get_class_tag(GDExtensionConstStringNamePtr p_c
return class_info ? class_info->class_ptr : nullptr;
}
-void gdextension_setup_interface(GDExtensionInterface *p_interface) {
- GDExtensionInterface &gde_interface = *p_interface;
-
- gde_interface.version_major = VERSION_MAJOR;
- gde_interface.version_minor = VERSION_MINOR;
-#if VERSION_PATCH
- gde_interface.version_patch = VERSION_PATCH;
-#else
- gde_interface.version_patch = 0;
+static void gdextension_editor_add_plugin(GDExtensionConstStringNamePtr p_classname) {
+#ifdef TOOLS_ENABLED
+ const StringName classname = *reinterpret_cast<const StringName *>(p_classname);
+ GDExtensionEditorPlugins::add_extension_class(classname);
#endif
- gde_interface.version_string = VERSION_FULL_NAME;
-
- /* GODOT CORE */
-
- gde_interface.mem_alloc = gdextension_alloc;
- gde_interface.mem_realloc = gdextension_realloc;
- gde_interface.mem_free = gdextension_free;
-
- gde_interface.print_error = gdextension_print_error;
- gde_interface.print_error_with_message = gdextension_print_error_with_message;
- gde_interface.print_warning = gdextension_print_warning;
- gde_interface.print_warning_with_message = gdextension_print_warning_with_message;
- gde_interface.print_script_error = gdextension_print_script_error;
- gde_interface.print_script_error_with_message = gdextension_print_script_error_with_message;
-
- gde_interface.get_native_struct_size = gdextension_get_native_struct_size;
-
- /* GODOT VARIANT */
-
- // variant general
- gde_interface.variant_new_copy = gdextension_variant_new_copy;
- gde_interface.variant_new_nil = gdextension_variant_new_nil;
- gde_interface.variant_destroy = gdextension_variant_destroy;
-
- gde_interface.variant_call = gdextension_variant_call;
- gde_interface.variant_call_static = gdextension_variant_call_static;
- gde_interface.variant_evaluate = gdextension_variant_evaluate;
- gde_interface.variant_set = gdextension_variant_set;
- gde_interface.variant_set_named = gdextension_variant_set_named;
- gde_interface.variant_set_keyed = gdextension_variant_set_keyed;
- gde_interface.variant_set_indexed = gdextension_variant_set_indexed;
- gde_interface.variant_get = gdextension_variant_get;
- gde_interface.variant_get_named = gdextension_variant_get_named;
- gde_interface.variant_get_keyed = gdextension_variant_get_keyed;
- gde_interface.variant_get_indexed = gdextension_variant_get_indexed;
- gde_interface.variant_iter_init = gdextension_variant_iter_init;
- gde_interface.variant_iter_next = gdextension_variant_iter_next;
- gde_interface.variant_iter_get = gdextension_variant_iter_get;
- gde_interface.variant_hash = gdextension_variant_hash;
- gde_interface.variant_recursive_hash = gdextension_variant_recursive_hash;
- gde_interface.variant_hash_compare = gdextension_variant_hash_compare;
- gde_interface.variant_booleanize = gdextension_variant_booleanize;
- gde_interface.variant_duplicate = gdextension_variant_duplicate;
- gde_interface.variant_stringify = gdextension_variant_stringify;
-
- gde_interface.variant_get_type = gdextension_variant_get_type;
- gde_interface.variant_has_method = gdextension_variant_has_method;
- gde_interface.variant_has_member = gdextension_variant_has_member;
- gde_interface.variant_has_key = gdextension_variant_has_key;
- gde_interface.variant_get_type_name = gdextension_variant_get_type_name;
- gde_interface.variant_can_convert = gdextension_variant_can_convert;
- gde_interface.variant_can_convert_strict = gdextension_variant_can_convert_strict;
-
- gde_interface.get_variant_from_type_constructor = gdextension_get_variant_from_type_constructor;
- gde_interface.get_variant_to_type_constructor = gdextension_get_type_from_variant_constructor;
-
- // ptrcalls.
-
- gde_interface.variant_get_ptr_operator_evaluator = gdextension_variant_get_ptr_operator_evaluator;
- gde_interface.variant_get_ptr_builtin_method = gdextension_variant_get_ptr_builtin_method;
- gde_interface.variant_get_ptr_constructor = gdextension_variant_get_ptr_constructor;
- gde_interface.variant_get_ptr_destructor = gdextension_variant_get_ptr_destructor;
- gde_interface.variant_construct = gdextension_variant_construct;
- gde_interface.variant_get_ptr_setter = gdextension_variant_get_ptr_setter;
- gde_interface.variant_get_ptr_getter = gdextension_variant_get_ptr_getter;
- gde_interface.variant_get_ptr_indexed_setter = gdextension_variant_get_ptr_indexed_setter;
- gde_interface.variant_get_ptr_indexed_getter = gdextension_variant_get_ptr_indexed_getter;
- gde_interface.variant_get_ptr_keyed_setter = gdextension_variant_get_ptr_keyed_setter;
- gde_interface.variant_get_ptr_keyed_getter = gdextension_variant_get_ptr_keyed_getter;
- gde_interface.variant_get_ptr_keyed_checker = gdextension_variant_get_ptr_keyed_checker;
- gde_interface.variant_get_constant_value = gdextension_variant_get_constant_value;
- gde_interface.variant_get_ptr_utility_function = gdextension_variant_get_ptr_utility_function;
-
- // extra utilities
-
- gde_interface.string_new_with_latin1_chars = gdextension_string_new_with_latin1_chars;
- gde_interface.string_new_with_utf8_chars = gdextension_string_new_with_utf8_chars;
- gde_interface.string_new_with_utf16_chars = gdextension_string_new_with_utf16_chars;
- gde_interface.string_new_with_utf32_chars = gdextension_string_new_with_utf32_chars;
- gde_interface.string_new_with_wide_chars = gdextension_string_new_with_wide_chars;
- gde_interface.string_new_with_latin1_chars_and_len = gdextension_string_new_with_latin1_chars_and_len;
- gde_interface.string_new_with_utf8_chars_and_len = gdextension_string_new_with_utf8_chars_and_len;
- gde_interface.string_new_with_utf16_chars_and_len = gdextension_string_new_with_utf16_chars_and_len;
- gde_interface.string_new_with_utf32_chars_and_len = gdextension_string_new_with_utf32_chars_and_len;
- gde_interface.string_new_with_wide_chars_and_len = gdextension_string_new_with_wide_chars_and_len;
- gde_interface.string_to_latin1_chars = gdextension_string_to_latin1_chars;
- gde_interface.string_to_utf8_chars = gdextension_string_to_utf8_chars;
- gde_interface.string_to_utf16_chars = gdextension_string_to_utf16_chars;
- gde_interface.string_to_utf32_chars = gdextension_string_to_utf32_chars;
- gde_interface.string_to_wide_chars = gdextension_string_to_wide_chars;
- gde_interface.string_operator_index = gdextension_string_operator_index;
- gde_interface.string_operator_index_const = gdextension_string_operator_index_const;
- gde_interface.string_operator_plus_eq_string = gdextension_string_operator_plus_eq_string;
- gde_interface.string_operator_plus_eq_char = gdextension_string_operator_plus_eq_char;
- gde_interface.string_operator_plus_eq_cstr = gdextension_string_operator_plus_eq_cstr;
- gde_interface.string_operator_plus_eq_wcstr = gdextension_string_operator_plus_eq_wcstr;
- gde_interface.string_operator_plus_eq_c32str = gdextension_string_operator_plus_eq_c32str;
-
- /* XMLParser extra utilities */
-
- gde_interface.xml_parser_open_buffer = gdextension_xml_parser_open_buffer;
-
- /* FileAccess extra utilities */
-
- gde_interface.file_access_store_buffer = gdextension_file_access_store_buffer;
- gde_interface.file_access_get_buffer = gdextension_file_access_get_buffer;
-
- /* WorkerThreadPool extra utilities */
-
- gde_interface.worker_thread_pool_add_native_group_task = gdextension_worker_thread_pool_add_native_group_task;
- gde_interface.worker_thread_pool_add_native_task = gdextension_worker_thread_pool_add_native_task;
-
- /* Packed array functions */
-
- gde_interface.packed_byte_array_operator_index = gdextension_packed_byte_array_operator_index;
- gde_interface.packed_byte_array_operator_index_const = gdextension_packed_byte_array_operator_index_const;
-
- gde_interface.packed_color_array_operator_index = gdextension_packed_color_array_operator_index;
- gde_interface.packed_color_array_operator_index_const = gdextension_packed_color_array_operator_index_const;
-
- gde_interface.packed_float32_array_operator_index = gdextension_packed_float32_array_operator_index;
- gde_interface.packed_float32_array_operator_index_const = gdextension_packed_float32_array_operator_index_const;
- gde_interface.packed_float64_array_operator_index = gdextension_packed_float64_array_operator_index;
- gde_interface.packed_float64_array_operator_index_const = gdextension_packed_float64_array_operator_index_const;
-
- gde_interface.packed_int32_array_operator_index = gdextension_packed_int32_array_operator_index;
- gde_interface.packed_int32_array_operator_index_const = gdextension_packed_int32_array_operator_index_const;
- gde_interface.packed_int64_array_operator_index = gdextension_packed_int64_array_operator_index;
- gde_interface.packed_int64_array_operator_index_const = gdextension_packed_int64_array_operator_index_const;
-
- gde_interface.packed_string_array_operator_index = gdextension_packed_string_array_operator_index;
- gde_interface.packed_string_array_operator_index_const = gdextension_packed_string_array_operator_index_const;
-
- gde_interface.packed_vector2_array_operator_index = gdextension_packed_vector2_array_operator_index;
- gde_interface.packed_vector2_array_operator_index_const = gdextension_packed_vector2_array_operator_index_const;
- gde_interface.packed_vector3_array_operator_index = gdextension_packed_vector3_array_operator_index;
- gde_interface.packed_vector3_array_operator_index_const = gdextension_packed_vector3_array_operator_index_const;
-
- gde_interface.array_operator_index = gdextension_array_operator_index;
- gde_interface.array_operator_index_const = gdextension_array_operator_index_const;
- gde_interface.array_ref = gdextension_array_ref;
- gde_interface.array_set_typed = gdextension_array_set_typed;
-
- /* Dictionary functions */
-
- gde_interface.dictionary_operator_index = gdextension_dictionary_operator_index;
- gde_interface.dictionary_operator_index_const = gdextension_dictionary_operator_index_const;
-
- /* OBJECT */
-
- gde_interface.object_method_bind_call = gdextension_object_method_bind_call;
- gde_interface.object_method_bind_ptrcall = gdextension_object_method_bind_ptrcall;
- gde_interface.object_destroy = gdextension_object_destroy;
- gde_interface.global_get_singleton = gdextension_global_get_singleton;
- gde_interface.object_get_instance_binding = gdextension_object_get_instance_binding;
- gde_interface.object_set_instance_binding = gdextension_object_set_instance_binding;
- gde_interface.object_set_instance = gdextension_object_set_instance;
-
- gde_interface.object_cast_to = gdextension_object_cast_to;
- gde_interface.object_get_instance_from_id = gdextension_object_get_instance_from_id;
- gde_interface.object_get_instance_id = gdextension_object_get_instance_id;
-
- /* REFERENCE */
-
- gde_interface.ref_get_object = gdextension_ref_get_object;
- gde_interface.ref_set_object = gdextension_ref_set_object;
-
- /* SCRIPT INSTANCE */
-
- gde_interface.script_instance_create = gdextension_script_instance_create;
-
- /* CLASSDB */
-
- gde_interface.classdb_construct_object = gdextension_classdb_construct_object;
- gde_interface.classdb_get_method_bind = gdextension_classdb_get_method_bind;
- gde_interface.classdb_get_class_tag = gdextension_classdb_get_class_tag;
-
- /* CLASSDB EXTENSION */
-
- //these are filled by implementation, since it will want to keep track of registered classes
- gde_interface.classdb_register_extension_class = nullptr;
- gde_interface.classdb_register_extension_class_method = nullptr;
- gde_interface.classdb_register_extension_class_integer_constant = nullptr;
- gde_interface.classdb_register_extension_class_property = nullptr;
- gde_interface.classdb_register_extension_class_property_group = nullptr;
- gde_interface.classdb_register_extension_class_property_subgroup = nullptr;
- gde_interface.classdb_register_extension_class_signal = nullptr;
- gde_interface.classdb_unregister_extension_class = nullptr;
+}
- gde_interface.get_library_path = nullptr;
+static void gdextension_editor_remove_plugin(GDExtensionConstStringNamePtr p_classname) {
+#ifdef TOOLS_ENABLED
+ const StringName classname = *reinterpret_cast<const StringName *>(p_classname);
+ GDExtensionEditorPlugins::remove_extension_class(classname);
+#endif
}
+
+#define REGISTER_INTERFACE_FUNC(m_name) GDExtension::register_interface_function(#m_name, (GDExtensionInterfaceFunctionPtr)&gdextension_##m_name)
+
+void gdextension_setup_interface() {
+ REGISTER_INTERFACE_FUNC(get_godot_version);
+ REGISTER_INTERFACE_FUNC(mem_alloc);
+ REGISTER_INTERFACE_FUNC(mem_realloc);
+ REGISTER_INTERFACE_FUNC(mem_free);
+ REGISTER_INTERFACE_FUNC(print_error);
+ REGISTER_INTERFACE_FUNC(print_error_with_message);
+ REGISTER_INTERFACE_FUNC(print_warning);
+ REGISTER_INTERFACE_FUNC(print_warning_with_message);
+ REGISTER_INTERFACE_FUNC(print_script_error);
+ REGISTER_INTERFACE_FUNC(print_script_error_with_message);
+ REGISTER_INTERFACE_FUNC(get_native_struct_size);
+ REGISTER_INTERFACE_FUNC(variant_new_copy);
+ REGISTER_INTERFACE_FUNC(variant_new_nil);
+ REGISTER_INTERFACE_FUNC(variant_destroy);
+ REGISTER_INTERFACE_FUNC(variant_call);
+ REGISTER_INTERFACE_FUNC(variant_call_static);
+ REGISTER_INTERFACE_FUNC(variant_evaluate);
+ REGISTER_INTERFACE_FUNC(variant_set);
+ REGISTER_INTERFACE_FUNC(variant_set_named);
+ REGISTER_INTERFACE_FUNC(variant_set_keyed);
+ REGISTER_INTERFACE_FUNC(variant_set_indexed);
+ REGISTER_INTERFACE_FUNC(variant_get);
+ REGISTER_INTERFACE_FUNC(variant_get_named);
+ REGISTER_INTERFACE_FUNC(variant_get_keyed);
+ REGISTER_INTERFACE_FUNC(variant_get_indexed);
+ REGISTER_INTERFACE_FUNC(variant_iter_init);
+ REGISTER_INTERFACE_FUNC(variant_iter_next);
+ REGISTER_INTERFACE_FUNC(variant_iter_get);
+ REGISTER_INTERFACE_FUNC(variant_hash);
+ REGISTER_INTERFACE_FUNC(variant_recursive_hash);
+ REGISTER_INTERFACE_FUNC(variant_hash_compare);
+ REGISTER_INTERFACE_FUNC(variant_booleanize);
+ REGISTER_INTERFACE_FUNC(variant_duplicate);
+ REGISTER_INTERFACE_FUNC(variant_stringify);
+ REGISTER_INTERFACE_FUNC(variant_get_type);
+ REGISTER_INTERFACE_FUNC(variant_has_method);
+ REGISTER_INTERFACE_FUNC(variant_has_member);
+ REGISTER_INTERFACE_FUNC(variant_has_key);
+ REGISTER_INTERFACE_FUNC(variant_get_type_name);
+ REGISTER_INTERFACE_FUNC(variant_can_convert);
+ REGISTER_INTERFACE_FUNC(variant_can_convert_strict);
+ REGISTER_INTERFACE_FUNC(get_variant_from_type_constructor);
+ REGISTER_INTERFACE_FUNC(get_variant_to_type_constructor);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_operator_evaluator);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_builtin_method);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_constructor);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_destructor);
+ REGISTER_INTERFACE_FUNC(variant_construct);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_setter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_getter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_indexed_setter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_indexed_getter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_keyed_setter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_keyed_getter);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_keyed_checker);
+ REGISTER_INTERFACE_FUNC(variant_get_constant_value);
+ REGISTER_INTERFACE_FUNC(variant_get_ptr_utility_function);
+ REGISTER_INTERFACE_FUNC(string_new_with_latin1_chars);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf8_chars);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf16_chars);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf32_chars);
+ REGISTER_INTERFACE_FUNC(string_new_with_wide_chars);
+ REGISTER_INTERFACE_FUNC(string_new_with_latin1_chars_and_len);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf8_chars_and_len);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf16_chars_and_len);
+ REGISTER_INTERFACE_FUNC(string_new_with_utf32_chars_and_len);
+ REGISTER_INTERFACE_FUNC(string_new_with_wide_chars_and_len);
+ REGISTER_INTERFACE_FUNC(string_to_latin1_chars);
+ REGISTER_INTERFACE_FUNC(string_to_utf8_chars);
+ REGISTER_INTERFACE_FUNC(string_to_utf16_chars);
+ REGISTER_INTERFACE_FUNC(string_to_utf32_chars);
+ REGISTER_INTERFACE_FUNC(string_to_wide_chars);
+ REGISTER_INTERFACE_FUNC(string_operator_index);
+ REGISTER_INTERFACE_FUNC(string_operator_index_const);
+ REGISTER_INTERFACE_FUNC(string_operator_plus_eq_string);
+ REGISTER_INTERFACE_FUNC(string_operator_plus_eq_char);
+ REGISTER_INTERFACE_FUNC(string_operator_plus_eq_cstr);
+ REGISTER_INTERFACE_FUNC(string_operator_plus_eq_wcstr);
+ REGISTER_INTERFACE_FUNC(string_operator_plus_eq_c32str);
+ REGISTER_INTERFACE_FUNC(xml_parser_open_buffer);
+ REGISTER_INTERFACE_FUNC(file_access_store_buffer);
+ REGISTER_INTERFACE_FUNC(file_access_get_buffer);
+ REGISTER_INTERFACE_FUNC(worker_thread_pool_add_native_group_task);
+ REGISTER_INTERFACE_FUNC(worker_thread_pool_add_native_task);
+ REGISTER_INTERFACE_FUNC(packed_byte_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_byte_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_color_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_color_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_float32_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_float32_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_float64_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_float64_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_int32_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_int32_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_int64_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_int64_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_string_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_string_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_vector2_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_vector2_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(packed_vector3_array_operator_index);
+ REGISTER_INTERFACE_FUNC(packed_vector3_array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(array_operator_index);
+ REGISTER_INTERFACE_FUNC(array_operator_index_const);
+ REGISTER_INTERFACE_FUNC(array_ref);
+ REGISTER_INTERFACE_FUNC(array_set_typed);
+ REGISTER_INTERFACE_FUNC(dictionary_operator_index);
+ REGISTER_INTERFACE_FUNC(dictionary_operator_index_const);
+ REGISTER_INTERFACE_FUNC(object_method_bind_call);
+ REGISTER_INTERFACE_FUNC(object_method_bind_ptrcall);
+ REGISTER_INTERFACE_FUNC(object_destroy);
+ REGISTER_INTERFACE_FUNC(global_get_singleton);
+ REGISTER_INTERFACE_FUNC(object_get_instance_binding);
+ REGISTER_INTERFACE_FUNC(object_set_instance_binding);
+ REGISTER_INTERFACE_FUNC(object_set_instance);
+ REGISTER_INTERFACE_FUNC(object_get_class_name);
+ REGISTER_INTERFACE_FUNC(object_cast_to);
+ REGISTER_INTERFACE_FUNC(object_get_instance_from_id);
+ REGISTER_INTERFACE_FUNC(object_get_instance_id);
+ REGISTER_INTERFACE_FUNC(ref_get_object);
+ REGISTER_INTERFACE_FUNC(ref_set_object);
+ REGISTER_INTERFACE_FUNC(script_instance_create);
+ REGISTER_INTERFACE_FUNC(classdb_construct_object);
+ REGISTER_INTERFACE_FUNC(classdb_get_method_bind);
+ REGISTER_INTERFACE_FUNC(classdb_get_class_tag);
+ REGISTER_INTERFACE_FUNC(editor_add_plugin);
+ REGISTER_INTERFACE_FUNC(editor_remove_plugin);
+}
+
+#undef REGISTER_INTERFACE_FUNCTION