Skip to content

Latest commit

 

History

History
64 lines (46 loc) · 1.38 KB

README.md

File metadata and controls

64 lines (46 loc) · 1.38 KB

hnc-pq - Erlang priority queues

🔗 API documentation (EDoc)

hnc-pq implements priority queues, built on regular Erlang queues.

Usage Example

%% Create a new hnc_pq instance with
%% 3 priorities: high, normal, and low
PQ0=hnc_pq:new([high, normal, low]).

%% Enqueue an item with high priority.
PQ1=hnc_pq:in(high, item_high, PQ0).

%% Enqueue another item with normal priority.
PQ2=hnc_pq:in(normal, item_normal, PQ1).

%% Enqueue yet another item with low priority.
PQ3=hnc_pq:in(low, item_low, PQ2).

%% Dequeue an item. Highest-priority items get
%% dequeued first.
{item_high, PQ4}=hnc_pq:out(PQ3).

%% Dequeue another item. As the high-priority
%% queue is empty by now, it is dequeued by
%% the next-highest priority queue (normal).
{item_normal, PQ5}=hnc_pq:out(PQ4).

%% Dequeue yet another item. As both the
%% high- and normal-priority queues are now
%% empty, it is dequeued from the next-highest
%% priority queue (low).
{item_low, PQ6}=hnc_pq:out(PQ5).

%% All queues are now empty.
empty=hnc_pq:out(PQ6).

Usage as a dependency

Erlang.mk

DEPS = hnc_pq
dep_hnc_pq = git https://github.com/hnc-agency/hnc-pq 0.1.2

rebar3

{deps, [
    {hnc, ".*", {git, "https://github.com/hnc-agency/hnc-pq",
                   {tag, "0.1.2"}}}
]}.

Authors

  • Maria Scott (Maria-12648430)
  • Jan Uhlig (juhlig)