blob: ba430239a6989d06dddcc7bfa783fc3e3fba3876 (
plain)
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
|
#include "./include/stack.h"
#include "./include/hash_table.h"
#include "./include/macros.h"
#include <stdio.h>
#include <stdlib.h>
stack_t *init_stack() {
stack_t *s = (stack_t *)malloc(sizeof(stack_t));
if (s == NULL)
die("malloc on stack");
s->stack = NULL;
s->cur = -1;
return s;
}
void stack_push(stack_t *s, hash_table_t *h) {
if (s->stack == NULL) {
s->stack = malloc(sizeof(hash_table_t *));
if (s->stack == NULL)
die("malloc on stack within stack_push");
} else {
s->stack = realloc(s->stack, (2 + s->cur) * sizeof(hash_table_t *));
}
s->cur++;
s->stack[s->cur] = h;
}
/* fix heap buffer overflow */
hash_table_t *stack_peek(stack_t *s) {
if (is_empty(s))
return NULL;
return s->stack[s->cur];
}
hash_table_t *stack_pop(stack_t *s) {
hash_table_t *h = s->stack[s->cur];
s->stack[s->cur] = NULL;
s->cur--;
return h;
}
bool is_empty(stack_t *s) {
if (s->cur == -1)
return true;
return false;
}
void stack_free(stack_t *s) {
if (s->stack != NULL) {
free(s->stack);
}
free(s);
}
|