From 2f173a67abebd14805d6f7c44db2e8b5c4b5cf83 Mon Sep 17 00:00:00 2001 From: Marius Guggenmos Date: Sat, 7 Oct 2017 17:49:23 +0200 Subject: [PATCH] Array::sort, sort_custom and invert now return reference to Array to allow chaining of operations --- core/array.cpp | 11 +++++++---- core/array.h | 6 +++--- doc/classes/Array.xml | 12 +++++++++--- 3 files changed, 19 insertions(+), 10 deletions(-) diff --git a/core/array.cpp b/core/array.cpp index 30184a002e8..171c11776c9 100644 --- a/core/array.cpp +++ b/core/array.cpp @@ -233,9 +233,10 @@ struct _ArrayVariantSort { } }; -void Array::sort() { +Array &Array::sort() { _p->array.sort_custom<_ArrayVariantSort>(); + return *this; } struct _ArrayVariantSortCustom { @@ -253,19 +254,21 @@ struct _ArrayVariantSortCustom { 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 avs; avs.compare.obj = p_obj; avs.compare.func = p_function; avs.sort(_p->array.ptr(), _p->array.size()); + return *this; } -void Array::invert() { +Array &Array::invert() { _p->array.invert(); + return *this; } void Array::push_front(const Variant &p_value) { diff --git a/core/array.h b/core/array.h index 8a647dd13bc..2c291031085 100644 --- a/core/array.h +++ b/core/array.h @@ -68,9 +68,9 @@ public: Variant front() 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 rfind(const Variant &p_value, int p_from = -1) const; diff --git a/doc/classes/Array.xml b/doc/classes/Array.xml index 9542c83eaf0..cc5f371087f 100644 --- a/doc/classes/Array.xml +++ b/doc/classes/Array.xml @@ -177,8 +177,10 @@ + + - 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. @@ -238,17 +240,21 @@ + + - Sort the array using natural order. + Sort the array using natural order and return reference to the array. + + - 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.