Merge branch 'coverity-scan' of https://github.com/ennorehling/eressea into ennorehling-coverity-scan

Conflicts:
	src/kernel/jsonconf.c
	src/kernel/save.h
	src/names.c
This commit is contained in:
Enno Rehling 2015-11-04 12:44:45 +01:00
commit 8ab4784e3f
6 changed files with 66 additions and 62 deletions

View file

@ -3247,7 +3247,6 @@ fighter *make_fighter(battle * b, unit * u, side * s1, bool attack)
int berserk; int berserk;
int strongmen; int strongmen;
int speeded = 0, speed = 1; int speeded = 0, speed = 1;
bool pr_aid = false;
int rest; int rest;
const group *g = NULL; const group *g = NULL;
const attrib *a = a_find(u->attribs, &at_otherfaction); const attrib *a = a_find(u->attribs, &at_otherfaction);
@ -3348,14 +3347,6 @@ fighter *make_fighter(battle * b, unit * u, side * s1, bool attack)
if (i < berserk) { if (i < berserk) {
fig->person[i].attack++; fig->person[i].attack++;
} }
/* Leute mit einem Aid-Prayer bekommen +1 auf fast alles. */
if (pr_aid) {
fig->person[i].attack++;
fig->person[i].defence++;
fig->person[i].damage++;
fig->person[i].damage_rear++;
fig->person[i].flags |= FL_COURAGE;
}
/* Leute mit Kraftzauber machen +2 Schaden im Nahkampf. */ /* Leute mit Kraftzauber machen +2 Schaden im Nahkampf. */
if (i < strongmen) { if (i < strongmen) {
fig->person[i].damage += 2; fig->person[i].damage += 2;
@ -3631,18 +3622,22 @@ battle *make_battle(region * r)
char zText[MAX_PATH]; char zText[MAX_PATH];
char zFilename[MAX_PATH]; char zFilename[MAX_PATH];
sprintf(zText, "%s/battles", basepath()); sprintf(zText, "%s/battles", basepath());
_mkdir(zText); if (_mkdir(zText) != 0) {
sprintf(zFilename, "%s/battle-%d-%s.log", zText, obs_count, simplename(r)); log_error("could not create subdirectory for battle logs: %s", zText);
battledebug = false;
}
else {
sprintf(zFilename, "%s/battle-%d-%s.log", zText, obs_count++, simplename(r));
bdebug = fopen(zFilename, "w"); bdebug = fopen(zFilename, "w");
if (!bdebug) if (!bdebug)
log_error("battles cannot be debugged\n"); log_error("battles cannot be debugged");
else { else {
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 }; const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
fwrite(utf8_bom, 1, 3, bdebug); fwrite(utf8_bom, 1, 3, bdebug);
fprintf(bdebug, "In %s findet ein Kampf statt:\n", rname(r, fprintf(bdebug, "In %s findet ein Kampf statt:\n", rname(r,
default_locale)); default_locale));
} }
obs_count++; }
} }
b->region = r; b->region = r;
@ -4259,10 +4254,11 @@ static bool is_enemy(battle *b, unit *u1, unit *u2) {
for (es = b->sides; es != b->sides + b->nsides; ++es) { for (es = b->sides; es != b->sides + b->nsides; ++es) {
if (!s1 && es->faction == u1->faction) s1 = es; if (!s1 && es->faction == u1->faction) s1 = es;
else if (!s2 && es->faction == u2->faction) s2 = es; else if (!s2 && es->faction == u2->faction) s2 = es;
if (s1 && s2) break; if (s1 && s2) {
}
return enemy(s1, s2); return enemy(s1, s2);
} }
}
}
else { else {
return !help_enter(u1, u2); return !help_enter(u1, u2);
} }

View file

