You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

36 lines
863 B

2 years ago
var Class = require('./Class');
var reverse = require('./reverse');
exports = Class({
initialize: function Stack() {
this.clear();
},
clear: function() {
this._items = [];
this.size = 0;
},
push: function(item) {
this._items.push(item);
return ++this.size;
},
pop: function() {
if (!this.size) return;
this.size--;
return this._items.pop();
},
peek: function() {
return this._items[this.size - 1];
},
forEach: function(iterator, ctx) {
ctx = arguments.length > 1 ? ctx : this;
var items = this._items;
for (var i = this.size - 1, j = 0; i >= 0; i--, j++) {
iterator.call(ctx, items[i], j, this);
}
},
toArr: function() {
return reverse(this._items);
}
});
module.exports = exports;