Compare commits

...

4 Commits

Author SHA1 Message Date
Lukas Tenbrink
2fc4738d7e
Merge ff7a3970a6 into 533c616cb8 2024-10-22 22:13:40 +02:00
Clay John
533c616cb8
Merge pull request #98391 from RandomShaper/rd_thread_switch
Some checks are pending
🔗 GHA / 📊 Static checks (push) Waiting to run
🔗 GHA / 🤖 Android (push) Blocked by required conditions
🔗 GHA / 🍏 iOS (push) Blocked by required conditions
🔗 GHA / 🐧 Linux (push) Blocked by required conditions
🔗 GHA / 🍎 macOS (push) Blocked by required conditions
🔗 GHA / 🏁 Windows (push) Blocked by required conditions
🔗 GHA / 🌐 Web (push) Blocked by required conditions
🔗 GHA / 🪲 Godot CPP (push) Blocked by required conditions
Implement thread ownership change for RenderingDevice
2024-10-22 13:10:32 -07:00
Pedro J. Estébanez
d5d509bbd6 Implement thread ownership change for RenderingDevice 2024-10-21 20:56:42 +02:00
Lukas Tenbrink
ff7a3970a6 Add PackedArrayRef classes, instances of PackedArrayRefRAII. These mimic Variant's PackedArray behavior as a ref counted shared ownership of a single instance PackedArray. 2024-10-21 15:00:42 +02:00
8 changed files with 362 additions and 106 deletions

View File

@ -0,0 +1,141 @@
/**************************************************************************/
/* packed_array_ref.h */
/**************************************************************************/
/* This file is part of: */
/* GODOT ENGINE */
/* https://godotengine.org */
/**************************************************************************/
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
/* */
/* Permission is hereby granted, free of charge, to any person obtaining */
/* a copy of this software and associated documentation files (the */
/* "Software"), to deal in the Software without restriction, including */
/* without limitation the rights to use, copy, modify, merge, publish, */
/* distribute, sublicense, and/or sell copies of the Software, and to */
/* permit persons to whom the Software is furnished to do so, subject to */
/* the following conditions: */
/* */
/* The above copyright notice and this permission notice shall be */
/* included in all copies or substantial portions of the Software. */
/* */
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/**************************************************************************/
#ifndef PACKED_ARRAY_REF_H
#define PACKED_ARRAY_REF_H
#include "core/os/memory.h"
#include "core/templates/vector.h"
struct PackedArrayRefBase {
SafeRefCount refcount;
_FORCE_INLINE_ PackedArrayRefBase *reference() {
if (refcount.ref()) {
return this;
} else {
return nullptr;
}
}
static _FORCE_INLINE_ PackedArrayRefBase *reference_from(PackedArrayRefBase *p_base, PackedArrayRefBase *p_from) {
if (p_base == p_from) {
return p_base; //same thing, do nothing
}
if (p_from->reference()) {
if (p_base->refcount.unref()) {
memdelete(p_base);
}
return p_from;
} else {
return p_base; //keep, could not reference new
}
}
static _FORCE_INLINE_ void destroy(PackedArrayRefBase *p_array) {
if (p_array->refcount.unref()) {
memdelete(p_array);
}
}
_FORCE_INLINE_ virtual ~PackedArrayRefBase() {} //needs virtual destructor, but make inline
};
template <typename T>
struct PackedArrayRef : public PackedArrayRefBase {
Vector<T> array;
static _FORCE_INLINE_ PackedArrayRef<T> *create() {
return memnew(PackedArrayRef<T>);
}
static _FORCE_INLINE_ PackedArrayRef<T> *create(const Vector<T> &p_from) {
return memnew(PackedArrayRef<T>(p_from));
}
static _FORCE_INLINE_ const Vector<T> &get_array(PackedArrayRefBase *p_base) {
return static_cast<PackedArrayRef<T> *>(p_base)->array;
}
static _FORCE_INLINE_ Vector<T> *get_array_ptr(const PackedArrayRefBase *p_base) {
return &const_cast<PackedArrayRef<T> *>(static_cast<const PackedArrayRef<T> *>(p_base))->array;
}
_FORCE_INLINE_ PackedArrayRef(const Vector<T> &p_from) {
array = p_from;
refcount.init();
}
_FORCE_INLINE_ PackedArrayRef(const PackedArrayRef<T> &p_from) {
array = p_from.array;
refcount.init();
}
_FORCE_INLINE_ PackedArrayRef() {
refcount.init();
}
};
template <typename T>
struct PackedArrayRefRAII {
PackedArrayRef<T> *ref = nullptr;
PackedArrayRefRAII() {
ref = PackedArrayRef<T>::create();
}
PackedArrayRefRAII(PackedArrayRefRAII<T> &p_from) {
if (p_from.ref) {
ref = dynamic_cast<PackedArrayRef<T> *>(p_from.ref->reference());
}
}
explicit PackedArrayRefRAII(const Vector<T> &p_from) {
ref = PackedArrayRef<T>::create(p_from);
}
explicit PackedArrayRefRAII(PackedArrayRef<T> &p_from) {
ref = dynamic_cast<PackedArrayRef<T> *>(p_from.reference());
}
explicit PackedArrayRefRAII(PackedArrayRef<T> *p_from) {
if (p_from) {
ref = dynamic_cast<PackedArrayRef<T> *>(p_from->reference());
}
}
~PackedArrayRefRAII() {
if (ref) {
PackedArrayRefBase::destroy(ref);
}
}
Vector<T> *operator->() {
return &ref->get_array_ptr(*this);
}
Vector<T> &operator*() {
return ref->get_array_ptr(*this);
}
};
#endif // PACKED_ARRAY_REF_H