@ -237,11 +237,15 @@ static int tolua_message_unit(lua_State * L)
unit *sender = (unit *)tolua_tousertype(L, 1, 0); unit *sender = (unit *)tolua_tousertype(L, 1, 0);
unit *target = (unit *)tolua_tousertype(L, 2, 0); unit *target = (unit *)tolua_tousertype(L, 2, 0);
const char *str = tolua_tostring(L, 3, 0); const char *str = tolua_tostring(L, 3, 0);
if (!target) if (!target) {
tolua_error(L, TOLUA_CAST "target is nil", NULL); tolua_error(L, TOLUA_CAST "target is nil", NULL);
if (!sender) }
else if (!sender) {
tolua_error(L, TOLUA_CAST "sender is nil", NULL); tolua_error(L, TOLUA_CAST "sender is nil", NULL);
}
else {
deliverMail(target->faction, sender->region, sender, str, target); deliverMail(target->faction, sender->region, sender, str, target);
}
return 0; return 0;
} }
@ -266,10 +270,13 @@ static int tolua_message_region(lua_State * L)
{ {
unit *sender = (unit *)tolua_tousertype(L, 1, 0); unit *sender = (unit *)tolua_tousertype(L, 1, 0);
const char *str = tolua_tostring(L, 2, 0); const char *str = tolua_tostring(L, 2, 0);
if (!sender) if (!sender) {
tolua_error(L, TOLUA_CAST "sender is nil", NULL); tolua_error(L, TOLUA_CAST "sender is nil", NULL);
}
else {
ADDMSG(&sender->region->msgs, msg_message("mail_result", "unit message", ADDMSG(&sender->region->msgs, msg_message("mail_result", "unit message",
sender, str)); sender, str));
}
return 0; return 0;
} }

View file

@ -833,16 +833,18 @@ static void json_include(cJSON *json) {
F = fopen(child->valuestring, "rt"); F = fopen(child->valuestring, "rt");
} }
if (F) { if (F) {
long pos;
fseek(F, 0, SEEK_END);
pos = ftell(F);
rewind(F);
if (pos > 0) {
cJSON *config; cJSON *config;
char *data; char *data;
size_t sz; size_t sz;
fseek(F, 0, SEEK_END);
sz = ftell(F); data = malloc(pos + 1);
rewind(F); sz = fread(data, 1, (size_t)pos, F);
data = malloc(sz+1);
sz = fread(data, 1, sz, F);
data[sz] = 0; data[sz] = 0;
fclose(F);
config = cJSON_Parse(data); config = cJSON_Parse(data);
free(data); free(data);
if (config) { if (config) {
@ -853,6 +855,8 @@ static void json_include(cJSON *json) {
log_error("invalid JSON, could not parse %s", child->valuestring); log_error("invalid JSON, could not parse %s", child->valuestring);
} }
} }
fclose(F);
}
} }
} }

View file

@ -553,8 +553,11 @@ int current_turn(void)
perror(zText); perror(zText);
} }
else { else {
fscanf(F, "%d\n", &cturn); int c = fscanf(F, "%d\n", &cturn);
fclose(F); fclose(F);
if (c != 1) {
return -1;
}
} }
return cturn; return cturn;
} }
@ -1405,8 +1408,8 @@ int readgame(const char *filename, bool backup)
fread(&gdata.version, sizeof(int), 1, F); fread(&gdata.version, sizeof(int), 1, F);
if (gdata.version >= INTPAK_VERSION) { if (gdata.version >= INTPAK_VERSION) {
int stream_version; int stream_version;
fread(&stream_version, sizeof(int), 1, F); size_t sz = fread(&stream_version, sizeof(int), 1, F);
assert(stream_version == STREAM_VERSION || !"unsupported data format"); assert((sz==1 && stream_version == STREAM_VERSION) || !"unsupported data format");
} }
assert(gdata.version >= MIN_VERSION || !"unsupported data format"); assert(gdata.version >= MIN_VERSION || !"unsupported data format");
assert(gdata.version <= MAX_VERSION || !"unsupported data format"); assert(gdata.version <= MAX_VERSION || !"unsupported data format");

View file

@ -4525,7 +4525,7 @@ void update_subscriptions(void)
int subscription, fno; int subscription, fno;
faction *f; faction *f;
if (fscanf(F, "%d %s", &subscription, zFaction) <= 0) if (fscanf(F, "%d %4s", &subscription, zFaction) <= 0)
break; break;
fno = atoi36(zFaction); fno = atoi36(zFaction);
f = findfaction(fno); f = findfaction(fno);

