- fixing snprintf calls gone wild

This commit is contained in:
Enno Rehling 2007-12-17 23:56:53 +00:00
parent 61cf2dc85f
commit 06e15c24d5
3 changed files with 23 additions and 13 deletions

View file

@ -314,7 +314,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
if (a_otherfaction && alliedunit(u, f, HELP_FSTEALTH)) { if (a_otherfaction && alliedunit(u, f, HELP_FSTEALTH)) {
faction * f = get_otherfaction(a_otherfaction); faction * f = get_otherfaction(a_otherfaction);
bytes = snprintf(bufp, size, ", %s (%s)", factionname(f), factionname(u->faction)); bytes = snprintf(bufp, size, ", %s (%s)", factionname(f), factionname(u->faction));
if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
} else { } else {
bytes = (int)strlcpy(bufp, ", ", size); bytes = (int)strlcpy(bufp, ", ", size);
if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
@ -333,7 +333,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
} else { } else {
bytes = snprintf(bufp, size, "%d ", u->number); bytes = snprintf(bufp, size, "%d ", u->number);
} }
if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
pzTmp = get_racename(u->attribs); pzTmp = get_racename(u->attribs);
if (pzTmp) { if (pzTmp) {
@ -462,7 +462,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
if (!dh) { if (!dh) {
bytes = snprintf(bufp, size, "%s: ", LOC(f->locale, "nr_inventory")); bytes = snprintf(bufp, size, "%s: ", LOC(f->locale, "nr_inventory"));
if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
dh = 1; dh = 1;
} }
if (in == 1) { if (in == 1) {
@ -470,7 +470,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
} else { } else {
bytes = snprintf(bufp, size, "%d %s", in, ic); bytes = snprintf(bufp, size, "%d %s", in, ic);
} }
if (wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
} }
if (show!=u->items) while (show) i_free(i_remove(&show, show)); if (show!=u->items) while (show) i_free(i_remove(&show, show));
@ -481,7 +481,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
spell_list *slist = m->spells; spell_list *slist = m->spells;
int t = effskill(u, SK_MAGIC); int t = effskill(u, SK_MAGIC);
int bytes = snprintf(bufp, size, ". Aura %d/%d", get_spellpoints(u), max_spellpoints(u->region,u)); int bytes = snprintf(bufp, size, ". Aura %d/%d", get_spellpoints(u), max_spellpoints(u->region,u));
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
for (dh=0; slist; slist=slist->next) { for (dh=0; slist; slist=slist->next) {
spell * sp = slist->data; spell * sp = slist->data;
@ -492,9 +492,9 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
} else { } else {
bytes = (int)strlcpy(bufp, ", ", size); bytes = (int)strlcpy(bufp, ", ", size);
} }
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
bytes = (int)strlcpy(bufp, spell_name(sp, f->locale), size); bytes = (int)strlcpy(bufp, spell_name(sp, f->locale), size);
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
} }
for (i=0; i!=MAXCOMBATSPELLS; ++i) { for (i=0; i!=MAXCOMBATSPELLS; ++i) {
@ -502,7 +502,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
} }
if (i!=MAXCOMBATSPELLS) { if (i!=MAXCOMBATSPELLS) {
bytes = snprintf(bufp, size, ", %s: ", LOC(f->locale, "nr_combatspells")); bytes = snprintf(bufp, size, ", %s: ", LOC(f->locale, "nr_combatspells"));
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
dh = 0; dh = 0;
for (i = 0; i < MAXCOMBATSPELLS; i++){ for (i = 0; i < MAXCOMBATSPELLS; i++){
@ -525,7 +525,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode, char * buf, siz
if (sl > 0) { if (sl > 0) {
bytes = snprintf(bufp, size, " (%d)", sl); bytes = snprintf(bufp, size, " (%d)", sl);
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
} }
} else { } else {
bytes = (int)strlcpy(bufp, LOC(f->locale, "nr_nospells"), size); bytes = (int)strlcpy(bufp, LOC(f->locale, "nr_nospells"), size);
@ -1790,7 +1790,7 @@ eval_resources(struct opstack ** stack, const void * userdata) /* order -> strin
while (res!=NULL && size > 4) { while (res!=NULL && size > 4) {
const char * rname = resourcename(res->type, (res->number!=1)?NMF_PLURAL:0); const char * rname = resourcename(res->type, (res->number!=1)?NMF_PLURAL:0);
int bytes = snprintf(bufp, size, "%d %s", res->number, LOC(report->locale, rname)); int bytes = snprintf(bufp, size, "%d %s", res->number, LOC(report->locale, rname));
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
res = res->next; res = res->next;
if (res!=NULL && size>2) { if (res!=NULL && size>2) {
@ -1844,7 +1844,7 @@ eval_trail(struct opstack ** stack, const void * userdata) /* order -> string */
const faction * report = (const faction*)userdata; const faction * report = (const faction*)userdata;
int i, end = 0, begin = 0; int i, end = 0, begin = 0;
const arg_regions * regions = (const arg_regions *)opop(stack).v; const arg_regions * regions = (const arg_regions *)opop(stack).v;
static char buf[256]; static char buf[512];
size_t size = sizeof(buf) - 1; size_t size = sizeof(buf) - 1;
variant var; variant var;
char * bufp = buf; char * bufp = buf;
@ -1856,7 +1856,7 @@ eval_trail(struct opstack ** stack, const void * userdata) /* order -> string */
const char * trail = trailinto(r, report->locale); const char * trail = trailinto(r, report->locale);
const char * rn = f_regionid_s(r, report); const char * rn = f_regionid_s(r, report);
int bytes = snprintf(bufp, size, trail, rn); int bytes = snprintf(bufp, size, trail, rn);
if (bytes && wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER(); if (bytes<0 || wrptr(&bufp, &size, bytes)!=0) WARN_STATIC_BUFFER();
if (i+2<end) { if (i+2<end) {
bytes = (int)strlcpy(bufp, ", ", size); bytes = (int)strlcpy(bufp, ", ", size);

View file

@ -221,7 +221,7 @@ fwritestr(FILE * F, const char * str)
{ {
int nwrite = 0; int nwrite = 0;
fputc('\"', F); fputc('\"', F);
while (*str) { if (str) while (*str) {
int c = (int)(unsigned char)*str++; int c = (int)(unsigned char)*str++;
switch (c) { switch (c) {
case '"': case '"':

View file

@ -1,6 +1,7 @@
#include <config.h> #include <config.h>
#include <string.h> #include <string.h>
#include <errno.h> #include <errno.h>
#include <assert.h>
#ifndef HAVE_INLINE #ifndef HAVE_INLINE
#include "bsdstring.h" #include "bsdstring.h"
@ -9,6 +10,15 @@
INLINE_FUNCTION int INLINE_FUNCTION int
wrptr(char ** ptr, size_t * size, int bytes) wrptr(char ** ptr, size_t * size, int bytes)
{ {
assert(bytes>=0 || !"you're not using snprintf right, maybe?");
if (bytes==0) {
return 0;
}
if (bytes<0) {
*size = 0;
return EINVAL;
}
if (bytes<=*(int*)size) { if (bytes<=*(int*)size) {
*ptr += bytes; *ptr += bytes;
*size -= bytes; *size -= bytes;