summaryrefslogtreecommitdiff
path: root/Zend/zend_dynamic_array.c
diff options
context:
space:
mode:
authorAndi Gutmans <andi@php.net>2000-02-18 00:14:23 +0000
committerAndi Gutmans <andi@php.net>2000-02-18 00:14:23 +0000
commit18b8440c95eceda0361ac5a7638d922f3d675981 (patch)
tree595ebc600e9a1201dfecad94121874717f6c56d7 /Zend/zend_dynamic_array.c
parent8f6a42f11bd6b9b261d301c8697902bf83d3d543 (diff)
downloadphp-git-18b8440c95eceda0361ac5a7638d922f3d675981.tar.gz
- Preliminary support for dynamic arrays. I need it on order to try out a
new hash implementation. It isn't used anywhere.
Diffstat (limited to 'Zend/zend_dynamic_array.c')
-rw-r--r--Zend/zend_dynamic_array.c62
1 files changed, 62 insertions, 0 deletions
diff --git a/Zend/zend_dynamic_array.c b/Zend/zend_dynamic_array.c
new file mode 100644
index 0000000000..8f638c54f0
--- /dev/null
+++ b/Zend/zend_dynamic_array.c
@@ -0,0 +1,62 @@
+/*
+ +----------------------------------------------------------------------+
+ | Zend Engine |
+ +----------------------------------------------------------------------+
+ | Copyright (c) 1998, 1999 Andi Gutmans, Zeev Suraski |
+ +----------------------------------------------------------------------+
+ | This source file is subject to version 0.91 of the Zend license, |
+ | that is bundled with this package in the file LICENSE, and is |
+ | available at through the world-wide-web at |
+ | http://www.zend.com/license/0_91.txt. |
+ | If you did not receive a copy of the Zend license and are unable to |
+ | obtain it through the world-wide-web, please send a note to |
+ | license@zend.com so we can mail you a copy immediately. |
+ +----------------------------------------------------------------------+
+ | Authors: Andi Gutmans <andi@zend.com> |
+ | Zeev Suraski <zeev@zend.com> |
+ +----------------------------------------------------------------------+
+*/
+
+#include "zend.h"
+
+typedef struct _dynamic_array {
+ char *array;
+ unsigned int element_size;
+ unsigned int current;
+ unsigned int allocated;
+} dynamic_array;
+
+ZEND_API int zend_dynamic_array_init(dynamic_array *da, unsigned int element_size, unsigned int size)
+{
+ da->element_size = element_size;
+ da->allocated = size;
+ da->current = 0;
+ da->array = (char *) emalloc(size*element_size);
+ if (da->array == NULL) {
+ return 1;
+ }
+ return 0;
+}
+
+ZEND_API void *zend_dynamic_array_push(dynamic_array *da)
+{
+ if (da->current == da->allocated) {
+ da->allocated *= 2;
+ da->array = (char *) erealloc(da->array, da->allocated*da->element_size);
+ }
+ return (da->array+(da->current++)*da->element_size);
+}
+
+ZEND_API void *zend_dynamic_array_pop(dynamic_array *da)
+{
+ return (da->array+(--(da->current))*da->element_size);
+
+}
+
+ZEND_API void *zend_dynamic_array_get_element(dynamic_array *da, unsigned int index)
+{
+ if (index >= da->current) {
+ return NULL;
+ }
+ return (da->array+index*da->element_size);
+}