summaryrefslogtreecommitdiff
path: root/src/stack.c
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);
}