Implement HashTable + fix some extra blank spaces, remove Bool type (using bool ...
[cgds.git] / src / Queue.c
CommitLineData
a7868768
BA
1/**
2 * @file Queue.c
3 */
4
5#include "cgds/Queue.h"
6
7void _queue_init(Queue* queue, size_t dataSize)
8{
a7868768 9 queue->dataSize = dataSize;
195fd722 10 _list_init(queue->list, dataSize);
a7868768
BA
11}
12
13Queue* _queue_new(size_t dataSize)
14{
15 Queue* queue = (Queue*) safe_malloc(sizeof (Queue));
195fd722 16 queue->list = _list_new(dataSize);
a7868768
BA
17 _queue_init(queue, dataSize);
18 return queue;
19}
20
21Queue* queue_copy(Queue* queue)
22{
012c97dd
BA
23 Queue* queueCopy = (Queue*) safe_malloc(sizeof (Queue));
24 queueCopy->dataSize = queue->dataSize;
195fd722
BA
25 List* listCopy = list_copy(queue->list);
26 queueCopy->list = listCopy;
a7868768
BA
27 return queueCopy;
28}
29
1ff641f9 30bool queue_empty(Queue* queue)
a7868768 31{
195fd722 32 return list_empty(queue->list);
a7868768
BA
33}
34
35UInt queue_size(Queue* queue)
36{
195fd722 37 return list_size(queue->list);
a7868768
BA
38}
39
40void _queue_push(Queue* queue, void* data)
41{
195fd722 42 _list_insert_back(queue->list, data);
a7868768
BA
43}
44
45void* _queue_peek(Queue* queue)
46{
195fd722 47 return _list_get(queue->list->head);
a7868768
BA
48}
49
50void queue_pop(Queue* queue)
51{
195fd722 52 list_remove_front(queue->list);
a7868768
BA
53}
54
55void queue_clear(Queue* queue)
56{
195fd722 57 list_clear(queue->list);
a7868768
BA
58}
59
60void queue_destroy(Queue* queue)
61{
195fd722 62 list_destroy(queue->list);
a7868768
BA
63 safe_free(queue);
64}