2004-07-16 19:16:42 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
|
#include <config.h>
|
|
|
|
|
#endif
|
|
|
|
|
|
2004-06-19 01:01:09 +00:00
|
|
|
#include <string.h>
|
|
|
|
|
#include <assert.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
#include "dynarray.h"
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
struct pa_dynarray {
|
2004-06-19 01:01:09 +00:00
|
|
|
void **data;
|
|
|
|
|
unsigned n_allocated, n_entries;
|
|
|
|
|
};
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
struct pa_dynarray* pa_dynarray_new(void) {
|
|
|
|
|
struct pa_dynarray *a;
|
|
|
|
|
a = malloc(sizeof(struct pa_dynarray));
|
2004-06-19 01:01:09 +00:00
|
|
|
assert(a);
|
|
|
|
|
a->data = NULL;
|
|
|
|
|
a->n_entries = 0;
|
|
|
|
|
a->n_allocated = 0;
|
|
|
|
|
return a;
|
|
|
|
|
}
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
void pa_dynarray_free(struct pa_dynarray* a, void (*func)(void *p, void *userdata), void *userdata) {
|
2004-06-19 01:01:09 +00:00
|
|
|
unsigned i;
|
|
|
|
|
assert(a);
|
|
|
|
|
|
|
|
|
|
if (func)
|
|
|
|
|
for (i = 0; i < a->n_entries; i++)
|
|
|
|
|
if (a->data[i])
|
|
|
|
|
func(a->data[i], userdata);
|
|
|
|
|
|
|
|
|
|
free(a->data);
|
|
|
|
|
free(a);
|
|
|
|
|
}
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
void pa_dynarray_put(struct pa_dynarray*a, unsigned i, void *p) {
|
2004-06-19 01:01:09 +00:00
|
|
|
assert(a);
|
|
|
|
|
|
|
|
|
|
if (i >= a->n_allocated) {
|
|
|
|
|
unsigned n;
|
|
|
|
|
|
|
|
|
|
if (!p)
|
|
|
|
|
return;
|
|
|
|
|
|
|
|
|
|
n = i+100;
|
|
|
|
|
a->data = realloc(a->data, sizeof(void*)*n);
|
|
|
|
|
memset(a->data+a->n_allocated, 0, sizeof(void*)*(n-a->n_allocated));
|
|
|
|
|
a->n_allocated = n;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
a->data[i] = p;
|
|
|
|
|
|
|
|
|
|
if (i >= a->n_entries)
|
|
|
|
|
a->n_entries = i+1;
|
|
|
|
|
}
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
unsigned pa_dynarray_append(struct pa_dynarray*a, void *p) {
|
2004-06-19 01:01:09 +00:00
|
|
|
unsigned i = a->n_entries;
|
2004-07-03 23:35:12 +00:00
|
|
|
pa_dynarray_put(a, i, p);
|
2004-06-19 01:01:09 +00:00
|
|
|
return i;
|
|
|
|
|
}
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
void *pa_dynarray_get(struct pa_dynarray*a, unsigned i) {
|
2004-06-19 01:01:09 +00:00
|
|
|
assert(a);
|
|
|
|
|
if (i >= a->n_allocated)
|
|
|
|
|
return NULL;
|
|
|
|
|
assert(a->data);
|
|
|
|
|
return a->data[i];
|
|
|
|
|
}
|
|
|
|
|
|
2004-07-03 23:35:12 +00:00
|
|
|
unsigned pa_dynarray_ncontents(struct pa_dynarray*a) {
|
2004-06-19 01:01:09 +00:00
|
|
|
assert(a);
|
|
|
|
|
return a->n_entries;
|
|
|
|
|
}
|