From 3d1644f7c3b639971aec03e9e0ed02a4b2a901d3 Mon Sep 17 00:00:00 2001 From: Haoyu Qiu Date: Sat, 7 May 2022 19:47:49 +0800 Subject: [PATCH] Add search methods for pool arrays * has() * count() * find() * rfind() --- core/pool_vector.h | 51 +++++++++++++++++++++++++++++ core/variant_call.cpp | 56 ++++++++++++++++++++++++++++++++ doc/classes/Array.xml | 4 +-- doc/classes/PoolByteArray.xml | 31 ++++++++++++++++++ doc/classes/PoolColorArray.xml | 31 ++++++++++++++++++ doc/classes/PoolIntArray.xml | 31 ++++++++++++++++++ doc/classes/PoolRealArray.xml | 31 ++++++++++++++++++ doc/classes/PoolStringArray.xml | 31 ++++++++++++++++++ doc/classes/PoolVector2Array.xml | 31 ++++++++++++++++++ doc/classes/PoolVector3Array.xml | 31 ++++++++++++++++++ 10 files changed, 326 insertions(+), 2 deletions(-) diff --git a/core/pool_vector.h b/core/pool_vector.h index a4884b3aa0f..b53061ad60f 100644 --- a/core/pool_vector.h +++ b/core/pool_vector.h @@ -373,6 +373,57 @@ public: resize(s - 1); } + int find(const T &p_val, int p_from = 0) const { + const int s = size(); + const Read r = read(); + + if (p_from < 0) { + return -1; + } + + for (int i = p_from; i < s; i++) { + if (r[i] == p_val) { + return i; + } + } + return -1; + } + + int rfind(const T &p_val, int p_from = -1) const { + const int s = size(); + const Read r = read(); + + if (p_from < 0) { + p_from = s + p_from; + } + if (p_from < 0 || p_from >= s) { + p_from = s - 1; + } + + for (int i = p_from; i >= 0; i--) { + if (r[i] == p_val) { + return i; + } + } + return -1; + } + + int count(const T &p_val) const { + const int s = size(); + const Read r = read(); + int amount = 0; + for (int i = 0; i < s; i++) { + if (r[i] == p_val) { + amount++; + } + } + return amount; + } + + bool has(const T &p_val) const { + return find(p_val) != -1; + } + inline int size() const; inline bool empty() const; T get(int p_index) const; diff --git a/core/variant_call.cpp b/core/variant_call.cpp index de9c699f63a..3d53d9db752 100644 --- a/core/variant_call.cpp +++ b/core/variant_call.cpp @@ -701,6 +701,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolByteArray, append_array); VCALL_LOCALMEM0(PoolByteArray, invert); VCALL_LOCALMEM2R(PoolByteArray, subarray); + VCALL_LOCALMEM2R(PoolByteArray, find); + VCALL_LOCALMEM2R(PoolByteArray, rfind); + VCALL_LOCALMEM1R(PoolByteArray, count); + VCALL_LOCALMEM1R(PoolByteArray, has); VCALL_LOCALMEM0R(PoolIntArray, size); VCALL_LOCALMEM0R(PoolIntArray, empty); @@ -714,6 +718,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolIntArray, append); VCALL_LOCALMEM1(PoolIntArray, append_array); VCALL_LOCALMEM0(PoolIntArray, invert); + VCALL_LOCALMEM2R(PoolIntArray, find); + VCALL_LOCALMEM2R(PoolIntArray, rfind); + VCALL_LOCALMEM1R(PoolIntArray, count); + VCALL_LOCALMEM1R(PoolIntArray, has); VCALL_LOCALMEM0R(PoolRealArray, size); VCALL_LOCALMEM0R(PoolRealArray, empty); @@ -727,6 +735,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolRealArray, append); VCALL_LOCALMEM1(PoolRealArray, append_array); VCALL_LOCALMEM0(PoolRealArray, invert); + VCALL_LOCALMEM2R(PoolRealArray, find); + VCALL_LOCALMEM2R(PoolRealArray, rfind); + VCALL_LOCALMEM1R(PoolRealArray, count); + VCALL_LOCALMEM1R(PoolRealArray, has); VCALL_LOCALMEM0R(PoolStringArray, size); VCALL_LOCALMEM0R(PoolStringArray, empty); @@ -741,6 +753,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolStringArray, append_array); VCALL_LOCALMEM0(PoolStringArray, invert); VCALL_LOCALMEM1R(PoolStringArray, join); + VCALL_LOCALMEM2R(PoolStringArray, find); + VCALL_LOCALMEM2R(PoolStringArray, rfind); + VCALL_LOCALMEM1R(PoolStringArray, count); + VCALL_LOCALMEM1R(PoolStringArray, has); VCALL_LOCALMEM0R(PoolVector2Array, size); VCALL_LOCALMEM0R(PoolVector2Array, empty); @@ -754,6 +770,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolVector2Array, append); VCALL_LOCALMEM1(PoolVector2Array, append_array); VCALL_LOCALMEM0(PoolVector2Array, invert); + VCALL_LOCALMEM2R(PoolVector2Array, find); + VCALL_LOCALMEM2R(PoolVector2Array, rfind); + VCALL_LOCALMEM1R(PoolVector2Array, count); + VCALL_LOCALMEM1R(PoolVector2Array, has); VCALL_LOCALMEM0R(PoolVector3Array, size); VCALL_LOCALMEM0R(PoolVector3Array, empty); @@ -767,6 +787,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolVector3Array, append); VCALL_LOCALMEM1(PoolVector3Array, append_array); VCALL_LOCALMEM0(PoolVector3Array, invert); + VCALL_LOCALMEM2R(PoolVector3Array, find); + VCALL_LOCALMEM2R(PoolVector3Array, rfind); + VCALL_LOCALMEM1R(PoolVector3Array, count); + VCALL_LOCALMEM1R(PoolVector3Array, has); VCALL_LOCALMEM0R(PoolColorArray, size); VCALL_LOCALMEM0R(PoolColorArray, empty); @@ -780,6 +804,10 @@ struct _VariantCall { VCALL_LOCALMEM1(PoolColorArray, append); VCALL_LOCALMEM1(PoolColorArray, append_array); VCALL_LOCALMEM0(PoolColorArray, invert); + VCALL_LOCALMEM2R(PoolColorArray, find); + VCALL_LOCALMEM2R(PoolColorArray, rfind); + VCALL_LOCALMEM1R(PoolColorArray, count); + VCALL_LOCALMEM1R(PoolColorArray, has); #define VCALL_PTR0(m_type, m_method) \ static void _call_##m_type##_##m_method(Variant &r_ret, Variant &p_self, const Variant **p_args) { reinterpret_cast(p_self._data._ptr)->m_method(); } @@ -1946,6 +1974,10 @@ void register_variant_methods() { ADDFUNC1(POOL_BYTE_ARRAY, NIL, PoolByteArray, resize, INT, "idx", varray()); ADDFUNC0(POOL_BYTE_ARRAY, NIL, PoolByteArray, invert, varray()); ADDFUNC2R(POOL_BYTE_ARRAY, POOL_BYTE_ARRAY, PoolByteArray, subarray, INT, "from", INT, "to", varray()); + ADDFUNC2R(POOL_BYTE_ARRAY, INT, PoolByteArray, find, INT, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_BYTE_ARRAY, INT, PoolByteArray, rfind, INT, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_BYTE_ARRAY, INT, PoolByteArray, count, INT, "value", varray()); + ADDFUNC1R(POOL_BYTE_ARRAY, BOOL, PoolByteArray, has, INT, "value", varray()); ADDFUNC0R(POOL_BYTE_ARRAY, STRING, PoolByteArray, get_string_from_ascii, varray()); ADDFUNC0R(POOL_BYTE_ARRAY, STRING, PoolByteArray, get_string_from_utf8, varray()); @@ -1965,6 +1997,10 @@ void register_variant_methods() { ADDFUNC2R(POOL_INT_ARRAY, INT, PoolIntArray, insert, INT, "idx", INT, "integer", varray()); ADDFUNC1(POOL_INT_ARRAY, NIL, PoolIntArray, resize, INT, "idx", varray()); ADDFUNC0(POOL_INT_ARRAY, NIL, PoolIntArray, invert, varray()); + ADDFUNC2R(POOL_INT_ARRAY, INT, PoolIntArray, find, INT, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_INT_ARRAY, INT, PoolIntArray, rfind, INT, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_INT_ARRAY, INT, PoolIntArray, count, INT, "value", varray()); + ADDFUNC1R(POOL_INT_ARRAY, BOOL, PoolIntArray, has, INT, "value", varray()); ADDFUNC0R(POOL_REAL_ARRAY, INT, PoolRealArray, size, varray()); ADDFUNC0R(POOL_REAL_ARRAY, BOOL, PoolRealArray, empty, varray()); @@ -1977,6 +2013,10 @@ void register_variant_methods() { ADDFUNC2R(POOL_REAL_ARRAY, INT, PoolRealArray, insert, INT, "idx", REAL, "value", varray()); ADDFUNC1(POOL_REAL_ARRAY, NIL, PoolRealArray, resize, INT, "idx", varray()); ADDFUNC0(POOL_REAL_ARRAY, NIL, PoolRealArray, invert, varray()); + ADDFUNC2R(POOL_REAL_ARRAY, INT, PoolRealArray, find, REAL, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_REAL_ARRAY, INT, PoolRealArray, rfind, REAL, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_REAL_ARRAY, INT, PoolRealArray, count, REAL, "value", varray()); + ADDFUNC1R(POOL_REAL_ARRAY, BOOL, PoolRealArray, has, REAL, "value", varray()); ADDFUNC0R(POOL_STRING_ARRAY, INT, PoolStringArray, size, varray()); ADDFUNC0R(POOL_STRING_ARRAY, BOOL, PoolStringArray, empty, varray()); @@ -1990,6 +2030,10 @@ void register_variant_methods() { ADDFUNC1(POOL_STRING_ARRAY, NIL, PoolStringArray, resize, INT, "idx", varray()); ADDFUNC0(POOL_STRING_ARRAY, NIL, PoolStringArray, invert, varray()); ADDFUNC1(POOL_STRING_ARRAY, STRING, PoolStringArray, join, STRING, "delimiter", varray()); + ADDFUNC2R(POOL_STRING_ARRAY, INT, PoolStringArray, find, STRING, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_STRING_ARRAY, INT, PoolStringArray, rfind, STRING, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_STRING_ARRAY, INT, PoolStringArray, count, STRING, "value", varray()); + ADDFUNC1R(POOL_STRING_ARRAY, BOOL, PoolStringArray, has, STRING, "value", varray()); ADDFUNC0R(POOL_VECTOR2_ARRAY, INT, PoolVector2Array, size, varray()); ADDFUNC0R(POOL_VECTOR2_ARRAY, BOOL, PoolVector2Array, empty, varray()); @@ -2002,6 +2046,10 @@ void register_variant_methods() { ADDFUNC2R(POOL_VECTOR2_ARRAY, INT, PoolVector2Array, insert, INT, "idx", VECTOR2, "vector2", varray()); ADDFUNC1(POOL_VECTOR2_ARRAY, NIL, PoolVector2Array, resize, INT, "idx", varray()); ADDFUNC0(POOL_VECTOR2_ARRAY, NIL, PoolVector2Array, invert, varray()); + ADDFUNC2R(POOL_VECTOR2_ARRAY, INT, PoolVector2Array, find, VECTOR2, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_VECTOR2_ARRAY, INT, PoolVector2Array, rfind, VECTOR2, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_VECTOR2_ARRAY, INT, PoolVector2Array, count, VECTOR2, "value", varray()); + ADDFUNC1R(POOL_VECTOR2_ARRAY, BOOL, PoolVector2Array, has, VECTOR2, "value", varray()); ADDFUNC0R(POOL_VECTOR3_ARRAY, INT, PoolVector3Array, size, varray()); ADDFUNC0R(POOL_VECTOR3_ARRAY, BOOL, PoolVector3Array, empty, varray()); @@ -2014,6 +2062,10 @@ void register_variant_methods() { ADDFUNC2R(POOL_VECTOR3_ARRAY, INT, PoolVector3Array, insert, INT, "idx", VECTOR3, "vector3", varray()); ADDFUNC1(POOL_VECTOR3_ARRAY, NIL, PoolVector3Array, resize, INT, "idx", varray()); ADDFUNC0(POOL_VECTOR3_ARRAY, NIL, PoolVector3Array, invert, varray()); + ADDFUNC2R(POOL_VECTOR3_ARRAY, INT, PoolVector3Array, find, VECTOR3, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_VECTOR3_ARRAY, INT, PoolVector3Array, rfind, VECTOR3, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_VECTOR3_ARRAY, INT, PoolVector3Array, count, VECTOR3, "value", varray()); + ADDFUNC1R(POOL_VECTOR3_ARRAY, BOOL, PoolVector3Array, has, VECTOR3, "value", varray()); ADDFUNC0R(POOL_COLOR_ARRAY, INT, PoolColorArray, size, varray()); ADDFUNC0R(POOL_COLOR_ARRAY, BOOL, PoolColorArray, empty, varray()); @@ -2026,6 +2078,10 @@ void register_variant_methods() { ADDFUNC2R(POOL_COLOR_ARRAY, INT, PoolColorArray, insert, INT, "idx", COLOR, "color", varray()); ADDFUNC1(POOL_COLOR_ARRAY, NIL, PoolColorArray, resize, INT, "idx", varray()); ADDFUNC0(POOL_COLOR_ARRAY, NIL, PoolColorArray, invert, varray()); + ADDFUNC2R(POOL_COLOR_ARRAY, INT, PoolColorArray, find, COLOR, "value", INT, "from", varray(0)); + ADDFUNC2R(POOL_COLOR_ARRAY, INT, PoolColorArray, rfind, COLOR, "value", INT, "from", varray(-1)); + ADDFUNC1R(POOL_COLOR_ARRAY, INT, PoolColorArray, count, COLOR, "value", varray()); + ADDFUNC1R(POOL_COLOR_ARRAY, BOOL, PoolColorArray, has, COLOR, "value", varray()); //pointerbased diff --git a/doc/classes/Array.xml b/doc/classes/Array.xml index 8cc3ffcd4fd..7b3175b47af 100644 --- a/doc/classes/Array.xml +++ b/doc/classes/Array.xml @@ -193,7 +193,7 @@ - Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. @@ -315,7 +315,7 @@ - Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. diff --git a/doc/classes/PoolByteArray.xml b/doc/classes/PoolByteArray.xml index 4046e9346b5..053a01de4cc 100644 --- a/doc/classes/PoolByteArray.xml +++ b/doc/classes/PoolByteArray.xml @@ -36,6 +36,13 @@ Returns a new [PoolByteArray] with the data compressed. Set the compression mode using one of [enum File.CompressionMode]'s constants. + + + + + Returns the number of times an element is in the array. + + @@ -67,6 +74,14 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + @@ -79,6 +94,14 @@ Returns a copy of the array's contents as [String]. Slower than [method get_string_from_ascii] but supports UTF-8 encoded data. Use this function if you are unsure about the source of the data. For user input this function should always be preferred. + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -121,6 +144,14 @@ [b]Note:[/b] Added elements are not automatically initialized to 0 and will contain garbage, i.e. indeterminate values. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolColorArray.xml b/doc/classes/PoolColorArray.xml index 11cea2a0f14..f07077c9d4e 100644 --- a/doc/classes/PoolColorArray.xml +++ b/doc/classes/PoolColorArray.xml @@ -29,6 +29,13 @@ Appends a [PoolColorArray] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -41,6 +48,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -72,6 +95,14 @@ Sets the size of the array. If the array is grown, reserves elements at the end of the array. If the array is shrunk, truncates the array to the new size. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolIntArray.xml b/doc/classes/PoolIntArray.xml index 3490f1bdb62..875e38210de 100644 --- a/doc/classes/PoolIntArray.xml +++ b/doc/classes/PoolIntArray.xml @@ -30,6 +30,13 @@ Appends a [PoolIntArray] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -42,6 +49,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -74,6 +97,14 @@ [b]Note:[/b] Added elements are not automatically initialized to 0 and will contain garbage, i.e. indeterminate values. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolRealArray.xml b/doc/classes/PoolRealArray.xml index c159c87195b..850ce887051 100644 --- a/doc/classes/PoolRealArray.xml +++ b/doc/classes/PoolRealArray.xml @@ -30,6 +30,13 @@ Appends a [PoolRealArray] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -42,6 +49,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -74,6 +97,14 @@ [b]Note:[/b] Added elements are not automatically initialized to 0 and will contain garbage, i.e. indeterminate values. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolStringArray.xml b/doc/classes/PoolStringArray.xml index aac699a2029..12249fd15dd 100644 --- a/doc/classes/PoolStringArray.xml +++ b/doc/classes/PoolStringArray.xml @@ -30,6 +30,13 @@ Appends a [PoolStringArray] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -42,6 +49,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -80,6 +103,14 @@ Sets the size of the array. If the array is grown, reserves elements at the end of the array. If the array is shrunk, truncates the array to the new size. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolVector2Array.xml b/doc/classes/PoolVector2Array.xml index 272bcb298f3..1720be783e5 100644 --- a/doc/classes/PoolVector2Array.xml +++ b/doc/classes/PoolVector2Array.xml @@ -30,6 +30,13 @@ Appends a [PoolVector2Array] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -42,6 +49,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -73,6 +96,14 @@ Sets the size of the array. If the array is grown, reserves elements at the end of the array. If the array is shrunk, truncates the array to the new size. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + + diff --git a/doc/classes/PoolVector3Array.xml b/doc/classes/PoolVector3Array.xml index ab0e6ba6753..dc5a6a4ca4c 100644 --- a/doc/classes/PoolVector3Array.xml +++ b/doc/classes/PoolVector3Array.xml @@ -29,6 +29,13 @@ Appends a [PoolVector3Array] at the end of this array. + + + + + Returns the number of times an element is in the array. + + @@ -41,6 +48,22 @@ Assigns the given value to all elements in the array. This can typically be used together with [method resize] to create an array with a given size and initialized elements. + + + + + + Searches the array for a value and returns its index or [code]-1[/code] if not found. Optionally, the initial search index can be passed. Returns [code]-1[/code] if [code]from[/code] is out of bounds. + + + + + + + Returns [code]true[/code] if the array contains the given value. + [b]Note:[/b] This is equivalent to using the [code]in[/code] operator. + + @@ -72,6 +95,14 @@ Sets the size of the array. If the array is grown, reserves elements at the end of the array. If the array is shrunk, truncates the array to the new size. + + + + + + Searches the array in reverse order. Optionally, a start search index can be passed. If negative, the start index is considered relative to the end of the array. If the adjusted start index is out of bounds, this method searches from the end of the array. + +