Mercurial > hg > Gears > GearsAgda
view src/parallel_execution/stack.c @ 118:32773f506410
remove code stack, add continuation of rotateL/totateR
author | ikkun |
---|---|
date | Mon, 26 Sep 2016 19:54:24 +0900 |
parents | f57e9ffa7960 |
children | 2bb5e4f0fd35 |
line wrap: on
line source
#include <string.h> #include "stack.h" stack_ptr stack_init(size_t size, int max) { stack_ptr p; if ((p = calloc(1, sizeof(stack))) == NULL) return NULL; if ((p->data = calloc(max, size)) == NULL) { free(p); return NULL; } p->size = size; p->max = max; p->num = 0; return p; } stack_ptr stack_realloc(stack_ptr p, int max) { if (p == NULL) return NULL; if ((p->data = realloc(p->data, p->size*max)) == NULL) return NULL; p->max = max; return p; } void stack_free(stack_ptr p) { if (p != NULL && p->data != NULL) { free(p->data); free(p); } } int stack_push(stack_ptr p, void* data) { if (p->max <= p->num) return -1; memcpy((char*)p->data+p->num*p->size, data, p->size); p->num++; return 0; } int stack_pop(stack_ptr p, void* data) { if (p->num == 0) return -1; p->num--; memcpy(data, (char*)p->data+p->num*p->size, p->size); return 0; } int isMax(const stack_ptr p) { return p->max<=p->num; } int isEmpty(const stack_ptr p) { return p->num<=0; }