forked from cirosantilli/cpp-cheat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
template_cpp.c
68 lines (56 loc) · 1.7 KB
/
template_cpp.c
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
/*
We can use memcmp and void* to simulate C++ templates like this.
Other possibilities:
- union of all possible types to use + enum
- macros
Biblography:
- http://stackoverflow.com/questions/10950828/simulation-of-templates-in-c
- http://stackoverflow.com/questions/5551427/generic-data-type-in-c-void
- http://stackoverflow.com/questions/3039513/type-safe-generic-data-structures-in-plain-old-c
*/
#include "common.h"
typedef struct Stack Stack;
struct Stack {
void *data;
size_t nelems;
size_t elem_size;
size_t nelems_capacity;
};
void Stack_init(Stack *stack, size_t elem_size, size_t nelems_capacity) {
stack->nelems = 0;
stack->elem_size = elem_size;
stack->nelems_capacity = nelems_capacity;
stack->data = malloc(nelems_capacity * elem_size);
}
void Stack_deinit(Stack *stack) {
free(stack->data);
}
int Stack_push(Stack *stack, void *data) {
Stack *buffer;
if (stack->nelems == stack->nelems_capacity) {
stack->nelems_capacity *= 2;
buffer = realloc(stack->data, stack->nelems_capacity);
if (buffer == NULL)
return 1;
stack->data = buffer;
}
stack->nelems++;
memcpy(&((uint8_t *)(stack->data))[stack->nelems * stack->elem_size], data, stack->elem_size);
return 0;
}
int Stack_pop(Stack *stack, void *elem) {
if (stack->nelems == 0)
return 1;
stack->nelems--;
memcpy(elem, &((uint8_t *)(stack->data))[stack->nelems * stack->elem_size], stack->elem_size);
return 0;
}
int main(void) {
Stack *s;
typedef int t;
uint8_t data[sizeof(t)];
/* TODO segfaulting. This was not properly testd. */
/*Stack_init(s, sizeof(t), 2);*/
/*Stack_push(s, 0);*/
return EXIT_SUCCESS;
}