forked from krakjoe/apcu
-
Notifications
You must be signed in to change notification settings - Fork 0
/
apc_stack.c
106 lines (88 loc) · 3.09 KB
/
apc_stack.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
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
/*
+----------------------------------------------------------------------+
| APC |
+----------------------------------------------------------------------+
| Copyright (c) 2006-2011 The PHP Group |
+----------------------------------------------------------------------+
| This source file is subject to version 3.01 of the PHP license, |
| that is bundled with this package in the file LICENSE, and is |
| available through the world-wide-web at the following url: |
| http://www.php.net/license/3_01.txt |
| If you did not receive a copy of the PHP license and are unable to |
| obtain it through the world-wide-web, please send a note to |
| [email protected] so we can mail you a copy immediately. |
+----------------------------------------------------------------------+
| Authors: Daniel Cowgill <[email protected]> |
+----------------------------------------------------------------------+
This software was contributed to PHP by Community Connect Inc. in 2002
and revised in 2005 by Yahoo! Inc. to add support for PHP 5.1.
Future revisions and derivatives of this source code must acknowledge
Community Connect Inc. as the original contributor of this module by
leaving this note intact in the source code.
All other licensing and usage conditions are those of the PHP Group.
*/
/* $Id: apc_stack.c 307048 2011-01-03 23:53:17Z kalle $ */
#include "apc.h"
#include "apc_stack.h"
struct apc_stack_t {
void** data;
int capacity;
int size;
};
apc_stack_t* apc_stack_create(int size_hint)
{
apc_stack_t* stack = (apc_stack_t*) apc_emalloc(sizeof(apc_stack_t));
stack->capacity = (size_hint > 0) ? size_hint : 10;
stack->size = 0;
stack->data = (void**) apc_emalloc(sizeof(void*) * stack->capacity);
return stack;
}
void apc_stack_destroy(apc_stack_t* stack)
{
if (stack != NULL) {
apc_efree(stack->data);
apc_efree(stack);
}
}
void apc_stack_clear(apc_stack_t* stack)
{
assert(stack != NULL);
stack->size = 0;
}
void apc_stack_push(apc_stack_t* stack, void* item)
{
assert(stack != NULL);
if (stack->size == stack->capacity) {
stack->capacity *= 2;
stack->data = apc_erealloc(stack->data, sizeof(void*)*stack->capacity);
}
stack->data[stack->size++] = item;
}
void* apc_stack_pop(apc_stack_t* stack)
{
assert(stack != NULL && stack->size > 0);
return stack->data[--stack->size];
}
void* apc_stack_top(apc_stack_t* stack)
{
assert(stack != NULL && stack->size > 0);
return stack->data[stack->size-1];
}
void* apc_stack_get(apc_stack_t* stack, int n)
{
assert(stack != NULL && stack->size > n);
return stack->data[n];
}
int apc_stack_size(apc_stack_t* stack)
{
assert(stack != NULL);
return stack->size;
}
/*
* Local variables:
* tab-width: 4
* c-basic-offset: 4
* End:
* vim>600: expandtab sw=4 ts=4 sts=4 fdm=marker
* vim<600: expandtab sw=4 ts=4 sts=4
*/