Skip to content

Commit

Permalink
(Array) pop_front, pop_back return values
Browse files Browse the repository at this point in the history
pop_front, pop_back now return values instead of `void`. Things
I didn't know how to properly implement:

1. pop_front & pop_back shows in the help menu Object as return value.
   I know this is incorrect but if not Object than what? Cause it
   can't be void. It needs to be a generic type that includes all the
   Array types
  • Loading branch information
razcore-rad committed Sep 11, 2016
1 parent c40ab44 commit 1a7aae7
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 9 deletions.
20 changes: 15 additions & 5 deletions core/array.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -276,16 +276,26 @@ void Array::push_front(const Variant& p_value) {
_p->array.insert(0,p_value);
}

void Array::pop_back(){
Variant Array::pop_back(){

if (!_p->array.empty())
_p->array.resize( _p->array.size() -1 );
if (!_p->array.empty()) {
int n = _p->array.size() - 1;
Variant ret = _p->array.get(n);
_p->array.resize(n);
return ret;
}
return Variant();

}
void Array::pop_front(){

if (!_p->array.empty())
Variant Array::pop_front(){

if (!_p->array.empty()) {
Variant ret = _p->array.get(0);
_p->array.remove(0);
return ret;
}
return Variant();

}

Expand Down
4 changes: 2 additions & 2 deletions core/array.h
Original file line number Diff line number Diff line change
Expand Up @@ -80,8 +80,8 @@ class Array {
void erase(const Variant& p_value);

void push_front(const Variant& p_value);
void pop_back();
void pop_front();
Variant pop_back();
Variant pop_front();

Array(const Array& p_from);
Array(bool p_shared=false);
Expand Down
4 changes: 2 additions & 2 deletions core/variant_call.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -464,8 +464,8 @@ static void _call_##m_type##_##m_method(Variant& r_ret,Variant& p_self,const Var
VCALL_LOCALMEM0R(Array,hash);
VCALL_LOCALMEM1(Array,push_back);
VCALL_LOCALMEM1(Array,push_front);
VCALL_LOCALMEM0(Array,pop_back);
VCALL_LOCALMEM0(Array,pop_front);
VCALL_LOCALMEM0R(Array,pop_back);
VCALL_LOCALMEM0R(Array,pop_front);
VCALL_LOCALMEM1(Array,append);
VCALL_LOCALMEM1(Array,resize);
VCALL_LOCALMEM2(Array,insert);
Expand Down

0 comments on commit 1a7aae7

Please sign in to comment.