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;
}