Mercurial > hg > index.cgi
view lwlib/lw_stringlist.c @ 426:b4825b42c151
Change to engage forwardrefmax pragma by default
There are enough cases where the forward reference optimization scheme in
lwasm makes assembly painfully slow that it warrants enabling this pragma by
default to avoid bug reports about lwasm being too slow. Which is is when
you have a lot of forward refences or other instruction sizes that don't
reduce on pass one. This gets worse exponentially as the source file size
gets bigger.
The old behaviour is available to anyone who needs or wants it, though. It
does work quite well on smallish files or files that do not have a lot of
abiguous instruction sizes.
It should be noted that this change does not change the correctness of the
code output by lwasm. What it might do is result in slightly larger code if
the assembler is forced to select a 16 bit mode when an 8 bit mode will do.
However, in most cases I've seen, it makes very little difference overall.
author | William Astle <lost@l-w.ca> |
---|---|
date | Thu, 03 Nov 2016 21:44:32 -0600 |
parents | a1a88a8ddc98 |
children |
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 <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) { lw_stringlist_t s; s = lw_alloc(sizeof(struct lw_stringlist_priv)); s -> strings = NULL; s -> nstrings = 0; s -> cstring = 0; return s; } 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 -> strings); 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; }