2014-11-22 23:59:48 +08:00
|
|
|
'use strict';
|
|
|
|
|
2010-04-13 00:27:32 +08:00
|
|
|
// This is a free list to avoid creating so many of the same object.
|
|
|
|
exports.FreeList = function(name, max, constructor) {
|
|
|
|
this.name = name;
|
|
|
|
this.constructor = constructor;
|
|
|
|
this.max = max;
|
|
|
|
this.list = [];
|
2010-10-07 11:05:23 +08:00
|
|
|
};
|
2010-04-13 00:27:32 +08:00
|
|
|
|
|
|
|
|
2010-12-02 09:43:30 +08:00
|
|
|
exports.FreeList.prototype.alloc = function() {
|
2010-04-13 00:27:32 +08:00
|
|
|
//debug("alloc " + this.name + " " + this.list.length);
|
2010-12-02 09:43:30 +08:00
|
|
|
return this.list.length ? this.list.shift() :
|
|
|
|
this.constructor.apply(this, arguments);
|
2010-04-13 00:27:32 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
|
2010-12-02 09:43:30 +08:00
|
|
|
exports.FreeList.prototype.free = function(obj) {
|
2010-04-13 00:27:32 +08:00
|
|
|
//debug("free " + this.name + " " + this.list.length);
|
|
|
|
if (this.list.length < this.max) {
|
|
|
|
this.list.push(obj);
|
2014-08-23 06:31:44 +08:00
|
|
|
return true;
|
2010-04-13 00:27:32 +08:00
|
|
|
}
|
2014-08-23 06:31:44 +08:00
|
|
|
return false;
|
2010-04-13 00:27:32 +08:00
|
|
|
};
|