forked from github/server
Merge pull request #471 from ennorehling/develop
fopen is misunderstood (by me)
This commit is contained in:
commit
49b5a27bc8
35 changed files with 103 additions and 120 deletions
|
@ -49,7 +49,7 @@ attrib_type at_movement = {
|
||||||
|
|
||||||
bool get_movement(attrib * const *alist, int type)
|
bool get_movement(attrib * const *alist, int type)
|
||||||
{
|
{
|
||||||
const attrib *a = a_findc(*alist, &at_movement);
|
const attrib *a = a_find(*alist, &at_movement);
|
||||||
if (a == NULL)
|
if (a == NULL)
|
||||||
return false;
|
return false;
|
||||||
if (a->data.i & type)
|
if (a->data.i & type)
|
||||||
|
|
|
@ -45,10 +45,10 @@ void set_prefix(attrib ** ap, const char *str)
|
||||||
a->data.v = _strdup(str);
|
a->data.v = _strdup(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char *get_prefix(const attrib * a)
|
const char *get_prefix(attrib * a)
|
||||||
{
|
{
|
||||||
char *str;
|
char *str;
|
||||||
a = a_findc(a, &at_raceprefix);
|
a = a_find(a, &at_raceprefix);
|
||||||
if (a == NULL)
|
if (a == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
str = (char *)a->data.v;
|
str = (char *)a->data.v;
|
||||||
|
|
|
@ -24,7 +24,7 @@ extern "C" {
|
||||||
|
|
||||||
extern struct attrib_type at_raceprefix;
|
extern struct attrib_type at_raceprefix;
|
||||||
extern void set_prefix(struct attrib **ap, const char *str);
|
extern void set_prefix(struct attrib **ap, const char *str);
|
||||||
extern const char *get_prefix(const struct attrib *a);
|
extern const char *get_prefix(struct attrib *a);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -3595,14 +3595,15 @@ battle *make_battle(region * r)
|
||||||
if (battledebug) {
|
if (battledebug) {
|
||||||
char zText[MAX_PATH];
|
char zText[MAX_PATH];
|
||||||
char zFilename[MAX_PATH];
|
char zFilename[MAX_PATH];
|
||||||
sprintf(zText, "%s/battles", basepath());
|
join_path(basepath(), "battles", zText, sizeof(zText));
|
||||||
if (_mkdir(zText) != 0) {
|
if (_mkdir(zText) != 0) {
|
||||||
log_error("could not create subdirectory for battle logs: %s", zText);
|
log_error("could not create subdirectory for battle logs: %s", zText);
|
||||||
battledebug = false;
|
battledebug = false;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sprintf(zFilename, "%s/battle-%d-%s.log", zText, obs_count++, simplename(r));
|
sprintf(zFilename, "battle-%d-%s.log", obs_count++, simplename(r));
|
||||||
bdebug = fopen(zFilename, "w");
|
join_path(zText, zFilename, zText, sizeof(zText));
|
||||||
|
bdebug = fopen(zText, "w");
|
||||||
if (!bdebug)
|
if (!bdebug)
|
||||||
log_error("battles cannot be debugged");
|
log_error("battles cannot be debugged");
|
||||||
else {
|
else {
|
||||||
|
|
|
@ -1,6 +1,7 @@
|
||||||
#include "bind_config.h"
|
#include "bind_config.h"
|
||||||
|
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
|
#include <kernel/config.h>
|
||||||
#include <kernel/jsonconf.h>
|
#include <kernel/jsonconf.h>
|
||||||
#include <util/log.h>
|
#include <util/log.h>
|
||||||
#include <util/language.h>
|
#include <util/language.h>
|
||||||
|
@ -58,11 +59,11 @@ int config_read(const char *filename, const char * relpath)
|
||||||
|
|
||||||
json_relpath = relpath;
|
json_relpath = relpath;
|
||||||
if (relpath) {
|
if (relpath) {
|
||||||
_snprintf(name, sizeof(name), "%s/%s", relpath, filename);
|
join_path(relpath, filename, name, sizeof(name));
|
||||||
F = fopen(name, "rt");
|
F = fopen(name, "r");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
F = fopen(filename, "rt");
|
F = fopen(filename, "r");
|
||||||
}
|
}
|
||||||
if (F) {
|
if (F) {
|
||||||
long size;
|
long size;
|
||||||
|
|
|
@ -32,7 +32,7 @@ int eressea_read_orders(const char * filename) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int eressea_export_json(const char * filename, int flags) {
|
int eressea_export_json(const char * filename, int flags) {
|
||||||
FILE *F = fopen(filename, "wt");
|
FILE *F = fopen(filename, "w");
|
||||||
if (F) {
|
if (F) {
|
||||||
stream out = { 0 };
|
stream out = { 0 };
|
||||||
int err;
|
int err;
|
||||||
|
@ -46,7 +46,7 @@ int eressea_export_json(const char * filename, int flags) {
|
||||||
}
|
}
|
||||||
|
|
||||||
int eressea_import_json(const char * filename) {
|
int eressea_import_json(const char * filename) {
|
||||||
FILE *F = fopen(filename, "rt");
|
FILE *F = fopen(filename, "r");
|
||||||
if (F) {
|
if (F) {
|
||||||
stream out = { 0 };
|
stream out = { 0 };
|
||||||
int err;
|
int err;
|
||||||
|
|
|
@ -32,7 +32,7 @@ without prior permission by the authors of Eressea.
|
||||||
static int tolua_storage_create(lua_State * L)
|
static int tolua_storage_create(lua_State * L)
|
||||||
{
|
{
|
||||||
const char *filename = tolua_tostring(L, 1, 0);
|
const char *filename = tolua_tostring(L, 1, 0);
|
||||||
const char *type = tolua_tostring(L, 2, "r");
|
const char *type = tolua_tostring(L, 2, "rb");
|
||||||
gamedata *data;
|
gamedata *data;
|
||||||
|
|
||||||
data = gamedata_open(filename, type);
|
data = gamedata_open(filename, type);
|
||||||
|
|
|
@ -1502,7 +1502,7 @@ report_computer(const char *filename, report_context * ctx, const char *charset)
|
||||||
const char *mailto = LOC(f->locale, "mailto");
|
const char *mailto = LOC(f->locale, "mailto");
|
||||||
const attrib *a;
|
const attrib *a;
|
||||||
seen_region *sr = NULL;
|
seen_region *sr = NULL;
|
||||||
FILE *F = fopen(filename, "wt");
|
FILE *F = fopen(filename, "w");
|
||||||
|
|
||||||
if (era < 0) {
|
if (era < 0) {
|
||||||
era = config_get_int("world.era", 1);
|
era = config_get_int("world.era", 1);
|
||||||
|
|
|
@ -848,7 +848,7 @@ static void handlekey(state * st, int c)
|
||||||
break;
|
break;
|
||||||
case 'B':
|
case 'B':
|
||||||
if (!new_players) {
|
if (!new_players) {
|
||||||
sprintf(sbuffer, "%s/newfactions", basepath());
|
join_path(basepath(), "newfactions", sbuffer, sizeof(sbuffer));
|
||||||
new_players = read_newfactions(sbuffer);
|
new_players = read_newfactions(sbuffer);
|
||||||
}
|
}
|
||||||
cnormalize(&st->cursor, &nx, &ny);
|
cnormalize(&st->cursor, &nx, &ny);
|
||||||
|
@ -1063,7 +1063,7 @@ static void handlekey(state * st, int c)
|
||||||
break;
|
break;
|
||||||
case 'A':
|
case 'A':
|
||||||
if (!new_players) {
|
if (!new_players) {
|
||||||
sprintf(sbuffer, "%s/newfactions", basepath());
|
join_path(basepath(), "newfactions", sbuffer, sizeof(sbuffer));
|
||||||
new_players = read_newfactions(sbuffer);
|
new_players = read_newfactions(sbuffer);
|
||||||
}
|
}
|
||||||
seed_players(&new_players, false);
|
seed_players(&new_players, false);
|
||||||
|
@ -1236,11 +1236,10 @@ void run_mapper(void)
|
||||||
WINDOW *hwininfo;
|
WINDOW *hwininfo;
|
||||||
WINDOW *hwinmap;
|
WINDOW *hwinmap;
|
||||||
int width, height, x, y;
|
int width, height, x, y;
|
||||||
int split = 20, old_flags = log_flags;
|
int split = 20;
|
||||||
state *st;
|
state *st;
|
||||||
point tl;
|
point tl;
|
||||||
|
|
||||||
log_flags &= ~(LOG_CPERROR | LOG_CPWARNING);
|
|
||||||
init_curses();
|
init_curses();
|
||||||
curs_set(1);
|
curs_set(1);
|
||||||
|
|
||||||
|
@ -1332,7 +1331,6 @@ void run_mapper(void)
|
||||||
set_readline(NULL);
|
set_readline(NULL);
|
||||||
curs_set(1);
|
curs_set(1);
|
||||||
endwin();
|
endwin();
|
||||||
log_flags = old_flags;
|
|
||||||
state_close(st);
|
state_close(st);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -180,10 +180,10 @@ alliedgroup(const struct plane *pl, const struct faction *f,
|
||||||
}
|
}
|
||||||
mode = ally_mode(sf, mode) | (mode & autoalliance(pl, f, f2));
|
mode = ally_mode(sf, mode) | (mode & autoalliance(pl, f, f2));
|
||||||
if (AllianceRestricted()) {
|
if (AllianceRestricted()) {
|
||||||
if (a_findc(f->attribs, &at_npcfaction)) {
|
if (a_find(f->attribs, &at_npcfaction)) {
|
||||||
return mode;
|
return mode;
|
||||||
}
|
}
|
||||||
if (a_findc(f2->attribs, &at_npcfaction)) {
|
if (a_find(f2->attribs, &at_npcfaction)) {
|
||||||
return mode;
|
return mode;
|
||||||
}
|
}
|
||||||
if (f->alliance != f2->alliance) {
|
if (f->alliance != f2->alliance) {
|
||||||
|
@ -232,7 +232,7 @@ int alliedunit(const unit * u, const faction * f2, int mode)
|
||||||
|
|
||||||
sf = u->faction->allies;
|
sf = u->faction->allies;
|
||||||
if (fval(u, UFL_GROUP)) {
|
if (fval(u, UFL_GROUP)) {
|
||||||
const attrib *a = a_findc(u->attribs, &at_group);
|
const attrib *a = a_find(u->attribs, &at_group);
|
||||||
if (a != NULL)
|
if (a != NULL)
|
||||||
sf = ((group *)a->data.v)->allies;
|
sf = ((group *)a->data.v)->allies;
|
||||||
}
|
}
|
||||||
|
|
|
@ -659,11 +659,16 @@ void set_basepath(const char *path)
|
||||||
#define PATH_DELIM '/'
|
#define PATH_DELIM '/'
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
char * join_path(const char *p1, const char *p2, char *dst, size_t len) {
|
char * join_path(const char *p1, const char *p2, char *dst, size_t len) {
|
||||||
size_t sz;
|
size_t sz;
|
||||||
assert(p1 && p2);
|
assert(p1 && p2);
|
||||||
|
assert(p2 != dst);
|
||||||
|
if (dst == p1) {
|
||||||
|
sz = strlen(p1);
|
||||||
|
}
|
||||||
|
else {
|
||||||
sz = strlcpy(dst, p1, len);
|
sz = strlcpy(dst, p1, len);
|
||||||
|
}
|
||||||
assert(sz < len);
|
assert(sz < len);
|
||||||
dst[sz++] = PATH_DELIM;
|
dst[sz++] = PATH_DELIM;
|
||||||
strlcpy(dst + sz, p2, len - sz);
|
strlcpy(dst + sz, p2, len - sz);
|
||||||
|
|
|
@ -853,7 +853,7 @@ int writepasswd(void)
|
||||||
FILE *F;
|
FILE *F;
|
||||||
char zText[128];
|
char zText[128];
|
||||||
|
|
||||||
sprintf(zText, "%s/passwd", basepath());
|
join_path(basepath(), "passwd", zText, sizeof(zText));
|
||||||
F = fopen(zText, "w");
|
F = fopen(zText, "w");
|
||||||
if (!F) {
|
if (!F) {
|
||||||
perror(zText);
|
perror(zText);
|
||||||
|
|
|
@ -23,7 +23,7 @@ static void test_group_readwrite(CuTest * tc)
|
||||||
FILE *F;
|
FILE *F;
|
||||||
stream strm;
|
stream strm;
|
||||||
|
|
||||||
F = fopen("test.dat", "w");
|
F = fopen("test.dat", "wb");
|
||||||
fstream_init(&strm, F);
|
fstream_init(&strm, F);
|
||||||
binstore_init(&store, &strm);
|
binstore_init(&store, &strm);
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
|
@ -36,7 +36,7 @@ static void test_group_readwrite(CuTest * tc)
|
||||||
binstore_done(&store);
|
binstore_done(&store);
|
||||||
fstream_done(&strm);
|
fstream_done(&strm);
|
||||||
|
|
||||||
F = fopen("test.dat", "r");
|
F = fopen("test.dat", "rb");
|
||||||
fstream_init(&strm, F);
|
fstream_init(&strm, F);
|
||||||
binstore_init(&store, &strm);
|
binstore_init(&store, &strm);
|
||||||
f->groups = 0;
|
f->groups = 0;
|
||||||
|
|
|
@ -828,11 +828,11 @@ static void json_include(cJSON *json) {
|
||||||
FILE *F;
|
FILE *F;
|
||||||
if (json_relpath) {
|
if (json_relpath) {
|
||||||
char name[MAX_PATH];
|
char name[MAX_PATH];
|
||||||
_snprintf(name, sizeof(name), "%s/%s", json_relpath, child->valuestring);
|
join_path(json_relpath, child->valuestring, name, sizeof(name));
|
||||||
F = fopen(name, "rt");
|
F = fopen(name, "r");
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
F = fopen(child->valuestring, "rt");
|
F = fopen(child->valuestring, "r");
|
||||||
}
|
}
|
||||||
if (F) {
|
if (F) {
|
||||||
long pos;
|
long pos;
|
||||||
|
|
|
@ -438,7 +438,7 @@ static void test_configs(CuTest * tc)
|
||||||
|
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
|
|
||||||
F = fopen("test.json", "wt");
|
F = fopen("test.json", "w");
|
||||||
fwrite(building_data, 1, strlen(building_data), F);
|
fwrite(building_data, 1, strlen(building_data), F);
|
||||||
fclose(F);
|
fclose(F);
|
||||||
CuAssertPtrNotNull(tc, json);
|
CuAssertPtrNotNull(tc, json);
|
||||||
|
|
|
@ -242,10 +242,10 @@ const char *rc_name_s(const race * rc, name_t n)
|
||||||
|
|
||||||
const char *raceprefix(const unit * u)
|
const char *raceprefix(const unit * u)
|
||||||
{
|
{
|
||||||
const attrib *asource = u->faction->attribs;
|
attrib *asource = u->faction->attribs;
|
||||||
|
|
||||||
if (fval(u, UFL_GROUP)) {
|
if (fval(u, UFL_GROUP)) {
|
||||||
const attrib *agroup = a_findc(u->attribs, &at_group);
|
attrib *agroup = a_find(u->attribs, &at_group);
|
||||||
if (agroup != NULL)
|
if (agroup != NULL)
|
||||||
asource = ((const group *)(agroup->data.v))->attribs;
|
asource = ((const group *)(agroup->data.v))->attribs;
|
||||||
}
|
}
|
||||||
|
|
|
@ -552,7 +552,7 @@ int current_turn(void)
|
||||||
int cturn = 0;
|
int cturn = 0;
|
||||||
FILE *F;
|
FILE *F;
|
||||||
|
|
||||||
sprintf(zText, "%s/turn", basepath());
|
join_path(basepath(), "turn", zText, sizeof(zText));
|
||||||
F = fopen(zText, "r");
|
F = fopen(zText, "r");
|
||||||
if (!F) {
|
if (!F) {
|
||||||
perror(zText);
|
perror(zText);
|
||||||
|
@ -1166,6 +1166,7 @@ faction *readfaction(struct gamedata * data)
|
||||||
char name[DISPLAYSIZE];
|
char name[DISPLAYSIZE];
|
||||||
|
|
||||||
READ_INT(data->store, &n);
|
READ_INT(data->store, &n);
|
||||||
|
assert(n > 0);
|
||||||
f = findfaction(n);
|
f = findfaction(n);
|
||||||
if (f == NULL) {
|
if (f == NULL) {
|
||||||
f = (faction *)calloc(1, sizeof(faction));
|
f = (faction *)calloc(1, sizeof(faction));
|
||||||
|
@ -1401,13 +1402,13 @@ int readgame(const char *filename, bool backup)
|
||||||
|
|
||||||
init_locales();
|
init_locales();
|
||||||
log_debug("- reading game data from %s\n", filename);
|
log_debug("- reading game data from %s\n", filename);
|
||||||
sprintf(path, "%s/%s", datapath(), filename);
|
join_path(datapath(), filename, path, sizeof(path));
|
||||||
|
|
||||||
if (backup) {
|
if (backup) {
|
||||||
create_backup(path);
|
create_backup(path);
|
||||||
}
|
}
|
||||||
|
|
||||||
F = fopen(path, "r");
|
F = fopen(path, "rb");
|
||||||
if (!F) {
|
if (!F) {
|
||||||
perror(path);
|
perror(path);
|
||||||
return -1;
|
return -1;
|
||||||
|
@ -1753,7 +1754,7 @@ int writegame(const char *filename)
|
||||||
/* make sure we don't overwrite an existing file (hard links) */
|
/* make sure we don't overwrite an existing file (hard links) */
|
||||||
unlink(path);
|
unlink(path);
|
||||||
#endif
|
#endif
|
||||||
F = fopen(path, "w");
|
F = fopen(path, "wb");
|
||||||
if (!F) {
|
if (!F) {
|
||||||
perror(path);
|
perror(path);
|
||||||
return -1;
|
return -1;
|
||||||
|
|
|
@ -15,10 +15,10 @@ static void test_readwrite_data(CuTest * tc)
|
||||||
const char *filename = "test.dat";
|
const char *filename = "test.dat";
|
||||||
char path[MAX_PATH];
|
char path[MAX_PATH];
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
sprintf(path, "%s/%s", datapath(), filename);
|
|
||||||
CuAssertIntEquals(tc, 0, writegame(filename));
|
CuAssertIntEquals(tc, 0, writegame(filename));
|
||||||
CuAssertIntEquals(tc, 0, readgame(filename, false));
|
CuAssertIntEquals(tc, 0, readgame(filename, false));
|
||||||
CuAssertIntEquals(tc, RELEASE_VERSION, global.data_version);
|
CuAssertIntEquals(tc, RELEASE_VERSION, global.data_version);
|
||||||
|
join_path(datapath(), filename, path, sizeof(path));
|
||||||
CuAssertIntEquals(tc, 0, remove(path));
|
CuAssertIntEquals(tc, 0, remove(path));
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
}
|
}
|
||||||
|
@ -42,15 +42,15 @@ static void test_readwrite_unit(CuTest * tc)
|
||||||
u = test_create_unit(f, r);
|
u = test_create_unit(f, r);
|
||||||
join_path(datapath(), filename, path, sizeof(path));
|
join_path(datapath(), filename, path, sizeof(path));
|
||||||
|
|
||||||
data = gamedata_open(path, "w");
|
data = gamedata_open(path, "wb");
|
||||||
CuAssertPtrNotNull(tc, data); // TODO: intermittent test
|
CuAssertPtrNotNull(tc, data); // TODO: intermittent test (even after the 'b' fix!)
|
||||||
write_unit(data, u);
|
write_unit(data, u);
|
||||||
gamedata_close(data);
|
gamedata_close(data);
|
||||||
|
|
||||||
free_gamedata();
|
free_gamedata();
|
||||||
f = test_create_faction(0);
|
f = test_create_faction(0);
|
||||||
renumber_faction(f, fno);
|
renumber_faction(f, fno);
|
||||||
data = gamedata_open(path, "r");
|
data = gamedata_open(path, "rb");
|
||||||
u = read_unit(data);
|
u = read_unit(data);
|
||||||
gamedata_close(data);
|
gamedata_close(data);
|
||||||
|
|
||||||
|
|
14
src/laws.c
14
src/laws.c
|
@ -4442,8 +4442,7 @@ void update_subscriptions(void)
|
||||||
FILE *F;
|
FILE *F;
|
||||||
char zText[MAX_PATH];
|
char zText[MAX_PATH];
|
||||||
|
|
||||||
strlcpy(zText, basepath(), sizeof(zText));
|
join_path(basepath(), "subscriptions", zText, sizeof(zText));
|
||||||
strlcat(zText, "/subscriptions", sizeof(zText));
|
|
||||||
F = fopen(zText, "r");
|
F = fopen(zText, "r");
|
||||||
if (F == NULL) {
|
if (F == NULL) {
|
||||||
log_warning(0, "could not open %s.\n", zText);
|
log_warning(0, "could not open %s.\n", zText);
|
||||||
|
@ -4463,17 +4462,6 @@ void update_subscriptions(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
fclose(F);
|
fclose(F);
|
||||||
|
|
||||||
sprintf(zText, "subscriptions.%u", turn);
|
|
||||||
F = fopen(zText, "w");
|
|
||||||
if (F) {
|
|
||||||
faction *f;
|
|
||||||
for (f = factions; f != NULL; f = f->next) {
|
|
||||||
fprintf(F, "%s:%u:%s:%s:%u:\n",
|
|
||||||
itoa36(f->no), f->subscription, f->email, dbrace(f->race), f->lastorders);
|
|
||||||
}
|
|
||||||
fclose(F);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
bool
|
bool
|
||||||
|
|
|
@ -296,7 +296,7 @@ int main(int argc, char **argv)
|
||||||
/* parse arguments again, to override ini file */
|
/* parse arguments again, to override ini file */
|
||||||
parse_args(argc, argv, &err);
|
parse_args(argc, argv, &err);
|
||||||
|
|
||||||
log_open(logfile);
|
log_open(logfile, LOG_CPERROR | LOG_CPWARNING | LOG_CPDEBUG | LOG_FLUSH);
|
||||||
locale_init();
|
locale_init();
|
||||||
|
|
||||||
#ifdef CRTDBG
|
#ifdef CRTDBG
|
||||||
|
|
|
@ -152,7 +152,7 @@ void score(void)
|
||||||
allscores = 1;
|
allscores = 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
sprintf(path, "%s/score", basepath());
|
join_path(basepath(), "score", path, sizeof(path));
|
||||||
scoreFP = fopen(path, "w");
|
scoreFP = fopen(path, "w");
|
||||||
if (scoreFP) {
|
if (scoreFP) {
|
||||||
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
|
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
|
||||||
|
@ -177,7 +177,7 @@ void score(void)
|
||||||
alliance *a;
|
alliance *a;
|
||||||
const item_type *token = it_find("conquesttoken");
|
const item_type *token = it_find("conquesttoken");
|
||||||
|
|
||||||
sprintf(path, "%s/score.alliances", basepath());
|
join_path(basepath(), "score.alliances", path, sizeof(path));
|
||||||
scoreFP = fopen(path, "w");
|
scoreFP = fopen(path, "w");
|
||||||
if (scoreFP) {
|
if (scoreFP) {
|
||||||
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
|
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
|
||||||
|
|
|
@ -122,7 +122,7 @@ get_followers(unit * target, region * r, const region_list * route_end,
|
||||||
unit *uf;
|
unit *uf;
|
||||||
for (uf = r->units; uf; uf = uf->next) {
|
for (uf = r->units; uf; uf = uf->next) {
|
||||||
if (fval(uf, UFL_FOLLOWING) && !fval(uf, UFL_NOTMOVING)) {
|
if (fval(uf, UFL_FOLLOWING) && !fval(uf, UFL_NOTMOVING)) {
|
||||||
const attrib *a = a_findc(uf->attribs, &at_follow);
|
const attrib *a = a_find(uf->attribs, &at_follow);
|
||||||
if (a && a->data.v == target) {
|
if (a && a->data.v == target) {
|
||||||
follower *fnew = (follower *)malloc(sizeof(follower));
|
follower *fnew = (follower *)malloc(sizeof(follower));
|
||||||
fnew->uf = uf;
|
fnew->uf = uf;
|
||||||
|
|
|
@ -1403,7 +1403,7 @@ report_template(const char *filename, report_context * ctx, const char *charset)
|
||||||
const resource_type *rsilver = get_resourcetype(R_SILVER);
|
const resource_type *rsilver = get_resourcetype(R_SILVER);
|
||||||
faction *f = ctx->f;
|
faction *f = ctx->f;
|
||||||
region *r;
|
region *r;
|
||||||
FILE *F = fopen(filename, "wt");
|
FILE *F = fopen(filename, "w");
|
||||||
stream strm = { 0 }, *out = &strm;
|
stream strm = { 0 }, *out = &strm;
|
||||||
seen_region *sr = NULL;
|
seen_region *sr = NULL;
|
||||||
char buf[8192], *bufp;
|
char buf[8192], *bufp;
|
||||||
|
@ -2067,7 +2067,7 @@ const char *charset)
|
||||||
unsigned char op;
|
unsigned char op;
|
||||||
int maxh, bytes, ix = want(O_STATISTICS);
|
int maxh, bytes, ix = want(O_STATISTICS);
|
||||||
int wants_stats = (f->options & ix);
|
int wants_stats = (f->options & ix);
|
||||||
FILE *F = fopen(filename, "wt");
|
FILE *F = fopen(filename, "w");
|
||||||
stream strm = { 0 }, *out = &strm;
|
stream strm = { 0 }, *out = &strm;
|
||||||
seen_region *sr = NULL;
|
seen_region *sr = NULL;
|
||||||
char buf[8192];
|
char buf[8192];
|
||||||
|
|
|
@ -354,7 +354,7 @@ const char **illusion)
|
||||||
|
|
||||||
bt_illusion = bt_find("illusioncastle");
|
bt_illusion = bt_find("illusioncastle");
|
||||||
if (bt_illusion && b->type == bt_illusion) {
|
if (bt_illusion && b->type == bt_illusion) {
|
||||||
const attrib *a = a_findc(b->attribs, &at_icastle);
|
const attrib *a = a_find(b->attribs, &at_icastle);
|
||||||
if (a != NULL) {
|
if (a != NULL) {
|
||||||
*illusion = buildingtype(icastle_type(a), b, b->size);
|
*illusion = buildingtype(icastle_type(a), b, b->size);
|
||||||
}
|
}
|
||||||
|
@ -1558,11 +1558,13 @@ int write_reports(faction * f, time_t ltime)
|
||||||
if (f->options & rtype->flag) {
|
if (f->options & rtype->flag) {
|
||||||
int error;
|
int error;
|
||||||
do {
|
do {
|
||||||
char filename[MAX_PATH];
|
char filename[32];
|
||||||
sprintf(filename, "%s/%d-%s.%s", reportpath(), turn, factionid(f),
|
char path[MAX_PATH];
|
||||||
|
sprintf(filename, "%d-%s.%s", turn, factionid(f),
|
||||||
rtype->extension);
|
rtype->extension);
|
||||||
|
join_path(reportpath(), filename, path, sizeof(path));
|
||||||
error = 0;
|
error = 0;
|
||||||
if (rtype->write(filename, &ctx, encoding) == 0) {
|
if (rtype->write(path, &ctx, encoding) == 0) {
|
||||||
gotit = true;
|
gotit = true;
|
||||||
}
|
}
|
||||||
if (errno) {
|
if (errno) {
|
||||||
|
@ -1657,15 +1659,6 @@ int reports(void)
|
||||||
if (mailit)
|
if (mailit)
|
||||||
fclose(mailit);
|
fclose(mailit);
|
||||||
free_seen();
|
free_seen();
|
||||||
#ifdef GLOBAL_REPORT
|
|
||||||
{
|
|
||||||
const char *str = config_get("globalreport");
|
|
||||||
if (str != NULL) {
|
|
||||||
sprintf(path, "%s/%s.%u.cr", reportpath(), str, turn);
|
|
||||||
global_report(path);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
return retval;
|
return retval;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -3091,9 +3091,9 @@ static int sp_summonshadowlords(castorder * co)
|
||||||
|
|
||||||
static bool chaosgate_valid(const connection * b)
|
static bool chaosgate_valid(const connection * b)
|
||||||
{
|
{
|
||||||
const attrib *a = a_findc(b->from->attribs, &at_direction);
|
const attrib *a = a_find(b->from->attribs, &at_direction);
|
||||||
if (!a)
|
if (!a)
|
||||||
a = a_findc(b->to->attribs, &at_direction);
|
a = a_find(b->to->attribs, &at_direction);
|
||||||
if (!a)
|
if (!a)
|
||||||
return false;
|
return false;
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -1 +0,0 @@
|
||||||
/* empty, only used in non-msvc builds */
|
|
|
@ -152,7 +152,7 @@ static void writeturn(void)
|
||||||
char zText[MAX_PATH];
|
char zText[MAX_PATH];
|
||||||
FILE *f;
|
FILE *f;
|
||||||
|
|
||||||
sprintf(zText, "%s/datum", basepath());
|
join_path(basepath(), "datum", zText, sizeof(zText));
|
||||||
f = fopen(zText, "w");
|
f = fopen(zText, "w");
|
||||||
if (!f) {
|
if (!f) {
|
||||||
perror(zText);
|
perror(zText);
|
||||||
|
@ -160,7 +160,7 @@ static void writeturn(void)
|
||||||
}
|
}
|
||||||
fputs(gamedate2(default_locale), f);
|
fputs(gamedate2(default_locale), f);
|
||||||
fclose(f);
|
fclose(f);
|
||||||
sprintf(zText, "%s/turn", basepath());
|
join_path(basepath(), "turn", zText, sizeof(zText));
|
||||||
f = fopen(zText, "w");
|
f = fopen(zText, "w");
|
||||||
if (!f) {
|
if (!f) {
|
||||||
perror(zText);
|
perror(zText);
|
||||||
|
@ -178,10 +178,10 @@ void report_summary(summary * s, summary * o, bool full)
|
||||||
char zText[MAX_PATH];
|
char zText[MAX_PATH];
|
||||||
|
|
||||||
if (full) {
|
if (full) {
|
||||||
sprintf(zText, "%s/parteien.full", basepath());
|
join_path(basepath(), "parteien.full", zText, sizeof(zText));
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
sprintf(zText, "%s/parteien", basepath());
|
join_path(basepath(), "parteien", zText, sizeof(zText));
|
||||||
}
|
}
|
||||||
F = fopen(zText, "w");
|
F = fopen(zText, "w");
|
||||||
if (!F) {
|
if (!F) {
|
||||||
|
|
|
@ -58,10 +58,6 @@ bool list = false;
|
||||||
|
|
||||||
int RunAllTests(int argc, char *argv[])
|
int RunAllTests(int argc, char *argv[])
|
||||||
{
|
{
|
||||||
int flags = log_flags;
|
|
||||||
|
|
||||||
log_flags = LOG_FLUSH | LOG_CPERROR;
|
|
||||||
|
|
||||||
/* self-test */
|
/* self-test */
|
||||||
ADD_SUITE(tests);
|
ADD_SUITE(tests);
|
||||||
ADD_SUITE(callback);
|
ADD_SUITE(callback);
|
||||||
|
@ -146,7 +142,6 @@ int RunAllTests(int argc, char *argv[])
|
||||||
suites = s;
|
suites = s;
|
||||||
}
|
}
|
||||||
printf("\ntest summary: %d tests, %d failed\n", summary->count, summary->failCount);
|
printf("\ntest summary: %d tests, %d failed\n", summary->count, summary->failCount);
|
||||||
log_flags = flags;
|
|
||||||
fail_count = summary->failCount;
|
fail_count = summary->failCount;
|
||||||
CuSuiteDelete(summary);
|
CuSuiteDelete(summary);
|
||||||
game_done();
|
game_done();
|
||||||
|
|
|
@ -101,13 +101,6 @@ attrib *a_find(attrib * a, const attrib_type * at)
|
||||||
return a;
|
return a;
|
||||||
}
|
}
|
||||||
|
|
||||||
const attrib *a_findc(const attrib * a, const attrib_type * at)
|
|
||||||
{
|
|
||||||
while (a && a->type != at)
|
|
||||||
a = a->nexttype;
|
|
||||||
return a;
|
|
||||||
}
|
|
||||||
|
|
||||||
static attrib *a_insert(attrib * head, attrib * a)
|
static attrib *a_insert(attrib * head, attrib * a)
|
||||||
{
|
{
|
||||||
attrib **pa;
|
attrib **pa;
|
||||||
|
|
|
@ -68,7 +68,6 @@ extern "C" {
|
||||||
extern attrib *a_select(attrib * a, const void *data,
|
extern attrib *a_select(attrib * a, const void *data,
|
||||||
bool(*compare) (const attrib *, const void *));
|
bool(*compare) (const attrib *, const void *));
|
||||||
extern attrib *a_find(attrib * a, const attrib_type * at);
|
extern attrib *a_find(attrib * a, const attrib_type * at);
|
||||||
extern const attrib *a_findc(const attrib * a, const attrib_type * at);
|
|
||||||
extern attrib *a_add(attrib ** pa, attrib * at);
|
extern attrib *a_add(attrib ** pa, attrib * at);
|
||||||
extern int a_remove(attrib ** pa, attrib * at);
|
extern int a_remove(attrib ** pa, attrib * at);
|
||||||
extern void a_removeall(attrib ** a, const attrib_type * at);
|
extern void a_removeall(attrib ** a, const attrib_type * at);
|
||||||
|
|
|
@ -31,22 +31,23 @@ static int stdio_codepage = STDIO_CP;
|
||||||
static int stdio_codepage = 0;
|
static int stdio_codepage = 0;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
typedef struct logger {
|
typedef struct log_t {
|
||||||
void(*log)(void *data, int level, const char *module, const char *format, va_list args);
|
void(*log)(void *data, int level, const char *module, const char *format, va_list args);
|
||||||
void *data;
|
void *data;
|
||||||
int flags;
|
int flags;
|
||||||
struct logger *next;
|
struct log_t *next;
|
||||||
} logger;
|
} log_t;
|
||||||
|
|
||||||
static logger *loggers;
|
static log_t *loggers;
|
||||||
|
|
||||||
void log_create(int flags, void *data, log_fun call) {
|
log_t *log_create(int flags, void *data, log_fun call) {
|
||||||
logger *lgr = malloc(sizeof(logger));
|
log_t *lgr = malloc(sizeof(log_t));
|
||||||
lgr->log = call;
|
lgr->log = call;
|
||||||
lgr->flags = flags;
|
lgr->flags = flags;
|
||||||
lgr->data = data;
|
lgr->data = data;
|
||||||
lgr->next = loggers;
|
lgr->next = loggers;
|
||||||
loggers = lgr;
|
loggers = lgr;
|
||||||
|
return lgr;
|
||||||
}
|
}
|
||||||
|
|
||||||
#define MAXLENGTH 4096 /* because I am lazy, CP437 output is limited to this many chars */
|
#define MAXLENGTH 4096 /* because I am lazy, CP437 output is limited to this many chars */
|
||||||
|
@ -122,10 +123,8 @@ static int check_dupe(const char *format, int type)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
if (dupes) {
|
if (dupes) {
|
||||||
if (log_flags & LOG_CPERROR) {
|
|
||||||
fprintf(stderr, "%s: last message repeated %d times\n", log_prefix(last_type),
|
fprintf(stderr, "%s: last message repeated %d times\n", log_prefix(last_type),
|
||||||
dupes + 1);
|
dupes + 1);
|
||||||
}
|
|
||||||
dupes = 0;
|
dupes = 0;
|
||||||
}
|
}
|
||||||
strlcpy(last_message, format, sizeof(last_message));
|
strlcpy(last_message, format, sizeof(last_message));
|
||||||
|
@ -167,12 +166,12 @@ static void log_stdio(void *data, int level, const char *module, const char *for
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void log_to_file(int flags, FILE *out) {
|
log_t *log_to_file(int flags, FILE *out) {
|
||||||
log_create(flags, out, log_stdio);
|
return log_create(flags, out, log_stdio);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void log_write(int flags, const char *module, const char *format, va_list args) {
|
static void log_write(int flags, const char *module, const char *format, va_list args) {
|
||||||
logger *lg;
|
log_t *lg;
|
||||||
for (lg = loggers; lg; lg = lg->next) {
|
for (lg = loggers; lg; lg = lg->next) {
|
||||||
int level = flags & LOG_LEVELS;
|
int level = flags & LOG_LEVELS;
|
||||||
if (lg->flags & level) {
|
if (lg->flags & level) {
|
||||||
|
@ -241,7 +240,7 @@ static FILE *logfile;
|
||||||
void log_close(void)
|
void log_close(void)
|
||||||
{
|
{
|
||||||
while (loggers) {
|
while (loggers) {
|
||||||
logger *lgr = loggers;
|
log_t *lgr = loggers;
|
||||||
loggers = lgr->next;
|
loggers = lgr->next;
|
||||||
free(lgr);
|
free(lgr);
|
||||||
}
|
}
|
||||||
|
@ -254,7 +253,7 @@ void log_close(void)
|
||||||
logfile = 0;
|
logfile = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void log_open(const char *filename)
|
log_t *log_open(const char *filename, int log_flags)
|
||||||
{
|
{
|
||||||
log_rotate(filename, LOG_MAXBACKUPS);
|
log_rotate(filename, LOG_MAXBACKUPS);
|
||||||
logfile = fopen(filename, "a");
|
logfile = fopen(filename, "a");
|
||||||
|
@ -263,6 +262,14 @@ void log_open(const char *filename)
|
||||||
time_t ltime;
|
time_t ltime;
|
||||||
time(<ime);
|
time(<ime);
|
||||||
fprintf(logfile, "===\n=== Logfile started at %s===\n", ctime(<ime));
|
fprintf(logfile, "===\n=== Logfile started at %s===\n", ctime(<ime));
|
||||||
log_create(log_flags, logfile, log_stdio);
|
return log_create(log_flags, logfile, log_stdio);
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int log_level(log_t * log, int flags)
|
||||||
|
{
|
||||||
|
int old = log->flags;
|
||||||
|
log->flags = flags;
|
||||||
|
return old;
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,10 +17,16 @@ extern "C" {
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdarg.h>
|
#include <stdarg.h>
|
||||||
|
|
||||||
extern void log_open(const char *filename);
|
struct log_t;
|
||||||
extern void log_close(void);
|
|
||||||
|
typedef void(*log_fun)(void *data, int level, const char *module, const char *format, va_list args);
|
||||||
|
|
||||||
|
struct log_t * log_open(const char *filename, int flags);
|
||||||
|
struct log_t * log_create(int flags, void *data, log_fun call);
|
||||||
|
struct log_t * log_to_file(int flags, FILE *out);
|
||||||
|
int log_level(struct log_t *log, int flags);
|
||||||
|
void log_close(void);
|
||||||
|
|
||||||
/* use macros above instead of these: */
|
|
||||||
extern void log_fatal(const char *format, ...);
|
extern void log_fatal(const char *format, ...);
|
||||||
extern void log_error(const char *format, ...);
|
extern void log_error(const char *format, ...);
|
||||||
extern void log_warning(const char *format, ...);
|
extern void log_warning(const char *format, ...);
|
||||||
|
@ -36,13 +42,6 @@ extern "C" {
|
||||||
#define LOG_FLUSH 0x10
|
#define LOG_FLUSH 0x10
|
||||||
#define LOG_BRIEF 0x20
|
#define LOG_BRIEF 0x20
|
||||||
|
|
||||||
typedef void(*log_fun)(void *data, int level, const char *module, const char *format, va_list args);
|
|
||||||
|
|
||||||
void log_create(int flags, void *data, log_fun call);
|
|
||||||
void log_to_file(int flags, FILE *out);
|
|
||||||
|
|
||||||
extern int log_flags;
|
|
||||||
extern int log_stderr;
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -149,7 +149,7 @@ attrib *create_special_direction(region * r, region * rt, int duration,
|
||||||
|
|
||||||
spec_direction *special_direction(const region * from, const region * to)
|
spec_direction *special_direction(const region * from, const region * to)
|
||||||
{
|
{
|
||||||
const attrib *a = a_findc(from->attribs, &at_direction);
|
const attrib *a = a_find(from->attribs, &at_direction);
|
||||||
|
|
||||||
while (a != NULL && a->type == &at_direction) {
|
while (a != NULL && a->type == &at_direction) {
|
||||||
spec_direction *sd = (spec_direction *)a->data.v;
|
spec_direction *sd = (spec_direction *)a->data.v;
|
||||||
|
|
1
tests/score
Normal file
1
tests/score
Normal file
|
@ -0,0 +1 @@
|
||||||
|
|
3
tests/score.alliances
Normal file
3
tests/score.alliances
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
# alliance:factions:persons:score
|
||||||
|
1248287:1:0:0
|
||||||
|
1490214:1:0:2105
|
Loading…
Reference in a new issue