README.md 2.79 KB
Newer Older
Rosanny Sihombing's avatar
Rosanny Sihombing committed
1
<p align="center">
Rosanny Sihombing's avatar
Rosanny Sihombing committed
2
  <h1 align="center">Denque</h1>
Rosanny Sihombing's avatar
Rosanny Sihombing committed
3
4
5
6
7
</p>

<p align="center">
  <a href="https://www.npmjs.com/package/denque"><img src="https://img.shields.io/npm/dm/denque.svg?style=flat-square" alt="NPM downloads"></a>
  <a href="https://www.npmjs.com/package/denque"><img src="https://img.shields.io/npm/v/denque.svg?style=flat-square" alt="NPM version"></a>
Rosanny Sihombing's avatar
Rosanny Sihombing committed
8
9
  <a href="https://github.com/invertase/denque/actions/workflows/testing.yam"><img src="https://github.com/invertase/denque/actions/workflows/testing.yaml/badge.svg" alt="Tests status"></a>
  <a href="https://codecov.io/gh/invertase/denque"><img src="https://codecov.io/gh/invertase/denque/branch/master/graph/badge.svg?token=rn91iI4bSe" alt="Coverage"></a>
Rosanny Sihombing's avatar
Rosanny Sihombing committed
10
11
12
13
  <a href="/LICENSE"><img src="https://img.shields.io/npm/l/denque.svg?style=flat-square" alt="License"></a>
  <a href="https://twitter.com/invertaseio"><img src="https://img.shields.io/twitter/follow/invertaseio.svg?style=social&label=Follow" alt="Follow on Twitter"></a>
</p>

Rosanny Sihombing's avatar
Rosanny Sihombing committed
14
15
Denque is a well tested, extremely fast and lightweight [double-ended queue](http://en.wikipedia.org/wiki/Double-ended_queue)
implementation with zero dependencies and includes TypeScript types.
Rosanny Sihombing's avatar
Rosanny Sihombing committed
16
17
18
19
20
21

Double-ended queues can also be used as a:

- [Stack](http://en.wikipedia.org/wiki/Stack_\(abstract_data_type\))
- [Queue](http://en.wikipedia.org/wiki/Queue_\(data_structure\))

Rosanny Sihombing's avatar
Rosanny Sihombing committed
22
This implementation is currently the fastest available, even faster than `double-ended-queue`, see the [benchmarks](https://docs.page/invertase/denque/benchmarks).
Rosanny Sihombing's avatar
Rosanny Sihombing committed
23
24
25
26
27

Every queue operation is done at a constant `O(1)` - including random access from `.peekAt(index)`.

**Works on all node versions >= v0.10**

Rosanny Sihombing's avatar
Rosanny Sihombing committed
28
## Quick Start
Rosanny Sihombing's avatar
Rosanny Sihombing committed
29

Rosanny Sihombing's avatar
Rosanny Sihombing committed
30
Install the package:
Rosanny Sihombing's avatar
Rosanny Sihombing committed
31

Rosanny Sihombing's avatar
Rosanny Sihombing committed
32
33
```bash
npm install denque
Rosanny Sihombing's avatar
Rosanny Sihombing committed
34
35
```

Rosanny Sihombing's avatar
Rosanny Sihombing committed
36
Create and consume a queue:
Rosanny Sihombing's avatar
Rosanny Sihombing committed
37
38

```js
Rosanny Sihombing's avatar
Rosanny Sihombing committed
39
const Denque = require("denque");
Rosanny Sihombing's avatar
Rosanny Sihombing committed
40

Rosanny Sihombing's avatar
Rosanny Sihombing committed
41
const denque = new Denque([1,2,3,4]);
Rosanny Sihombing's avatar
Rosanny Sihombing committed
42
43
44
45
46
denque.shift(); // 1
denque.pop(); // 4
```


Rosanny Sihombing's avatar
Rosanny Sihombing committed
47
See the [API reference documentation](https://docs.page/invertase/denque/api) for more examples.
Rosanny Sihombing's avatar
Rosanny Sihombing committed
48

Rosanny Sihombing's avatar
Rosanny Sihombing committed
49
---
Rosanny Sihombing's avatar
Rosanny Sihombing committed
50

Rosanny Sihombing's avatar
Rosanny Sihombing committed
51
## Who's using it?
Rosanny Sihombing's avatar
Rosanny Sihombing committed
52

Rosanny Sihombing's avatar
Rosanny Sihombing committed
53
54
55
56
57
- [Kafka Node.js client](https://www.npmjs.com/package/kafka-node)
- [MariaDB Node.js client](https://www.npmjs.com/package/mariadb)
- [MongoDB Node.js client](https://www.npmjs.com/package/mongodb)
- [MySQL Node.js client](https://www.npmjs.com/package/mysql2)
- [Redis Node.js clients](https://www.npmjs.com/package/redis)
Rosanny Sihombing's avatar
Rosanny Sihombing committed
58

Rosanny Sihombing's avatar
Rosanny Sihombing committed
59
... and [many more](https://www.npmjs.com/browse/depended/denque).
Rosanny Sihombing's avatar
Rosanny Sihombing committed
60
61


Rosanny Sihombing's avatar
Rosanny Sihombing committed
62
---
Rosanny Sihombing's avatar
Rosanny Sihombing committed
63

Rosanny Sihombing's avatar
Rosanny Sihombing committed
64
## License
Rosanny Sihombing's avatar
Rosanny Sihombing committed
65

Rosanny Sihombing's avatar
Rosanny Sihombing committed
66
- See [LICENSE](/LICENSE)
Rosanny Sihombing's avatar
Rosanny Sihombing committed
67
68
69

---

Rosanny Sihombing's avatar
Rosanny Sihombing committed
70
71
72
73
74
75
76
77
<p align="center">
  <a href="https://invertase.io/?utm_source=readme&utm_medium=footer&utm_campaign=denque">
    <img width="75px" src="https://static.invertase.io/assets/invertase/invertase-rounded-avatar.png">
  </a>
  <p align="center">
    Built and maintained by <a href="https://invertase.io/?utm_source=readme&utm_medium=footer&utm_campaign=denque">Invertase</a>.
  </p>
</p>