View File

@ -2349,6 +2349,86 @@ Variant::operator PackedVector4Array() const {
}
}
Variant::operator PackedByteArrayRef() {
if (type == PACKED_BYTE_ARRAY) {
return PackedByteArrayRef(static_cast<PackedArrayRef<uint8_t> *>(_data.packed_array));
} else {
return PackedByteArrayRef(_convert_array_from_variant<PackedByteArray>(*this));
}
}
Variant::operator PackedInt32ArrayRef() {
if (type == PACKED_INT32_ARRAY) {
return PackedInt32ArrayRef(static_cast<PackedArrayRef<int32_t> *>(_data.packed_array));
} else {
return PackedInt32ArrayRef(_convert_array_from_variant<PackedInt32Array>(*this));
}
}
Variant::operator PackedInt64ArrayRef() {
if (type == PACKED_INT64_ARRAY) {
return PackedInt64ArrayRef(static_cast<PackedArrayRef<int64_t> *>(_data.packed_array));
} else {
return PackedInt64ArrayRef(_convert_array_from_variant<PackedInt64Array>(*this));
}
}
Variant::operator PackedFloat32ArrayRef() {
if (type == PACKED_FLOAT32_ARRAY) {
return PackedFloat32ArrayRef(static_cast<PackedArrayRef<float> *>(_data.packed_array));
} else {
return PackedFloat32ArrayRef(_convert_array_from_variant<PackedFloat32Array>(*this));
}
}
Variant::operator PackedFloat64ArrayRef() {
if (type == PACKED_FLOAT64_ARRAY) {
return PackedFloat64ArrayRef(static_cast<PackedArrayRef<double> *>(_data.packed_array));
} else {
return PackedFloat64ArrayRef(_convert_array_from_variant<PackedFloat64Array>(*this));
}
}
Variant::operator PackedStringArrayRef() {
if (type == PACKED_STRING_ARRAY) {
return PackedStringArrayRef(static_cast<PackedArrayRef<String> *>(_data.packed_array));
} else {
return PackedStringArrayRef(_convert_array_from_variant<PackedStringArray>(*this));
}
}
Variant::operator PackedVector2ArrayRef() {
if (type == PACKED_VECTOR2_ARRAY) {
return PackedVector2ArrayRef(static_cast<PackedArrayRef<Vector2> *>(_data.packed_array));
} else {
return PackedVector2ArrayRef(_convert_array_from_variant<PackedVector2Array>(*this));
}
}
Variant::operator PackedVector3ArrayRef() {
if (type == PACKED_VECTOR3_ARRAY) {
return PackedVector3ArrayRef(static_cast<PackedArrayRef<Vector3> *>(_data.packed_array));
} else {
return PackedVector3ArrayRef(_convert_array_from_variant<PackedVector3Array>(*this));
}
}
Variant::operator PackedColorArrayRef() {
if (type == PACKED_COLOR_ARRAY) {
return PackedColorArrayRef(static_cast<PackedArrayRef<Color> *>(_data.packed_array));
} else {
return PackedColorArrayRef(_convert_array_from_variant<PackedColorArray>(*this));
}
}
Variant::operator PackedVector4ArrayRef() {
if (type == PACKED_VECTOR4_ARRAY) {
return PackedVector4ArrayRef(static_cast<PackedArrayRef<Vector4> *>(_data.packed_array));
} else {
return PackedVector4ArrayRef(_convert_array_from_variant<PackedVector4Array>(*this));
}
}
/* helpers */
Variant::operator Vector<::RID>() const {
@ -2696,6 +2776,56 @@ Variant::Variant(const PackedVector4Array &p_vector4_array) :
_data.packed_array = PackedArrayRef<Vector4>::create(p_vector4_array);
}
Variant::Variant(PackedByteArrayRef &p_byte_array) :
type(PACKED_BYTE_ARRAY) {
_data.packed_array = p_byte_array.ref->reference();
}
Variant::Variant(PackedInt32ArrayRef &p_int32_array) :
type(PACKED_INT32_ARRAY) {
_data.packed_array = p_int32_array.ref->reference();
}
Variant::Variant(PackedInt64ArrayRef &p_int64_array) :
type(PACKED_INT64_ARRAY) {
_data.packed_array = p_int64_array.ref->reference();
}
Variant::Variant(PackedFloat32ArrayRef &p_float32_array) :
type(PACKED_FLOAT32_ARRAY) {
_data.packed_array = p_float32_array.ref->reference();
}
Variant::Variant(PackedFloat64ArrayRef &p_float64_array) :
type(PACKED_FLOAT64_ARRAY) {
_data.packed_array = p_float64_array.ref->reference();
}
Variant::Variant(PackedStringArrayRef &p_string_array) :
type(PACKED_STRING_ARRAY) {
_data.packed_array = p_string_array.ref->reference();
}
Variant::Variant(PackedVector2ArrayRef &p_vector2_array) :
type(PACKED_VECTOR2_ARRAY) {
_data.packed_array = p_vector2_array.ref->reference();
}
Variant::Variant(PackedVector3ArrayRef &p_vector3_array) :
type(PACKED_VECTOR3_ARRAY) {
_data.packed_array = p_vector3_array.ref->reference();
}
Variant::Variant(PackedColorArrayRef &p_color_array) :
type(PACKED_COLOR_ARRAY) {
_data.packed_array = p_color_array.ref->reference();
}
Variant::Variant(PackedVector4ArrayRef &p_vector4_array) :
type(PACKED_VECTOR4_ARRAY) {
_data.packed_array = p_vector4_array.ref->reference();
}
/* helpers */
Variant::Variant(const Vector<::RID> &p_array) :
type(ARRAY) {

View File

@ -60,6 +60,7 @@
#include "core/variant/array.h"
#include "core/variant/callable.h"
#include "core/variant/dictionary.h"
#include "core/variant/packed_array_ref.h"
class Object;
class RefCounted;
@ -82,6 +83,18 @@ typedef Vector<Vector3> PackedVector3Array;
typedef Vector<Color> PackedColorArray;
typedef Vector<Vector4> PackedVector4Array;
typedef PackedArrayRefRAII<uint8_t> PackedByteArrayRef;
typedef PackedArrayRefRAII<int32_t> PackedInt32ArrayRef;
typedef PackedArrayRefRAII<int64_t> PackedInt64ArrayRef;
typedef PackedArrayRefRAII<float> PackedFloat32ArrayRef;
typedef PackedArrayRefRAII<double> PackedFloat64ArrayRef;
typedef PackedArrayRefRAII<real_t> PackedRealArrayRef;
typedef PackedArrayRefRAII<String> PackedStringArrayRef;
typedef PackedArrayRefRAII<Vector2> PackedVector2ArrayRef;
typedef PackedArrayRefRAII<Vector3> PackedVector3ArrayRef;
typedef PackedArrayRefRAII<Color> PackedColorArrayRef;
typedef PackedArrayRefRAII<Vector4> PackedVector4ArrayRef;
class Variant {
public:
// If this changes the table in variant_op must be updated
@ -195,64 +208,6 @@ private:
}
};
/* array helpers */
struct PackedArrayRefBase {
SafeRefCount refcount;
_FORCE_INLINE_ PackedArrayRefBase *reference() {
if (refcount.ref()) {
return this;
} else {
return nullptr;
}
}
static _FORCE_INLINE_ PackedArrayRefBase *reference_from(PackedArrayRefBase *p_base, PackedArrayRefBase *p_from) {
if (p_base == p_from) {
return p_base; //same thing, do nothing
}
if (p_from->reference()) {
if (p_base->refcount.unref()) {
memdelete(p_base);
}
return p_from;
} else {
return p_base; //keep, could not reference new
}
}
static _FORCE_INLINE_ void destroy(PackedArrayRefBase *p_array) {
if (p_array->refcount.unref()) {
memdelete(p_array);
}
}
_FORCE_INLINE_ virtual ~PackedArrayRefBase() {} //needs virtual destructor, but make inline
};
template <typename T>
struct PackedArrayRef : public PackedArrayRefBase {
Vector<T> array;
static _FORCE_INLINE_ PackedArrayRef<T> *create() {
return memnew(PackedArrayRef<T>);
}
static _FORCE_INLINE_ PackedArrayRef<T> *create(const Vector<T> &p_from) {
return memnew(PackedArrayRef<T>(p_from));
}
static _FORCE_INLINE_ const Vector<T> &get_array(PackedArrayRefBase *p_base) {
return static_cast<PackedArrayRef<T> *>(p_base)->array;
}
static _FORCE_INLINE_ Vector<T> *get_array_ptr(const PackedArrayRefBase *p_base) {
return &const_cast<PackedArrayRef<T> *>(static_cast<const PackedArrayRef<T> *>(p_base))->array;
}
_FORCE_INLINE_ PackedArrayRef(const Vector<T> &p_from) {
array = p_from;
refcount.init();
}
_FORCE_INLINE_ PackedArrayRef() {
refcount.init();
}
};
/* end of array helpers */
_ALWAYS_INLINE_ ObjData &_get_obj();
_ALWAYS_INLINE_ const ObjData &_get_obj() const;
@ -434,6 +389,17 @@ public:
operator PackedColorArray() const;
operator PackedVector4Array() const;
operator PackedByteArrayRef();
operator PackedInt32ArrayRef();
operator PackedInt64ArrayRef();
operator PackedFloat32ArrayRef();
operator PackedFloat64ArrayRef();
operator PackedStringArrayRef();
operator PackedVector2ArrayRef();
operator PackedVector3ArrayRef();
operator PackedColorArrayRef();
operator PackedVector4ArrayRef();
operator Vector<::RID>() const;
operator Vector<Plane>() const;
operator Vector<Face3>() const;
@ -500,6 +466,17 @@ public:
Variant(const PackedColorArray &p_color_array);
Variant(const PackedVector4Array &p_vector4_array);
Variant(PackedByteArrayRef &p_byte_array);
Variant(PackedInt32ArrayRef &p_int32_array);
Variant(PackedInt64ArrayRef &p_int64_array);
Variant(PackedFloat32ArrayRef &p_float32_array);
Variant(PackedFloat64ArrayRef &p_float64_array);
Variant(PackedStringArrayRef &p_string_array);
Variant(PackedVector2ArrayRef &p_vector2_array);
Variant(PackedVector3ArrayRef &p_vector3_array);
Variant(PackedColorArrayRef &p_color_array);
Variant(PackedVector4ArrayRef &p_vector4_array);
Variant(const Vector<::RID> &p_array); // helper
Variant(const Vector<Plane> &p_array); // helper
Variant(const Vector<Face3> &p_face_array);

