forked from github/server
- fixing snprintf calls gone wild
This commit is contained in:
parent
61cf2dc85f
commit
06e15c24d5
3 changed files with 23 additions and 13 deletions
|
@ -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);
|
||||||
|
|
|
@ -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 '"':
|
||||||
|
|
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue