elendige strcpy-pointer-verschieberei geht jedesmal shcief.

This commit is contained in:
Enno Rehling 2005-06-17 18:35:28 +00:00
parent 0b8c2c94ef
commit 71cbf35a72

View file

@ -2748,29 +2748,50 @@ print_stats(battle * b)
for (bf=b->factions;bf;bf=bf->next) { for (bf=b->factions;bf;bf=bf->next) {
faction * f = bf->faction; faction * f = bf->faction;
const char * loc_army = LOC(f->locale, "battle_army"); const char * loc_army = LOC(f->locale, "battle_army");
char * bufp = buf;
size_t rsize, size = sizeof(buf);
fbattlerecord(b, f, " "); fbattlerecord(b, f, " ");
slprintf(buf, sizeof(buf), "%s %d: %s", loc_army, side->index,
seematrix(f, side) slprintf(buf, size, "%s %d: %s", loc_army, side->index,
? sidename(side,false) : LOC(f->locale, "unknown_faction")); seematrix(f, side) ? sidename(side, false) : LOC(f->locale, "unknown_faction"));
fbattlerecord(b, f, buf); fbattlerecord(b, f, buf);
strcpy(buf, LOC(f->locale, "battle_opponents"));
rsize = strlcpy(buf, LOC(f->locale, "battle_opponents"), size);
if (rsize>size) rsize = size-1;
size -= rsize;
bufp += rsize;
komma = false; komma = false;
cv_foreach(s2, b->sides) { cv_foreach(s2, b->sides) {
if (enemy(s2, side)) { if (enemy(s2, side)) {
const char * abbrev = seematrix(f, s2)?sideabkz(s2, false):"-?-"; const char * abbrev = seematrix(f, s2)?sideabkz(s2, false):"-?-";
slprintf(buf, sizeof(buf), "%s%s %s %d(%s)", buf, komma++ ? "," : "", loc_army, rsize = slprintf(bufp, size, "%s%s %s %d(%s)", buf,
s2->index, abbrev); komma++ ? "," : "", loc_army, s2->index, abbrev);
if (rsize>size) rsize = size-1;
size -= rsize;
bufp += rsize;
} }
} }
cv_next(s2); cv_next(s2);
fbattlerecord(b, f, buf); fbattlerecord(b, f, buf);
strcpy(buf, LOC(f->locale, "battle_attack"));
bufp = buf;
size = sizeof(buf);
rsize = strlcpy(buf, LOC(f->locale, "battle_attack"), size);
if (rsize>size) rsize = size-1;
size -= rsize;
bufp += rsize;
komma = false; komma = false;
cv_foreach(s2, b->sides) { cv_foreach(s2, b->sides) {
if (side->enemy[s2->index] & E_ATTACKING) { if (side->enemy[s2->index] & E_ATTACKING) {
const char * abbrev = seematrix(f, s2)?sideabkz(s2, false):"-?-"; const char * abbrev = seematrix(f, s2)?sideabkz(s2, false):"-?-";
slprintf(buf, sizeof(buf), "%s%s %s %d(%s)", buf, komma++ ? "," : "", loc_army, rsize = slprintf(bufp, size, "%s%s %s %d(%s)", buf, komma++ ? "," : "", loc_army,
s2->index, abbrev); s2->index, abbrev);
if (rsize>size) rsize = size-1;
size -= rsize;
bufp += rsize;
} }
} }
cv_next(s2); cv_next(s2);