-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathqueue.c
More file actions
62 lines (49 loc) · 1.14 KB
/
queue.c
File metadata and controls
62 lines (49 loc) · 1.14 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/**
* Projekt c.3 do predmetu IPK
* @author Jan Dusek <xdusek17@stud.fit.vutbr.cz>
* @date 20.4.2011
*/
#include "queue.h"
void queue_init(queue_t* q, delete_item_func_t func) {
q->head = NULL;
q->tail = NULL;
q->size = 0;
q->del_func = func;
}
int queue_append(queue_t* q, const queue_data_t* data) {
queue_item_t *item = malloc(sizeof(queue_item_t));
if (item == NULL)
return 0;
item->qdata = *data;
item->next = NULL;
if (q->head == NULL)
q->head = item;
else
q->tail->next = item;
q->tail = item;
return ++q->size;
}
int queue_is_empty(queue_t* q) {
return !q->size;
}
void queue_remove(queue_t* q) {
q->del_func(q->head->qdata.data);
queue_item_t *oldhead = q->head;
q->head = q->head->next;
free(oldhead);
q->size--;
}
void queue_destroy(queue_t* q) {
while (!queue_is_empty(q))
queue_remove(q);
}
queue_data_t* queue_get(queue_t* q, size_t index) {
int i = 0;
queue_item_t *item = q->head;
while (item != NULL) {
if (i++ == index)
return &item->qdata;
item = item->next;
}
return NULL;
}