| /* |
| parray.c -- create / free array of pointers |
| Copyright (C) 2005-2014 Dieter Baron and Thomas Klausner |
| |
| This file is part of ckmame, a program to check rom sets for MAME. |
| The authors can be contacted at <ckmame@nih.at> |
| |
| Redistribution and use in source and binary forms, with or without |
| modification, are permitted provided that the following conditions |
| are met: |
| 1. Redistributions of source code must retain the above copyright |
| notice, this list of conditions and the following disclaimer. |
| 2. Redistributions in binary form must reproduce the above copyright |
| notice, this list of conditions and the following disclaimer in |
| the documentation and/or other materials provided with the |
| distribution. |
| 3. The name of the author may not be used to endorse or promote |
| products derived from this software without specific prior |
| written permission. |
| |
| THIS SOFTWARE IS PROVIDED BY THE AUTHORS ``AS IS'' AND ANY EXPRESS |
| OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED |
| WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE |
| ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY |
| DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
| DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE |
| GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS |
| INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER |
| IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR |
| OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN |
| IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| */ |
| |
| #include <stdlib.h> |
| |
| #include "parray.h" |
| |
| void |
| parray_free(parray_t *pa, void (*fn)(void *)) |
| { |
| int i; |
| |
| if (pa == NULL) |
| return; |
| |
| if (fn) { |
| for (i=0; i<parray_length(pa); i++) |
| fn(parray_get(pa, i)); |
| } |
| |
| free(pa->entry); |
| free(pa); |
| } |
| |
| parray_t * |
| parray_new_sized(int n) |
| { |
| parray_t *pa; |
| |
| if (n<0) |
| n = 0; |
| |
| if ((pa=malloc(sizeof(*pa))) == NULL) |
| exit(1); |
| |
| if (n == 0) |
| pa->entry = 0; |
| else { |
| if ((pa->entry=malloc(n*sizeof(pa->entry[0]))) == NULL) |
| exit(1); |
| } |
| pa->nentry = 0; |
| pa->alloc_len = n; |
| |
| return pa; |
| } |