Mercurial > ~dholland > hg > ag > index.cgi
view help2html/array.h @ 7:57b2cc9b87f7
Use memcpy instead of strncpy when we know the length anyway.
Modern gcc seems to think it knows how to detect misuse of strncpy,
but it's wrong (in fact: very, very wrong) and the path of least
resistance is to not try to fight with it.
author | David A. Holland |
---|---|
date | Mon, 30 May 2022 23:47:52 -0400 |
parents | 13d2b8934445 |
children | 60b08b68c750 |
line wrap: on
line source
#include <assert.h> /* treat as opaque */ struct array { void **v; unsigned num, max; }; struct array *array_create(void); void array_init(struct array *a); void array_cleanup(struct array *a); void array_destroy(struct array *a); unsigned array_num(const struct array *a); void *array_get(const struct array *a, unsigned ix); void array_set(struct array *a, unsigned ix, void *ptr); unsigned array_add(struct array *a, void *ptr); void array_setsize(struct array *a, unsigned newsize); /* compact, removing any null elements */ void array_nonulls(struct array *a); /* x and y are pointers that were placed in the array */ void array_sort(struct array *a, int (*f)(void *x, void *y)); extern inline unsigned array_num(const struct array *a) { return a->num; } extern inline void *array_get(const struct array *a, unsigned ix) { assert(ix < a->num); return a->v[ix]; } extern inline void array_set(struct array *a, unsigned ix, void *ptr) { assert(ix < a->num); a->v[ix] = ptr; }