Merge pull request #44472 from winterpixelgames/PR-duplicate-packedarrays
Add support for duplicate() for Packed*Array, and they are pass by ref in godot 4.0
This commit is contained in:
commit
6532596d97
12 changed files with 94 additions and 9 deletions
|
@ -112,6 +112,10 @@ public:
|
||||||
sort_custom<_DefaultComparator<T>>();
|
sort_custom<_DefaultComparator<T>>();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Vector<T> duplicate() {
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
void ordered_insert(const T &p_val) {
|
void ordered_insert(const T &p_val) {
|
||||||
int i;
|
int i;
|
||||||
for (i = 0; i < _cowdata.size(); i++) {
|
for (i = 0; i < _cowdata.size(); i++) {
|
||||||
|
|
|
@ -1316,6 +1316,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedByteArray, invert, sarray(), varray());
|
bind_method(PackedByteArray, invert, sarray(), varray());
|
||||||
bind_method(PackedByteArray, subarray, sarray("from", "to"), varray());
|
bind_method(PackedByteArray, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedByteArray, sort, sarray(), varray());
|
bind_method(PackedByteArray, sort, sarray(), varray());
|
||||||
|
bind_method(PackedByteArray, duplicate, sarray(), varray());
|
||||||
|
|
||||||
bind_function(PackedByteArray, get_string_from_ascii, _VariantCall::func_PackedByteArray_get_string_from_ascii, sarray(), varray());
|
bind_function(PackedByteArray, get_string_from_ascii, _VariantCall::func_PackedByteArray_get_string_from_ascii, sarray(), varray());
|
||||||
bind_function(PackedByteArray, get_string_from_utf8, _VariantCall::func_PackedByteArray_get_string_from_utf8, sarray(), varray());
|
bind_function(PackedByteArray, get_string_from_utf8, _VariantCall::func_PackedByteArray_get_string_from_utf8, sarray(), varray());
|
||||||
|
@ -1342,6 +1343,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedInt32Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedInt32Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedInt32Array, to_byte_array, sarray(), varray());
|
bind_method(PackedInt32Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedInt32Array, sort, sarray(), varray());
|
bind_method(PackedInt32Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedInt32Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Int64 Array */
|
/* Int64 Array */
|
||||||
|
|
||||||
|
@ -1359,6 +1361,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedInt64Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedInt64Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedInt64Array, to_byte_array, sarray(), varray());
|
bind_method(PackedInt64Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedInt64Array, sort, sarray(), varray());
|
bind_method(PackedInt64Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedInt64Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Float32 Array */
|
/* Float32 Array */
|
||||||
|
|
||||||
|
@ -1376,6 +1379,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedFloat32Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedFloat32Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedFloat32Array, to_byte_array, sarray(), varray());
|
bind_method(PackedFloat32Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedFloat32Array, sort, sarray(), varray());
|
bind_method(PackedFloat32Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedFloat32Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Float64 Array */
|
/* Float64 Array */
|
||||||
|
|
||||||
|
@ -1393,6 +1397,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedFloat64Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedFloat64Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedFloat64Array, to_byte_array, sarray(), varray());
|
bind_method(PackedFloat64Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedFloat64Array, sort, sarray(), varray());
|
bind_method(PackedFloat64Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedFloat64Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* String Array */
|
/* String Array */
|
||||||
|
|
||||||
|
@ -1410,6 +1415,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedStringArray, subarray, sarray("from", "to"), varray());
|
bind_method(PackedStringArray, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedStringArray, to_byte_array, sarray(), varray());
|
bind_method(PackedStringArray, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedStringArray, sort, sarray(), varray());
|
bind_method(PackedStringArray, sort, sarray(), varray());
|
||||||
|
bind_method(PackedStringArray, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Vector2 Array */
|
/* Vector2 Array */
|
||||||
|
|
||||||
|
@ -1427,6 +1433,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedVector2Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedVector2Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedVector2Array, to_byte_array, sarray(), varray());
|
bind_method(PackedVector2Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedVector2Array, sort, sarray(), varray());
|
bind_method(PackedVector2Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedVector2Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Vector3 Array */
|
/* Vector3 Array */
|
||||||
|
|
||||||
|
@ -1444,6 +1451,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedVector3Array, subarray, sarray("from", "to"), varray());
|
bind_method(PackedVector3Array, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedVector3Array, to_byte_array, sarray(), varray());
|
bind_method(PackedVector3Array, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedVector3Array, sort, sarray(), varray());
|
bind_method(PackedVector3Array, sort, sarray(), varray());
|
||||||
|
bind_method(PackedVector3Array, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Color Array */
|
/* Color Array */
|
||||||
|
|
||||||
|
@ -1461,6 +1469,7 @@ static void _register_variant_builtin_methods() {
|
||||||
bind_method(PackedColorArray, subarray, sarray("from", "to"), varray());
|
bind_method(PackedColorArray, subarray, sarray("from", "to"), varray());
|
||||||
bind_method(PackedColorArray, to_byte_array, sarray(), varray());
|
bind_method(PackedColorArray, to_byte_array, sarray(), varray());
|
||||||
bind_method(PackedColorArray, sort, sarray(), varray());
|
bind_method(PackedColorArray, sort, sarray(), varray());
|
||||||
|
bind_method(PackedColorArray, duplicate, sarray(), varray());
|
||||||
|
|
||||||
/* Register constants */
|
/* Register constants */
|
||||||
|
|
||||||
|
|
|
@ -2023,6 +2023,24 @@ Variant Variant::duplicate(bool deep) const {
|
||||||
return operator Dictionary().duplicate(deep);
|
return operator Dictionary().duplicate(deep);
|
||||||
case ARRAY:
|
case ARRAY:
|
||||||
return operator Array().duplicate(deep);
|
return operator Array().duplicate(deep);
|
||||||
|
case PACKED_BYTE_ARRAY:
|
||||||
|
return operator Vector<uint8_t>().duplicate();
|
||||||
|
case PACKED_INT32_ARRAY:
|
||||||
|
return operator Vector<int32_t>().duplicate();
|
||||||
|
case PACKED_INT64_ARRAY:
|
||||||
|
return operator Vector<int64_t>().duplicate();
|
||||||
|
case PACKED_FLOAT32_ARRAY:
|
||||||
|
return operator Vector<float>().duplicate();
|
||||||
|
case PACKED_FLOAT64_ARRAY:
|
||||||
|
return operator Vector<double>().duplicate();
|
||||||
|
case PACKED_STRING_ARRAY:
|
||||||
|
return operator Vector<String>().duplicate();
|
||||||
|
case PACKED_VECTOR2_ARRAY:
|
||||||
|
return operator Vector<Vector2>().duplicate();
|
||||||
|
case PACKED_VECTOR3_ARRAY:
|
||||||
|
return operator Vector<Vector3>().duplicate();
|
||||||
|
case PACKED_COLOR_ARRAY:
|
||||||
|
return operator Vector<Color>().duplicate();
|
||||||
default:
|
default:
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold bytes. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold bytes. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
|
@ -86,6 +85,13 @@
|
||||||
GZIP has a maximal compression ratio of 1032:1, meaning it's very possible for a small compressed payload to decompress to a potentially very large output. To guard against this, you may provide a maximum size this function is allowed to allocate in bytes via [code]max_output_size[/code]. Passing -1 will allow for unbounded output. If any positive value is passed, and the decompression exceeds that amount in bytes, then an error will be returned.
|
GZIP has a maximal compression ratio of 1032:1, meaning it's very possible for a small compressed payload to decompress to a potentially very large output. To guard against this, you may provide a maximum size this function is allowed to allocate in bytes via [code]max_output_size[/code]. Passing -1 will allow for unbounded output. If any positive value is passed, and the decompression exceeds that amount in bytes, then an error will be returned.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedByteArray">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold [Color]. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold [Color]. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
|
@ -53,6 +52,13 @@
|
||||||
Appends a [PackedColorArray] at the end of this array.
|
Appends a [PackedColorArray] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedColorArray">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold 32-bit floating-point values. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold 32-bit floating-point values. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
If you need to pack 64-bit floats tightly, see [PackedFloat64Array].
|
If you need to pack 64-bit floats tightly, see [PackedFloat64Array].
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedFloat32Array] at the end of this array.
|
Appends a [PackedFloat32Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedFloat32Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold 64-bit floating-point values. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold 64-bit floating-point values. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
If you only need to pack 32-bit floats tightly, see [PackedFloat32Array] for a more memory-friendly alternative.
|
If you only need to pack 32-bit floats tightly, see [PackedFloat32Array] for a more memory-friendly alternative.
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedFloat64Array] at the end of this array.
|
Appends a [PackedFloat64Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedFloat64Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold 32-bit integer values. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold 32-bit integer values. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
[b]Note:[/b] This type stores signed 32-bit integers, which means it can take values in the interval [code][-2^31, 2^31 - 1][/code], i.e. [code][-2147483648, 2147483647][/code]. Exceeding those bounds will wrap around. In comparison, [int] uses signed 64-bit integers which can hold much larger values. If you need to pack 64-bit integers tightly, see [PackedInt64Array].
|
[b]Note:[/b] This type stores signed 32-bit integers, which means it can take values in the interval [code][-2^31, 2^31 - 1][/code], i.e. [code][-2147483648, 2147483647][/code]. Exceeding those bounds will wrap around. In comparison, [int] uses signed 64-bit integers which can hold much larger values. If you need to pack 64-bit integers tightly, see [PackedInt64Array].
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedInt32Array] at the end of this array.
|
Appends a [PackedInt32Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedInt32Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold 64-bit integer values. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold 64-bit integer values. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
[b]Note:[/b] This type stores signed 64-bit integers, which means it can take values in the interval [code][-2^63, 2^63 - 1][/code], i.e. [code][-9223372036854775808, 9223372036854775807][/code]. Exceeding those bounds will wrap around. If you only need to pack 32-bit integers tightly, see [PackedInt32Array] for a more memory-friendly alternative.
|
[b]Note:[/b] This type stores signed 64-bit integers, which means it can take values in the interval [code][-2^63, 2^63 - 1][/code], i.e. [code][-9223372036854775808, 9223372036854775807][/code]. Exceeding those bounds will wrap around. If you only need to pack 32-bit integers tightly, see [PackedInt32Array] for a more memory-friendly alternative.
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedInt64Array] at the end of this array.
|
Appends a [PackedInt64Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedInt64Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold [String]s. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold [String]s. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
<link title="OS Test Demo">https://godotengine.org/asset-library/asset/677</link>
|
<link title="OS Test Demo">https://godotengine.org/asset-library/asset/677</link>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedStringArray] at the end of this array.
|
Appends a [PackedStringArray] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedStringArray">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold [Vector2]. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold [Vector2]. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
<link title="2D Navigation Astar Demo">https://godotengine.org/asset-library/asset/519</link>
|
<link title="2D Navigation Astar Demo">https://godotengine.org/asset-library/asset/519</link>
|
||||||
|
@ -54,6 +53,13 @@
|
||||||
Appends a [PackedVector2Array] at the end of this array.
|
Appends a [PackedVector2Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedVector2Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
An [Array] specifically designed to hold [Vector3]. Packs data tightly, so it saves memory for large array sizes.
|
An [Array] specifically designed to hold [Vector3]. Packs data tightly, so it saves memory for large array sizes.
|
||||||
[b]Note:[/b] This type is passed by value and not by reference.
|
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
|
@ -53,6 +52,13 @@
|
||||||
Appends a [PackedVector3Array] at the end of this array.
|
Appends a [PackedVector3Array] at the end of this array.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
|
<method name="duplicate">
|
||||||
|
<return type="PackedVector3Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Creates a copy of the array, and returns it.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
<method name="empty">
|
<method name="empty">
|
||||||
<return type="bool">
|
<return type="bool">
|
||||||
</return>
|
</return>
|
||||||
|
|
Loading…
Reference in a new issue