fix problems in Queue.c / Stack.c ; still issues: to investigate
[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;
012c97dd 10 _vector_init(queue->array, dataSize);
a7868768
BA
11}
12
13Queue* _queue_new(size_t dataSize)
14{
15 Queue* queue = (Queue*) safe_malloc(sizeof (Queue));
ea7acb53 16 queue->array = _vector_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;
25 Vector* arrayCopy = vector_copy(queue->array);
26 queueCopy->array = arrayCopy;
a7868768
BA
27 return queueCopy;
28}
29
30Bool queue_empty(Queue* queue)
31{
012c97dd 32 return vector_empty(queue->array);
a7868768
BA
33}
34
35UInt queue_size(Queue* queue)
36{
012c97dd 37 return vector_size(queue->array);
a7868768
BA
38}
39
40void _queue_push(Queue* queue, void* data)
41{
012c97dd 42 _vector_push(queue->array, data);
a7868768
BA
43}
44
45void* _queue_peek(Queue* queue)
46{
bbd242d4 47 return _vector_get(queue->array, 0);
a7868768
BA
48}
49
50void queue_pop(Queue* queue)
51{
012c97dd
BA
52 //remove first vector element and shift its internal array
53 safe_free(queue->array->datas[0]);
54 queue->array->datas++;
55 //NOTE: we remove first element, so capacity decrease too
56 queue->array->size--;
57 queue->array->capacity--;
a7868768
BA
58}
59
60void queue_clear(Queue* queue)
61{
012c97dd 62 vector_clear(queue->array);
a7868768
BA
63}
64
65void queue_destroy(Queue* queue)
66{
ea7acb53 67 vector_destroy(queue->array);
a7868768
BA
68 safe_free(queue);
69}