Merge pull request #390 from ennorehling/develop

latest batch of coverity scan fixes
This commit is contained in:
Enno Rehling 2015-11-11 16:19:03 +01:00
commit 385a5dbe3a
5 changed files with 35 additions and 29 deletions

View file

@ -1391,6 +1391,7 @@ int readgame(const char *filename, bool backup)
storage store; storage store;
stream strm; stream strm;
FILE *F; FILE *F;
size_t sz;
init_locales(); init_locales();
log_debug("- reading game data from %s\n", filename); log_debug("- reading game data from %s\n", filename);
@ -1405,8 +1406,8 @@ int readgame(const char *filename, bool backup)
perror(path); perror(path);
return -1; return -1;
} }
fread(&gdata.version, sizeof(int), 1, F); sz = fread(&gdata.version, sizeof(int), 1, F);
if (gdata.version >= INTPAK_VERSION) { if (sz!=sizeof(int) || gdata.version >= INTPAK_VERSION) {
int stream_version; int stream_version;
size_t sz = fread(&stream_version, sizeof(int), 1, F); size_t sz = fread(&stream_version, sizeof(int), 1, F);
assert((sz==1 && stream_version == STREAM_VERSION) || !"unsupported data format"); assert((sz==1 && stream_version == STREAM_VERSION) || !"unsupported data format");

View file

@ -208,6 +208,7 @@ newfaction *read_newfactions(const char *filename)
nf = calloc(sizeof(newfaction), 1); nf = calloc(sizeof(newfaction), 1);
if (set_email(&nf->email, email) != 0) { if (set_email(&nf->email, email) != 0) {
log_error("Invalid email address for subscription %s: %s\n", itoa36(subscription), email); log_error("Invalid email address for subscription %s: %s\n", itoa36(subscription), email);
free(nf);
continue; continue;
} }
nf->password = _strdup(password); nf->password = _strdup(password);

View file

@ -2189,7 +2189,7 @@ static const region_list *travel_i(unit * u, const region_list * route_begin,
static void travel(unit * u, region_list ** routep) static void travel(unit * u, region_list ** routep)
{ {
region *r = u->region; region *r = u->region;
region_list *route_begin = NULL; region_list *route_begin;
follower *followers = NULL; follower *followers = NULL;
assert(routep); assert(routep);
@ -2232,36 +2232,37 @@ static void travel(unit * u, region_list ** routep)
make_route(u, u->thisorder, routep); make_route(u, u->thisorder, routep);
route_begin = *routep; route_begin = *routep;
/* und ab die post: */ if (route_begin) {
travel_i(u, route_begin, NULL, u->thisorder, TRAVEL_NORMAL, &followers); /* und ab die post: */
travel_i(u, route_begin, NULL, u->thisorder, TRAVEL_NORMAL, &followers);
/* followers */ /* followers */
while (followers != NULL) { while (followers != NULL) {
follower *fnext = followers->next; follower *fnext = followers->next;
unit *uf = followers->uf; unit *uf = followers->uf;
unit *ut = followers->ut; unit *ut = followers->ut;
const region_list *route_end = followers->route_end; const region_list *route_end = followers->route_end;
free(followers); free(followers);
followers = fnext; followers = fnext;
if (uf->region == r) { if (uf->region == r) {
order *follow_order; order *follow_order;
const struct locale *lang = u->faction->locale; const struct locale *lang = u->faction->locale;
const char *s = LOC(uf->faction->locale, parameters[P_UNIT]); const char *s = LOC(uf->faction->locale, parameters[P_UNIT]);
/* construct an order */ /* construct an order */
assert(s || !"missing translation for UNIT keyword"); assert(s || !"missing translation for UNIT keyword");
follow_order = create_order(K_FOLLOW, lang, "%s %i", follow_order = create_order(K_FOLLOW, lang, "%s %i",
s, ut->no); s, ut->no);
route_end = reroute(uf, route_begin, route_end); route_end = reroute(uf, route_begin, route_end);
travel_i(uf, route_begin, route_end, follow_order, TRAVEL_FOLLOWING, travel_i(uf, route_begin, route_end, follow_order, TRAVEL_FOLLOWING,
&followers); &followers);
caught_target(uf->region, uf); caught_target(uf->region, uf);
free_order(follow_order); free_order(follow_order);
}
} }
} }
} }
void move_cmd(unit * u, bool move_on_land) void move_cmd(unit * u, bool move_on_land)

View file

@ -1033,7 +1033,7 @@ int sp_chaosrow(struct castorder * co)
if (u_race(df->unit)->battle_flags & BF_NOBLOCK) { if (u_race(df->unit)->battle_flags & BF_NOBLOCK) {
df->side->nonblockers[row] -= df->alive; df->side->nonblockers[row] -= df->alive;
} }
row = FIRST_ROW + (rng_int() % (LAST_ROW - FIRST_ROW)); row = FIRST_ROW + (rng_int() % (NUMROWS - FIRST_ROW));
switch (row) { switch (row) {
case FIGHT_ROW: case FIGHT_ROW:
df->status = ST_FIGHT; df->status = ST_FIGHT;

View file

@ -374,7 +374,10 @@ summary *make_summary(void)
s->factions++; s->factions++;
/* Problem mit Monsterpartei ... */ /* Problem mit Monsterpartei ... */
if (!is_monsters(f)) { if (!is_monsters(f)) {
s->factionrace[old_race(f->race)]++; int rc = old_race(f->race);
if (rc >= 0) {
s->factionrace[rc]++;
}
} }
} }
} }