Mercurial > hg-old > index.cgi
view lwlib/lw_stringlist.c @ 348:11a95c6414b4
Added third func to instab to split resolve and emit logic
author | lost@starbug |
---|---|
date | Sat, 27 Mar 2010 22:15:07 -0600 |
parents | 80826bf2827b |
children | 33c5bc04ea67 |
line wrap: on
line source
/* lw_stringlist.c Copyright © 2010 William Astle This file is part of LWTOOLS. LWTOOLS is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see <http://www.gnu.org/licenses/>. */ #include <config.h> #include <stdlib.h> #define ___lw_stringlist_c_seen___ #include "lw_stringlist.h" #include "lw_string.h" #include "lw_alloc.h" lw_stringlist_t lw_stringlist_create(void) { return lw_alloc(sizeof(struct lw_stringlist_priv)); } void lw_stringlist_destroy(lw_stringlist_t S) { if (S) { int i; for (i = 0; i < S -> nstrings; i++) { lw_free(S -> strings[i]); } lw_free(S); } } void lw_stringlist_addstring(lw_stringlist_t S, char *str) { S -> strings = lw_realloc(S -> strings, sizeof(char *) * (S -> nstrings + 1)); S -> strings[S -> nstrings] = lw_strdup(str); S -> nstrings++; } void lw_stringlist_reset(lw_stringlist_t S) { S -> cstring = 0; } char *lw_stringlist_current(lw_stringlist_t S) { if (S -> cstring >= S -> nstrings) return NULL; return S -> strings[S -> cstring]; } char *lw_stringlist_next(lw_stringlist_t S) { S -> cstring++; return lw_stringlist_current(S); } int lw_stringlist_nstrings(lw_stringlist_t S) { return S -> nstrings; } lw_stringlist_t lw_stringlist_copy(lw_stringlist_t S) { lw_stringlist_t r; r = lw_alloc(sizeof(lw_stringlist_t)); r -> nstrings = S -> nstrings; if (S -> nstrings) { int i; r -> strings = lw_alloc(sizeof(char *) * S -> nstrings); for (i = 0; i < S -> nstrings; i++) { r -> strings[i] = lw_strdup(S -> strings[i]); } } return r; }