80 lines
1.4 KiB
C
80 lines
1.4 KiB
C
|
#include "vstack.h"
|
||
|
|
||
|
#include <stdlib.h>
|
||
|
#include <assert.h>
|
||
|
|
||
|
//#define DEBUG
|
||
|
#include "debug.h"
|
||
|
|
||
|
struct __vstack_t
|
||
|
{
|
||
|
uint32 pointer;
|
||
|
uint32 *values;
|
||
|
uint32 capacity;
|
||
|
};
|
||
|
|
||
|
vstack_t *vstack_new()
|
||
|
{
|
||
|
vstack_t *stack = (vstack_t *)malloc(sizeof(vstack_t));
|
||
|
assert(stack);
|
||
|
stack->pointer = 0;
|
||
|
stack->values = NULL;
|
||
|
stack->capacity = 0;
|
||
|
return stack;
|
||
|
}
|
||
|
|
||
|
void vstack_destroy(vstack_t *stack)
|
||
|
{
|
||
|
assert(stack);
|
||
|
free(stack->values);
|
||
|
free(stack);
|
||
|
}
|
||
|
|
||
|
void vstack_push(vstack_t *stack, uint32 val)
|
||
|
{
|
||
|
assert(stack);
|
||
|
vstack_reserve(stack, stack->pointer + 1);
|
||
|
stack->values[stack->pointer] = val;
|
||
|
++(stack->pointer);
|
||
|
}
|
||
|
void vstack_pop(vstack_t *stack)
|
||
|
{
|
||
|
assert(stack);
|
||
|
assert(stack->pointer > 0);
|
||
|
--(stack->pointer);
|
||
|
}
|
||
|
|
||
|
uint32 vstack_top(vstack_t *stack)
|
||
|
{
|
||
|
assert(stack);
|
||
|
assert(stack->pointer > 0);
|
||
|
return stack->values[(stack->pointer - 1)];
|
||
|
}
|
||
|
int vstack_empty(vstack_t *stack)
|
||
|
{
|
||
|
assert(stack);
|
||
|
return stack->pointer == 0;
|
||
|
}
|
||
|
uint32 vstack_size(vstack_t *stack)
|
||
|
{
|
||
|
return stack->pointer;
|
||
|
}
|
||
|
void vstack_reserve(vstack_t *stack, uint32 size)
|
||
|
{
|
||
|
assert(stack);
|
||
|
if (stack->capacity < size)
|
||
|
{
|
||
|
uint32 new_capacity = stack->capacity + 1;
|
||
|
DEBUGP("Increasing current capacity %u to %u\n", stack->capacity, size);
|
||
|
while (new_capacity < size)
|
||
|
{
|
||
|
new_capacity *= 2;
|
||
|
}
|
||
|
stack->values = (uint32 *)realloc(stack->values, sizeof(uint32)*new_capacity);
|
||
|
assert(stack->values);
|
||
|
stack->capacity = new_capacity;
|
||
|
DEBUGP("Increased\n");
|
||
|
}
|
||
|
}
|
||
|
|