Browse Source

Merge pull request #11919 from Toizi/array_sort_ref

Array::sort/invert now return reference to Array
Andreas Haas 8 years ago
parent
commit
1d8a546a07
3 changed files with 19 additions and 10 deletions
  1. 7 4
      core/array.cpp
  2. 3 3
      core/array.h
  3. 9 3
      doc/classes/Array.xml

+ 7 - 4
core/array.cpp

@@ -233,9 +233,10 @@ struct _ArrayVariantSort {
 	}
 	}
 };
 };
 
 
-void Array::sort() {
+Array &Array::sort() {
 
 
 	_p->array.sort_custom<_ArrayVariantSort>();
 	_p->array.sort_custom<_ArrayVariantSort>();
+	return *this;
 }
 }
 
 
 struct _ArrayVariantSortCustom {
 struct _ArrayVariantSortCustom {
@@ -253,19 +254,21 @@ struct _ArrayVariantSortCustom {
 		return res;
 		return res;
 	}
 	}
 };
 };
-void Array::sort_custom(Object *p_obj, const StringName &p_function) {
+Array &Array::sort_custom(Object *p_obj, const StringName &p_function) {
 
 
-	ERR_FAIL_NULL(p_obj);
+	ERR_FAIL_NULL_V(p_obj, *this);
 
 
 	SortArray<Variant, _ArrayVariantSortCustom> avs;
 	SortArray<Variant, _ArrayVariantSortCustom> avs;
 	avs.compare.obj = p_obj;
 	avs.compare.obj = p_obj;
 	avs.compare.func = p_function;
 	avs.compare.func = p_function;
 	avs.sort(_p->array.ptr(), _p->array.size());
 	avs.sort(_p->array.ptr(), _p->array.size());
+	return *this;
 }
 }
 
 
-void Array::invert() {
+Array &Array::invert() {
 
 
 	_p->array.invert();
 	_p->array.invert();
+	return *this;
 }
 }
 
 
 void Array::push_front(const Variant &p_value) {
 void Array::push_front(const Variant &p_value) {

+ 3 - 3
core/array.h

@@ -68,9 +68,9 @@ public:
 	Variant front() const;
 	Variant front() const;
 	Variant back() const;
 	Variant back() const;
 
 
-	void sort();
-	void sort_custom(Object *p_obj, const StringName &p_function);
-	void invert();
+	Array &sort();
+	Array &sort_custom(Object *p_obj, const StringName &p_function);
+	Array &invert();
 
 
 	int find(const Variant &p_value, int p_from = 0) const;
 	int find(const Variant &p_value, int p_from = 0) const;
 	int rfind(const Variant &p_value, int p_from = -1) const;
 	int rfind(const Variant &p_value, int p_from = -1) const;

+ 9 - 3
doc/classes/Array.xml

@@ -178,8 +178,10 @@
 			</description>
 			</description>
 		</method>
 		</method>
 		<method name="invert">
 		<method name="invert">
+			<return type="Array">
+			</return>
 			<description>
 			<description>
-				Reverse the order of the elements in the array (so first element will now be the last).
+				Reverse the order of the elements in the array (so first element will now be the last) and return reference to the array.
 			</description>
 			</description>
 		</method>
 		</method>
 		<method name="pop_back">
 		<method name="pop_back">
@@ -239,17 +241,21 @@
 			</description>
 			</description>
 		</method>
 		</method>
 		<method name="sort">
 		<method name="sort">
+			<return type="Array">
+			</return>
 			<description>
 			<description>
-				Sort the array using natural order.
+				Sort the array using natural order and return reference to the array.
 			</description>
 			</description>
 		</method>
 		</method>
 		<method name="sort_custom">
 		<method name="sort_custom">
+			<return type="Array">
+			</return>
 			<argument index="0" name="obj" type="Object">
 			<argument index="0" name="obj" type="Object">
 			</argument>
 			</argument>
 			<argument index="1" name="func" type="String">
 			<argument index="1" name="func" type="String">
 			</argument>
 			</argument>
 			<description>
 			<description>
-				Sort the array using a custom method. The arguments are an object that holds the method and the name of such method. The custom method receives two arguments (a pair of elements from the array) and must return true if the first argument is less than the second, and return false otherwise. Note: you cannot randomize the return value as the heapsort algorithm expects a deterministic result. Doing so will result in unexpected behavior.
+				Sort the array using a custom method and return reference to the array. The arguments are an object that holds the method and the name of such method. The custom method receives two arguments (a pair of elements from the array) and must return true if the first argument is less than the second, and return false otherwise. Note: you cannot randomize the return value as the heapsort algorithm expects a deterministic result. Doing so will result in unexpected behavior.
 			</description>
 			</description>
 		</method>
 		</method>
 	</methods>
 	</methods>