diff options
| author | Rémi Verschelde | 2016-06-04 16:07:48 +0200 |
|---|---|---|
| committer | Rémi Verschelde | 2016-06-04 16:07:48 +0200 |
| commit | 4b0bae97998dc337c0ca3cfb84332fe2d06d3433 (patch) | |
| tree | 01b985e9b4d0065b023c8e1b38dee18053292c06 /core/array.cpp | |
| parent | 992a76b41a59de8aad28cf6bce918e7d17970e4e (diff) | |
| parent | 5f5ca8cd9b323e3a89940afd5df09099f83d1473 (diff) | |
| download | godot-4b0bae97998dc337c0ca3cfb84332fe2d06d3433.tar.gz godot-4b0bae97998dc337c0ca3cfb84332fe2d06d3433.tar.zst godot-4b0bae97998dc337c0ca3cfb84332fe2d06d3433.zip | |
Merge pull request #5027 from J08nY/gdscript
Add Array.find_last() and Array.count()
Diffstat (limited to 'core/array.cpp')
| -rw-r--r-- | core/array.cpp | 31 |
1 files changed, 31 insertions, 0 deletions
diff --git a/core/array.cpp b/core/array.cpp index fef0fcbb4..1d283a14a 100644 --- a/core/array.cpp +++ b/core/array.cpp @@ -155,6 +155,37 @@ int Array::find(const Variant& p_value) const { return _p->array.find(p_value); } +int Array::find_last(const Variant& p_value) const { + + if(_p->array.size() == 0) + return -1; + + for (int i=_p->array.size()-1; i>=0; i--) { + + if(_p->array[i] == p_value){ + return i; + }; + }; + + return -1; +} + +int Array::count(const Variant& p_value) const { + + if(_p->array.size() == 0) + return 0; + + int amount=0; + for (int i=0; i<_p->array.size(); i++) { + + if(_p->array[i] == p_value){ + amount++; + }; + }; + + return amount; +} + void Array::remove(int p_pos) { _p->array.remove(p_pos); |
