summaryrefslogtreecommitdiffstats
path: root/moon-abe/pbc-0.5.14/misc/darray.c
diff options
context:
space:
mode:
authorwukong <rebirthmonkey@gmail.com>2015-11-23 17:48:48 +0100
committerwukong <rebirthmonkey@gmail.com>2015-11-23 17:48:48 +0100
commitfca74d4bc3569506a6659880a89aa009dc11f552 (patch)
tree4cefd06af989608ea8ebd3bc6306889e2a1ad175 /moon-abe/pbc-0.5.14/misc/darray.c
parent840ac3ebca7af381132bf7e93c1e4c0430d6b16a (diff)
moon-abe cleanup
Change-Id: Ie1259856db03f0b9e80de3e967ec6bd1f03191b3
Diffstat (limited to 'moon-abe/pbc-0.5.14/misc/darray.c')
-rw-r--r--moon-abe/pbc-0.5.14/misc/darray.c176
1 files changed, 0 insertions, 176 deletions
diff --git a/moon-abe/pbc-0.5.14/misc/darray.c b/moon-abe/pbc-0.5.14/misc/darray.c
deleted file mode 100644
index 50b127f3..00000000
--- a/moon-abe/pbc-0.5.14/misc/darray.c
+++ /dev/null
@@ -1,176 +0,0 @@
-#include <stdlib.h>
-#include <stdio.h>
-#include <string.h>
-#include "pbc_memory.h"
-#include "darray.h"
-
-#define NDEBUG
-#include <assert.h>
-
-enum {
- max_init = 8
-};
-
-void darray_init(darray_ptr a)
-{
- a->max = max_init;
- a->count = 0;
- a->item = pbc_malloc(sizeof(void *) * a->max);
-}
-
-darray_ptr darray_new(void)
-{
- darray_ptr res = pbc_malloc(sizeof(darray_t));
- darray_init(res);
- return res;
-}
-
-void darray_remove_all(darray_ptr a)
-{
- a->max = max_init;
- a->count = 0;
- pbc_free(a->item);
- a->item = pbc_malloc(sizeof(void *) * a->max);
-}
-
-void darray_remove_last(darray_ptr a)
-{
- assert(a->count > 0);
- a->count--;
-}
-
-static void darray_realloc(darray_ptr a, int size)
-{
- a->max = size;
- a->item = pbc_realloc(a->item, sizeof(void *) * a->max);
-}
-
-void darray_append(darray_ptr a, void *p)
-{
- if (a->count == a->max) {
- if (!a->max) a->max = max_init;
- else a->max *= 2;
- a->item = pbc_realloc(a->item, sizeof(void *) * a->max);
- }
- a->item[a->count] = p;
- a->count++;
-}
-
-int darray_index_of(darray_ptr a, void *p)
-{
- int i;
- for (i=0; i<a->count; i++) {
- if (a->item[i] == p) return i;
- }
- return -1;
-}
-
-void darray_clear(darray_t a)
-{
- pbc_free(a->item);
- a->max = 0;
- a->count = 0;
-}
-
-void darray_free(darray_ptr a) {
- darray_clear(a);
- pbc_free(a);
-}
-
-void darray_remove_index(darray_ptr a, int n)
-{
- assert(a->count >= n-1);
- a->count--;
- memmove(&a->item[n], &a->item[n+1], sizeof(void *) * (a->count - n));
-}
-
-void darray_remove(darray_ptr a, void *p)
-{
- int i;
- for (i=0; i<a->count; i++) {
- if (a->item[i] == p) {
- a->count--;
- memmove(&a->item[i], &a->item[i+1], sizeof(void *) * (a->count - i));
- return;
- }
- }
- assert(0);
-}
-
-void darray_remove_with_test(darray_ptr a, int (*test)(void *))
-{
- int i;
- for (i=0; i<a->count; i++) {
- if (test(a->item[i])) {
- for (;i<a->count; i++) {
- a->item[i] = a->item[i+1];
- }
- a->count--;
- }
- }
-}
-
-void darray_copy(darray_ptr dst, darray_ptr src)
-{
- darray_realloc(dst, src->count);
- memcpy(dst->item, src->item, src->count * sizeof(void *));
- dst->count = src->count;
-}
-
-void darray_forall(darray_t a, void (*func)(void *))
-{
- int i, n = a->count;
- for (i=0; i<n; i++) {
- func(a->item[i]);
- }
-}
-
-void darray_forall2(darray_t a,
- void (*func)(void *darray_item, void *scope_ptr),
- void *scope_ptr)
-{
- int i, n = a->count;
- for (i=0; i<n; i++) {
- func(a->item[i], scope_ptr);
- }
-}
-
-void darray_forall3(darray_t a,
- void (*func)(void *darray_item,
- void *scope_ptr1,
- void *scope_ptr2),
- void *scope_ptr1,
- void *scope_ptr2)
-{
- int i, n = a->count;
- for (i=0; i<n; i++) {
- func(a->item[i], scope_ptr1, scope_ptr2);
- }
-}
-
-void darray_forall4(darray_t a,
- void (*func)(void *darray_item,
- void *scope_ptr1,
- void *scope_ptr2,
- void *scope_ptr3),
- void *scope_ptr1,
- void *scope_ptr2,
- void *scope_ptr3)
-{
- int i, n = a->count;
- for (i=0; i<n; i++) {
- func(a->item[i], scope_ptr1, scope_ptr2, scope_ptr3);
- }
-}
-
-void *darray_at_test(darray_ptr a,
- int (*test)(void *data, void *scope_ptr),
- void *scope_ptr)
-{
- int i;
- for (i = 0; i < a->count; i++) {
- void *p = a->item[i];
- if (test(p, scope_ptr)) return p;
- }
- return NULL;
-}