View file

@ -1848,18 +1848,16 @@ const faction * f)
{ {
int i, bytes; int i, bytes;
const char *name, *bname, *billusion = NULL; const char *name, *bname, *billusion = NULL;
const struct locale *lang = NULL; const struct locale *lang;
char buffer[8192], *bufp = buffer; char buffer[8192], *bufp = buffer;
message *msg; message *msg;
size_t size = sizeof(buffer) - 1; size_t size = sizeof(buffer) - 1;
newline(out); assert(f);
if (f)
lang = f->locale; lang = f->locale;
newline(out);
bytes = bytes =
_snprintf(bufp, size, "%s, %s %d, ", buildingname(b), LOC(f->locale, _snprintf(bufp, size, "%s, %s %d, ", buildingname(b), LOC(lang,
"nr_size"), b->size); "nr_size"), b->size);
if (wrptr(&bufp, &size, bytes) != 0) if (wrptr(&bufp, &size, bytes) != 0)
WARN_STATIC_BUFFER(); WARN_STATIC_BUFFER();
@ -1881,7 +1879,7 @@ const faction * f)
} }
if (b->size < b->type->maxsize) { if (b->size < b->type->maxsize) {
bytes = (int)strlcpy(bufp, LOC(f->locale, "nr_building_inprogress"), size); bytes = (int)strlcpy(bufp, LOC(lang, "nr_building_inprogress"), size);
if (wrptr(&bufp, &size, bytes) != 0) if (wrptr(&bufp, &size, bytes) != 0)
WARN_STATIC_BUFFER(); WARN_STATIC_BUFFER();
} }
@ -1889,7 +1887,7 @@ const faction * f)
if (b->besieged > 0 && sr->mode >= see_lighthouse) { if (b->besieged > 0 && sr->mode >= see_lighthouse) {
msg = msg_message("nr_building_besieged", "soldiers diff", b->besieged, msg = msg_message("nr_building_besieged", "soldiers diff", b->besieged,
b->besieged - b->size * SIEGEFACTOR); b->besieged - b->size * SIEGEFACTOR);
bytes = (int)nr_render(msg, f->locale, bufp, size, f); bytes = (int)nr_render(msg, lang, bufp, size, f);
if (wrptr(&bufp, &size, bytes) != 0) if (wrptr(&bufp, &size, bytes) != 0)
WARN_STATIC_BUFFER(); WARN_STATIC_BUFFER();
msg_release(msg); msg_release(msg);
@ -1926,6 +1924,7 @@ static void nr_paragraph(stream *out, message * m, faction * f)
char buf[4096], *bufp = buf; char buf[4096], *bufp = buf;
size_t size = sizeof(buf) - 1; size_t size = sizeof(buf) - 1;
assert(f);
bytes = (int)nr_render(m, f->locale, bufp, size, f); bytes = (int)nr_render(m, f->locale, bufp, size, f);
if (wrptr(&bufp, &size, bytes) != 0) if (wrptr(&bufp, &size, bytes) != 0)
WARN_STATIC_BUFFER(); WARN_STATIC_BUFFER();
@ -2331,7 +2330,7 @@ const char *charset)
message *m = 0; message *m = 0;
if (herb && lux) { if (herb && lux) {
m = msg_message("nr_market_info_p", "p1 p2", m = msg_message("nr_market_info_p", "p1 p2",
lux ? lux->rtype : 0, herb ? herb->rtype : 0); lux->rtype, herb->rtype);
} }
else if (lux || herb) { else if (lux || herb) {
m = msg_message("nr_market_info_s", "p1", m = msg_message("nr_market_info_s", "p1",
@ -2361,11 +2360,6 @@ const char *charset)
newline(out); newline(out);
write_travelthru(out, r, f); write_travelthru(out, r, f);
} }
else if (sr->mode == see_lighthouse) {
describe(out, sr, f);
newline(out);
write_travelthru(out, r, f);
}
else { else {
describe(out, sr, f); describe(out, sr, f);
newline(out); newline(out);