Thu, 22 Jan 2015 13:21:57 +0100
Incorporate requested changes from Mozilla in review:
https://bugzilla.mozilla.org/show_bug.cgi?id=1123480#c6
1 /* This Source Code Form is subject to the terms of the Mozilla Public
2 * License, v. 2.0. If a copy of the MPL was not distributed with this file,
3 * You can obtain one at http://mozilla.org/MPL/2.0/. */
5 this.EXPORTED_SYMBOLS = ["Queue"];
7 this.Queue = function Queue() {
8 this._queue = [];
9 this._index = 0;
10 }
12 Queue.prototype = {
13 getLength: function() { return (this._queue.length - this._index); },
15 isEmpty: function() { return (this._queue.length == 0); },
17 enqueue: function(item) { this._queue.push(item); },
19 dequeue: function() {
20 if(this.isEmpty())
21 return undefined;
23 var item = this._queue[this._index];
24 if (++this._index * 2 >= this._queue.length){
25 this._queue = this._queue.slice(this._index);
26 this._index = 0;
27 }
28 return item;
29 }
30 }