fifo
FIFO queue implemented using a double linked-list
Last updated 3 years ago by mafintosh .
MIT · Repository · Bugs · Original npm · Tarball · package.json
$ npm install fifo 
SYNC missed versions from official npm registry.

fifo

FIFO queue implemented using a double linked-list

npm install fifo

build status

Usage

var fifo = require('fifo')()

fifo.push('hello')
fifo.push('world')

console.log(fifo.first()) // prints hello
console.log(fifo.last())  // prints world

console.log(fifo.shift()) // prints hello
console.log(fifo.shift()) // prints world

var node = fifo.push('meh')

fifo.remove(node)     // remove 'meh' from the stack
fifo.unshift('hello') // insert at the beginning

fifo uses a linked list behind the scene so all list manipulation methods run in O(1)

API

fifo = FIFO()

Create a new instance

fifo.node

Contains the first node on the list.

fifo.length

Number of nodes in the list.

node = fifo.push(value)

Push a new value to the end of the list. Returns a node that contains this value. The value can be accessed by accessing node.value.

value = fifo.shift()

Removes the first node and returns the value

value = fifo.pop()

Removes the last node and returns the value

value = fifo.remove(node)

Removes the node and returns the value

fifo.add(node)

Readds a node. Should only be done with a node that has been removed.

value = fifo.first()

Peek at the first value

value = fifo.last()

Peek at the last value

node = fifo.unshift(value)

Inserts a value at the beginning of the list

node = fifo.next(node)

Returns the next node relative to the node you pass. If the node was the last node in the list null is returned.

node = fifo.prev(node)

Returns the previous node relative to the node you pass. If the node was the first node in the list null is returned.

fifo.bump(node)

Moves a node to the end of the list

fifo.clear()

Clears the list.

fifo.forEach(fn)

Iterate over all values in the list. Calls the function with value, node.

Iteration

To iterate the list simply use the following for loop

for (var node = fifo.node; node; node = fifo.next(node)) {
  console.log('value is', node.value)
}

Optionally you can call fifo.forEach(fn) which does the above internally.

License

MIT

Current Tags

  • 2.4.1                                ...           latest (3 years ago)

13 Versions

  • 2.4.1                                ...           3 years ago
  • 2.4.0                                ...           3 years ago
  • 2.3.0                                ...           9 years ago
  • 2.2.1                                ...           9 years ago
  • 2.2.0                                ...           9 years ago
  • 2.1.0                                ...           10 years ago
  • 2.0.0                                ...           10 years ago
  • 0.2.0                                ...           11 years ago
  • 0.1.4                                ...           11 years ago
  • 0.1.3                                ...           11 years ago
  • 0.1.2                                ...           11 years ago
  • 0.1.1                                ...           11 years ago
  • 0.1.0                                ...           11 years ago
Maintainers (1)
Downloads
Total 14
Today 1
This Week 1
This Month 14
Last Day 0
Last Week 13
Last Month 0
Dependencies (0)
None
Dev Dependencies (1)
Dependents (1)

© 2010 - cnpmjs.org x YWFE | Home | YWFE