public
Description: a personal programming language written for school
Clone URL: git://github.com/brosner/dpl.git
brosner (author)
Tue May 13 00:44:02 -0700 2008
commit  c18c15b08bf890e2055a42f30813c7a01ee04ffc
tree    84dc8a0476de2dc79f5c4c47cdbf3d2bc62f3e57
parent  b1887024450de241ab24b5b810bcea079e67210d
dpl / src / stack.c
100755 81 lines (61 sloc) 1.79 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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
/*
+----------------------------------------------+
| DPL Programming Language v1.1 |
+----------------------------------------------+
| The DPL langauge was developed for a school |
| project at ThunderRidge High School. |
| |
| Development of the language after its |
| completion is reserved to Brian Rosner. |
+----------------------------------------------+
| Author: Brian Rosner <br@brosner.com> |
+----------------------------------------------+
*/
 
#include <stdio.h>
#include <string.h>
 
#include "dpl.h"
#include "stack.h"
 
void stackInit(Stack *stack) {
  stack->size = 0;
  stack->head = NULL;
  stack->tail = NULL;
}
 
void stackDestroy(Stack *stack) {
}
 
int stackPush(Stack *stack, void *data, int size) {
  StackElement *element;
 
  /* allocate memory for element */
  element = (StackElement *) malloc(sizeof(StackElement));
 
  if(element == NULL) {
    return FAILURE;
  }
 
  /* allocate memory for data and store it */
  element->data = (void *) malloc(size);
  memcpy(element->data, data, size);
 
  if(stackSize(stack) == 0) {
    stack->tail = element;
  }
 
  element->next = stack->head;
  stack->head = element;
 
  /* adjust stack size */
  stackSize(stack)++;
 
  return SUCCESS;
}
 
int stackPop(Stack *stack, void **data) {
  StackElement *element;
 
  /* dont allow removal from empty list */
  if(stackSize(stack) == 0) {
    return FAILURE;
  }
 
  *data = stack->head->data;
  element = stack->head;
  stack->head = stack->head->next;
 
  if(stackSize(stack) == 1) {
    stack->tail = NULL;
  }
 
  /* free memory */
  free(element);
 
  /* adjust stack size */
  stackSize(stack)--;
 
  return SUCCESS;
}