View File

@ -186,26 +186,26 @@ public:
_FORCE_INLINE_ static const Array *get_array(const Variant *v) { return reinterpret_cast<const Array *>(v->_data._mem); }
// Typed arrays.
_FORCE_INLINE_ static PackedByteArray *get_byte_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<uint8_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedByteArray *get_byte_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<uint8_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedInt32Array *get_int32_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<int32_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedInt32Array *get_int32_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<int32_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedInt64Array *get_int64_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<int64_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedInt64Array *get_int64_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<int64_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedFloat32Array *get_float32_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<float> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedFloat32Array *get_float32_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<float> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedFloat64Array *get_float64_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<double> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedFloat64Array *get_float64_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<double> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedStringArray *get_string_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<String> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedStringArray *get_string_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<String> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector2Array *get_vector2_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<Vector2> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector2Array *get_vector2_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<Vector2> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector3Array *get_vector3_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<Vector3> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector3Array *get_vector3_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<Vector3> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedColorArray *get_color_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<Color> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedColorArray *get_color_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<Color> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector4Array *get_vector4_array(Variant *v) { return &static_cast<Variant::PackedArrayRef<Vector4> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector4Array *get_vector4_array(const Variant *v) { return &static_cast<const Variant::PackedArrayRef<Vector4> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedByteArray *get_byte_array(Variant *v) { return &static_cast<PackedArrayRef<uint8_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedByteArray *get_byte_array(const Variant *v) { return &static_cast<const PackedArrayRef<uint8_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedInt32Array *get_int32_array(Variant *v) { return &static_cast<PackedArrayRef<int32_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedInt32Array *get_int32_array(const Variant *v) { return &static_cast<const PackedArrayRef<int32_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedInt64Array *get_int64_array(Variant *v) { return &static_cast<PackedArrayRef<int64_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedInt64Array *get_int64_array(const Variant *v) { return &static_cast<const PackedArrayRef<int64_t> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedFloat32Array *get_float32_array(Variant *v) { return &static_cast<PackedArrayRef<float> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedFloat32Array *get_float32_array(const Variant *v) { return &static_cast<const PackedArrayRef<float> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedFloat64Array *get_float64_array(Variant *v) { return &static_cast<PackedArrayRef<double> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedFloat64Array *get_float64_array(const Variant *v) { return &static_cast<const PackedArrayRef<double> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedStringArray *get_string_array(Variant *v) { return &static_cast<PackedArrayRef<String> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedStringArray *get_string_array(const Variant *v) { return &static_cast<const PackedArrayRef<String> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector2Array *get_vector2_array(Variant *v) { return &static_cast<PackedArrayRef<Vector2> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector2Array *get_vector2_array(const Variant *v) { return &static_cast<const PackedArrayRef<Vector2> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector3Array *get_vector3_array(Variant *v) { return &static_cast<PackedArrayRef<Vector3> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector3Array *get_vector3_array(const Variant *v) { return &static_cast<const PackedArrayRef<Vector3> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedColorArray *get_color_array(Variant *v) { return &static_cast<PackedArrayRef<Color> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedColorArray *get_color_array(const Variant *v) { return &static_cast<const PackedArrayRef<Color> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static PackedVector4Array *get_vector4_array(Variant *v) { return &static_cast<PackedArrayRef<Vector4> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static const PackedVector4Array *get_vector4_array(const Variant *v) { return &static_cast<const PackedArrayRef<Vector4> *>(v->_data.packed_array)->array; }
_FORCE_INLINE_ static Object **get_object(Variant *v) { return (Object **)&v->_get_obj().obj; }
_FORCE_INLINE_ static const Object **get_object(const Variant *v) { return (const Object **)&v->_get_obj().obj; }
@ -279,43 +279,43 @@ public:
v->type = Variant::ARRAY;
}
_FORCE_INLINE_ static void init_byte_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<uint8_t>::create(Vector<uint8_t>());
v->_data.packed_array = PackedArrayRef<uint8_t>::create(Vector<uint8_t>());
v->type = Variant::PACKED_BYTE_ARRAY;
}
_FORCE_INLINE_ static void init_int32_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<int32_t>::create(Vector<int32_t>());
v->_data.packed_array = PackedArrayRef<int32_t>::create(Vector<int32_t>());
v->type = Variant::PACKED_INT32_ARRAY;
}
_FORCE_INLINE_ static void init_int64_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<int64_t>::create(Vector<int64_t>());
v->_data.packed_array = PackedArrayRef<int64_t>::create(Vector<int64_t>());
v->type = Variant::PACKED_INT64_ARRAY;
}
_FORCE_INLINE_ static void init_float32_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<float>::create(Vector<float>());
v->_data.packed_array = PackedArrayRef<float>::create(Vector<float>());
v->type = Variant::PACKED_FLOAT32_ARRAY;
}
_FORCE_INLINE_ static void init_float64_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<double>::create(Vector<double>());
v->_data.packed_array = PackedArrayRef<double>::create(Vector<double>());
v->type = Variant::PACKED_FLOAT64_ARRAY;
}
_FORCE_INLINE_ static void init_string_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<String>::create(Vector<String>());
v->_data.packed_array = PackedArrayRef<String>::create(Vector<String>());
v->type = Variant::PACKED_STRING_ARRAY;
}
_FORCE_INLINE_ static void init_vector2_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<Vector2>::create(Vector<Vector2>());
v->_data.packed_array = PackedArrayRef<Vector2>::create(Vector<Vector2>());
v->type = Variant::PACKED_VECTOR2_ARRAY;
}
_FORCE_INLINE_ static void init_vector3_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<Vector3>::create(Vector<Vector3>());
v->_data.packed_array = PackedArrayRef<Vector3>::create(Vector<Vector3>());
v->type = Variant::PACKED_VECTOR3_ARRAY;
}
_FORCE_INLINE_ static void init_color_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<Color>::create(Vector<Color>());
v->_data.packed_array = PackedArrayRef<Color>::create(Vector<Color>());
v->type = Variant::PACKED_COLOR_ARRAY;
}
_FORCE_INLINE_ static void init_vector4_array(Variant *v) {
v->_data.packed_array = Variant::PackedArrayRef<Vector4>::create(Vector<Vector4>());
v->_data.packed_array = PackedArrayRef<Vector4>::create(Vector<Vector4>());
v->type = Variant::PACKED_VECTOR4_ARRAY;
}
_FORCE_INLINE_ static void init_object(Variant *v) {

View File

@ -177,16 +177,16 @@
<DisplayString Condition="type == Variant::OBJECT">{*(*reinterpret_cast&lt;ObjData*&gt;(&amp;_data._mem[0])).obj}</DisplayString>
<DisplayString Condition="type == Variant::DICTIONARY">{*(Dictionary *)_data._mem}</DisplayString>
<DisplayString Condition="type == Variant::ARRAY">{*(Array *)_data._mem}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_BYTE_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;unsigned char&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_INT32_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;int&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_BYTE_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;unsigned char&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_INT32_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;int&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_INT64_ARRAY">{*reinterpret_cast&lt;PackedInt64Array *&gt;(&amp;_data.packed_array[1])}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_FLOAT32_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;float&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_FLOAT64_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;double&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_STRING_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;String&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR2_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector2&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR3_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector3&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_COLOR_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Color&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR4_ARRAY">{reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector4&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_FLOAT32_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;float&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_FLOAT64_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;double&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_STRING_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;String&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR2_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;Vector2&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR3_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;Vector3&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_COLOR_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;Color&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type == Variant::PACKED_VECTOR4_ARRAY">{reinterpret_cast&lt;const PackedArrayRef&lt;Vector4&gt;*&gt;(_data.packed_array)->array}</DisplayString>
<DisplayString Condition="type &lt; 0 || type >= Variant::VARIANT_MAX">[INVALID]</DisplayString>
<StringView Condition="type == Variant::STRING &amp;&amp; ((String *)(_data._mem))->_cowdata._ptr">((String *)(_data._mem))->_cowdata._ptr,s32</StringView>
@ -212,16 +212,16 @@
<Item Name="[value]" Condition="type == Variant::OBJECT">*(*reinterpret_cast&lt;ObjData*&gt;(&amp;_data._mem[0])).obj</Item>
<Item Name="[value]" Condition="type == Variant::DICTIONARY">*(Dictionary *)_data._mem</Item>
<Item Name="[value]" Condition="type == Variant::ARRAY">*(Array *)_data._mem</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_BYTE_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;unsigned char&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_INT32_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;int&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_BYTE_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;unsigned char&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_INT32_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;int&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_INT64_ARRAY">*reinterpret_cast&lt;PackedInt64Array *&gt;(&amp;_data.packed_array[1])</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_FLOAT32_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;float&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_FLOAT64_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;double&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_STRING_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;String&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR2_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector2&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR3_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector3&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_COLOR_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Color&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR4_ARRAY">reinterpret_cast&lt;const Variant::PackedArrayRef&lt;Vector4&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_FLOAT32_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;float&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_FLOAT64_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;double&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_STRING_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;String&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR2_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;Vector2&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR3_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;Vector3&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_COLOR_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;Color&gt;*&gt;(_data.packed_array)->array</Item>
<Item Name="[value]" Condition="type == Variant::PACKED_VECTOR4_ARRAY">reinterpret_cast&lt;const PackedArrayRef&lt;Vector4&gt;*&gt;(_data.packed_array)->array</Item>
</Expand>
</Type>

View File

@ -7260,6 +7260,10 @@ void RenderingDevice::_bind_methods() {
BIND_ENUM_CONSTANT(DEBUG_PASS);
}
void RenderingDevice::make_current() {
render_thread_id = Thread::get_caller_id();
}
RenderingDevice::~RenderingDevice() {
finalize();

View File

@ -1496,6 +1496,8 @@ public:
static RenderingDevice *get_singleton();
void make_current();
RenderingDevice();
~RenderingDevice();

View File

@ -370,6 +370,8 @@ Size2i RenderingServerDefault::get_maximum_viewport_size() const {
void RenderingServerDefault::_assign_mt_ids(WorkerThreadPool::TaskID p_pump_task_id) {
server_thread = Thread::get_caller_id();
server_task_id = p_pump_task_id;
// This is needed because the main RD is created on the main thread.
RenderingDevice::get_singleton()->make_current();
}
void RenderingServerDefault::_thread_exit() {