forked from github/server
Merge branch 'develop' of https://github.com/ennorehling/eressea.git
This commit is contained in:
commit
537166eadf
30 changed files with 178 additions and 152 deletions
|
@ -13,6 +13,7 @@ addons:
|
||||||
- libsqlite3-dev
|
- libsqlite3-dev
|
||||||
- libxml2-dev
|
- libxml2-dev
|
||||||
- valgrind
|
- valgrind
|
||||||
|
- cppcheck
|
||||||
os:
|
os:
|
||||||
- linux
|
- linux
|
||||||
notifications:
|
notifications:
|
||||||
|
|
|
@ -22,6 +22,8 @@ s/cmake-init
|
||||||
s/build
|
s/build
|
||||||
cd $ROOT
|
cd $ROOT
|
||||||
inifile
|
inifile
|
||||||
|
cppcheck --version
|
||||||
|
cppcheck --quiet --error-exitcode=1 src
|
||||||
s/runtests -V
|
s/runtests -V
|
||||||
|
|
||||||
integration_tests
|
integration_tests
|
||||||
|
|
||||||
|
|
|
@ -135,7 +135,13 @@ static void dict_upgrade(attrib **alist, attrib *abegin) {
|
||||||
assert(!"invalid input");
|
assert(!"invalid input");
|
||||||
}
|
}
|
||||||
if (i == 4) {
|
if (i == 4) {
|
||||||
keys = realloc(keys, sizeof(int) * (n + i + 1));
|
int *k;
|
||||||
|
k = realloc(keys, sizeof(int) * (n + i + 1));
|
||||||
|
if (!k) {
|
||||||
|
free(keys);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
keys = k;
|
||||||
memcpy(keys + n + 1, val, sizeof(val));
|
memcpy(keys + n + 1, val, sizeof(val));
|
||||||
n += i;
|
n += i;
|
||||||
i = 0;
|
i = 0;
|
||||||
|
|
|
@ -123,8 +123,14 @@ static int a_readkeys(attrib * a, void *owner, gamedata *data) {
|
||||||
if (e != n) {
|
if (e != n) {
|
||||||
int sz = keys_size(n);
|
int sz = keys_size(n);
|
||||||
if (e > sz) {
|
if (e > sz) {
|
||||||
|
int *k;
|
||||||
sz = keys_size(e);
|
sz = keys_size(e);
|
||||||
keys = realloc(keys, sizeof(int)*(2 * sz + 1));
|
k = realloc(keys, sizeof(int)*(2 * sz + 1));
|
||||||
|
if (!k) {
|
||||||
|
free(keys);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
keys = k;
|
||||||
keys[0] = e;
|
keys[0] = e;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
12
src/battle.h
12
src/battle.h
|
@ -172,17 +172,6 @@ extern "C" {
|
||||||
int catmsg; /* Merkt sich, ob Katapultmessage schon generiert. */
|
int catmsg; /* Merkt sich, ob Katapultmessage schon generiert. */
|
||||||
struct person {
|
struct person {
|
||||||
int hp; /* Trefferpunkte der Personen */
|
int hp; /* Trefferpunkte der Personen */
|
||||||
#ifdef LOMEM
|
|
||||||
int attack : 8; /* (Magie) Attackenbonus der Personen */
|
|
||||||
int defence : 8; /* (Magie) Paradenbonus der Personen */
|
|
||||||
int damage : 8; /* (Magie) Schadensbonus der Personen im Nahkampf */
|
|
||||||
int damage_rear : 8; /* (Magie) Schadensbonus der Personen im Fernkampf */
|
|
||||||
int flags : 8; /* (Magie) Diverse Flags auf Kaempfern */
|
|
||||||
int speed : 8; /* (Magie) Geschwindigkeitsmultiplkator. */
|
|
||||||
int reload : 4; /* Anzahl Runden, die die Waffe x noch laden muss.
|
|
||||||
* dahinter steckt ein array[RL_MAX] wenn er min. eine hat. */
|
|
||||||
int last_action : 4; /* In welcher Runde haben wir zuletzt etwas getan */
|
|
||||||
#else
|
|
||||||
int attack;
|
int attack;
|
||||||
int defence;
|
int defence;
|
||||||
int damage;
|
int damage;
|
||||||
|
@ -191,7 +180,6 @@ extern "C" {
|
||||||
int speed;
|
int speed;
|
||||||
int reload;
|
int reload;
|
||||||
int last_action;
|
int last_action;
|
||||||
#endif
|
|
||||||
struct weapon *missile; /* missile weapon */
|
struct weapon *missile; /* missile weapon */
|
||||||
struct weapon *melee; /* melee weapon */
|
struct weapon *melee; /* melee weapon */
|
||||||
} *person;
|
} *person;
|
||||||
|
|
|
@ -30,5 +30,6 @@ extern "C"
|
||||||
extern const char * directions[];
|
extern const char * directions[];
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -217,7 +217,7 @@ static unit *setup_trade_unit(CuTest *tc, region *r, const struct race *rc) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_trade_insect(CuTest *tc) {
|
static void test_trade_insect(CuTest *tc) {
|
||||||
/* Insekten können in Wüsten und Sümpfen auch ohne Burgen handeln. */
|
/* Insekten k<EFBFBD>nnen in W<>sten und S<>mpfen auch ohne Burgen handeln. */
|
||||||
unit *u;
|
unit *u;
|
||||||
region *r;
|
region *r;
|
||||||
const item_type *it_luxury;
|
const item_type *it_luxury;
|
||||||
|
@ -239,6 +239,8 @@ static void test_trade_insect(CuTest *tc) {
|
||||||
LOC(u->faction->locale, resourcename(it_luxury->rtype, 0))));
|
LOC(u->faction->locale, resourcename(it_luxury->rtype, 0))));
|
||||||
|
|
||||||
set_item(u, it_silver, 10);
|
set_item(u, it_silver, 10);
|
||||||
|
CuAssertPtrEquals(tc, r, u->region);
|
||||||
|
CuAssertPtrEquals(tc, (void *)it_luxury, (void *)r_luxury(u->region));
|
||||||
produce(u->region);
|
produce(u->region);
|
||||||
CuAssertIntEquals(tc, 1, get_item(u, it_luxury));
|
CuAssertIntEquals(tc, 1, get_item(u, it_luxury));
|
||||||
CuAssertIntEquals(tc, 5, get_item(u, it_silver));
|
CuAssertIntEquals(tc, 5, get_item(u, it_silver));
|
||||||
|
|
20
src/gmtool.c
20
src/gmtool.c
|
@ -720,6 +720,22 @@ static void select_regions(state * st, int selectmode)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (findmode == 'c') {
|
||||||
|
region *r;
|
||||||
|
sprintf(sbuffer, "%schaos", status);
|
||||||
|
statusline(st->wnd_status->handle, sbuffer);
|
||||||
|
for (r = regions; r; r = r->next) {
|
||||||
|
if (fval(r, RF_CHAOTIC)) {
|
||||||
|
if (selectmode & MODE_SELECT) {
|
||||||
|
select_coordinate(st->selected, r->x, r->y,
|
||||||
|
selectmode == MODE_SELECT);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
highlight_region(r, selectmode == MODE_MARK);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
else if (findmode == 'm') {
|
else if (findmode == 'm') {
|
||||||
region *r;
|
region *r;
|
||||||
sprintf(sbuffer, "%smonsters", status);
|
sprintf(sbuffer, "%smonsters", status);
|
||||||
|
@ -991,9 +1007,13 @@ static void handlekey(state * st, int c)
|
||||||
break;
|
break;
|
||||||
case 'c': /* clear/reset */
|
case 'c': /* clear/reset */
|
||||||
reset_cursor(st);
|
reset_cursor(st);
|
||||||
|
st->modified = 1;
|
||||||
|
st->wnd_map->update |= 1;
|
||||||
break;
|
break;
|
||||||
case 'C': /* clear/reset */
|
case 'C': /* clear/reset */
|
||||||
reset_rect(st);
|
reset_rect(st);
|
||||||
|
st->modified = 1;
|
||||||
|
st->wnd_map->update |= 1;
|
||||||
break;
|
break;
|
||||||
case 0x09: /* tab = next selected */
|
case 0x09: /* tab = next selected */
|
||||||
if (regions != NULL) {
|
if (regions != NULL) {
|
||||||
|
|
|
@ -89,7 +89,8 @@ alliance *new_alliance(int id, const char *name) {
|
||||||
al->flags |= ALF_NON_ALLIED;
|
al->flags |= ALF_NON_ALLIED;
|
||||||
}
|
}
|
||||||
al->next = alliances;
|
al->next = alliances;
|
||||||
return alliances = al;
|
alliances = al;
|
||||||
|
return al;
|
||||||
}
|
}
|
||||||
|
|
||||||
alliance *findalliance(int id)
|
alliance *findalliance(int id)
|
||||||
|
|
|
@ -207,7 +207,7 @@ static void test_build_building_with_golem(CuTest *tc) {
|
||||||
const building_type *btype;
|
const building_type *btype;
|
||||||
|
|
||||||
u = setup_build(&bf);
|
u = setup_build(&bf);
|
||||||
bf.rc->flags |= RCF_STONEGOLEM;
|
bf.rc->ec_flags |= ECF_STONEGOLEM;
|
||||||
btype = bt_find("castle");
|
btype = bt_find("castle");
|
||||||
assert(btype);
|
assert(btype);
|
||||||
assert(btype->construction);
|
assert(btype->construction);
|
||||||
|
|
|
@ -95,7 +95,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
|
|
||||||
struct settings global;
|
struct settings global;
|
||||||
|
|
||||||
bool lomem = false;
|
|
||||||
int turn = 0;
|
int turn = 0;
|
||||||
|
|
||||||
const char *parameters[MAXPARAMS] = {
|
const char *parameters[MAXPARAMS] = {
|
||||||
|
|
|
@ -141,7 +141,6 @@ extern "C" {
|
||||||
extern const char *parameters[];
|
extern const char *parameters[];
|
||||||
extern settings global;
|
extern settings global;
|
||||||
|
|
||||||
extern bool lomem; /* save memory */
|
|
||||||
extern int turn;
|
extern int turn;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
|
|
@ -105,10 +105,10 @@ static int res_changepeasants(unit * u, const resource_type * rtype, int delta)
|
||||||
}
|
}
|
||||||
|
|
||||||
static int golem_factor(const unit *u, const resource_type *rtype) {
|
static int golem_factor(const unit *u, const resource_type *rtype) {
|
||||||
if (rtype == get_resourcetype(R_STONE) && (u_race(u)->flags & RCF_STONEGOLEM)) {
|
if (rtype == get_resourcetype(R_STONE) && (u_race(u)->ec_flags & ECF_STONEGOLEM)) {
|
||||||
return GOLEM_STONE;
|
return GOLEM_STONE;
|
||||||
}
|
}
|
||||||
if (rtype == get_resourcetype(R_IRON) && (u_race(u)->flags & RCF_IRONGOLEM)) {
|
if (rtype == get_resourcetype(R_IRON) && (u_race(u)->ec_flags & ECF_IRONGOLEM)) {
|
||||||
return GOLEM_IRON;
|
return GOLEM_IRON;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -340,8 +340,10 @@ void it_set_appearance(item_type *itype, const char *appearance) {
|
||||||
assert(itype);
|
assert(itype);
|
||||||
assert(itype->rtype);
|
assert(itype->rtype);
|
||||||
if (appearance) {
|
if (appearance) {
|
||||||
|
char plural[32];
|
||||||
itype->_appearance[0] = strdup(appearance);
|
itype->_appearance[0] = strdup(appearance);
|
||||||
itype->_appearance[1] = strcat(strcpy((char *)malloc(strlen((char *)appearance) + 3), (char *)appearance), "_p");
|
snprintf(plural, sizeof(plural), "%s_p", appearance);
|
||||||
|
itype->_appearance[1] = strdup(plural);
|
||||||
} else {
|
} else {
|
||||||
itype->_appearance[0] = 0;
|
itype->_appearance[0] = 0;
|
||||||
itype->_appearance[1] = 0;
|
itype->_appearance[1] = 0;
|
||||||
|
@ -665,7 +667,7 @@ static int
|
||||||
mod_dwarves_only(const unit * u, const region * r, skill_t sk, int value)
|
mod_dwarves_only(const unit * u, const region * r, skill_t sk, int value)
|
||||||
{
|
{
|
||||||
UNUSED_ARG(r);
|
UNUSED_ARG(r);
|
||||||
if (u_race(u) == get_race(RC_DWARF) || (u_race(u)->flags & RCF_IRONGOLEM)) {
|
if (u_race(u) == get_race(RC_DWARF) || (u_race(u)->ec_flags & ECF_IRONGOLEM)) {
|
||||||
return value;
|
return value;
|
||||||
}
|
}
|
||||||
return -118;
|
return -118;
|
||||||
|
|
|
@ -291,7 +291,7 @@ void free_messagelist(mlist *msgs)
|
||||||
message *add_message(message_list ** pm, message * m)
|
message *add_message(message_list ** pm, message * m)
|
||||||
{
|
{
|
||||||
assert(m && m->type);
|
assert(m && m->type);
|
||||||
if (!lomem && m != NULL) {
|
if (m != NULL) {
|
||||||
struct mlist *mnew = malloc(sizeof(struct mlist));
|
struct mlist *mnew = malloc(sizeof(struct mlist));
|
||||||
if (*pm == NULL) {
|
if (*pm == NULL) {
|
||||||
*pm = malloc(sizeof(message_list));
|
*pm = malloc(sizeof(message_list));
|
||||||
|
|
|
@ -279,27 +279,13 @@ void close_orders(void) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
static order *create_order_i(order *ord, keyword_t kwd, const char *sptr, bool persistent,
|
static void create_order_i(order *ord, keyword_t kwd, const char *sptr, bool persistent,
|
||||||
bool noerror, const struct locale *lang)
|
bool noerror, const struct locale *lang)
|
||||||
{
|
{
|
||||||
int lindex;
|
int lindex;
|
||||||
|
|
||||||
assert(ord);
|
assert(ord);
|
||||||
if (kwd == NOKEYWORD || keyword_disabled(kwd)) {
|
assert(kwd != NOKEYWORD && !keyword_disabled(kwd));
|
||||||
log_error("trying to create an order for disabled keyword %s.", keyword(kwd));
|
|
||||||
return NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* if this is just nonsense, then we skip it. */
|
|
||||||
if (lomem) {
|
|
||||||
switch (kwd) {
|
|
||||||
case K_KOMMENTAR:
|
|
||||||
case NOKEYWORD:
|
|
||||||
return NULL;
|
|
||||||
default:
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
lindex = locale_index(lang);
|
lindex = locale_index(lang);
|
||||||
assert(lindex < MAXLOCALES);
|
assert(lindex < MAXLOCALES);
|
||||||
|
@ -318,8 +304,6 @@ static order *create_order_i(order *ord, keyword_t kwd, const char *sptr, bool p
|
||||||
|
|
||||||
while (isspace(*(unsigned char *)sptr)) ++sptr;
|
while (isspace(*(unsigned char *)sptr)) ++sptr;
|
||||||
ord->data = create_data(kwd, sptr, lindex);
|
ord->data = create_data(kwd, sptr, lindex);
|
||||||
|
|
||||||
return ord;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
order *create_order(keyword_t kwd, const struct locale * lang,
|
order *create_order(keyword_t kwd, const struct locale * lang,
|
||||||
|
@ -377,7 +361,8 @@ order *create_order(keyword_t kwd, const struct locale * lang,
|
||||||
zBuffer[0] = 0;
|
zBuffer[0] = 0;
|
||||||
}
|
}
|
||||||
ord = (order *)malloc(sizeof(order));
|
ord = (order *)malloc(sizeof(order));
|
||||||
return create_order_i(ord, kwd, zBuffer, false, false, lang);
|
create_order_i(ord, kwd, zBuffer, false, false, lang);
|
||||||
|
return ord;
|
||||||
}
|
}
|
||||||
|
|
||||||
order *parse_order(const char *s, const struct locale * lang)
|
order *parse_order(const char *s, const struct locale * lang)
|
||||||
|
@ -409,7 +394,8 @@ order *parse_order(const char *s, const struct locale * lang)
|
||||||
}
|
}
|
||||||
if (kwd != NOKEYWORD) {
|
if (kwd != NOKEYWORD) {
|
||||||
order *ord = (order *)malloc(sizeof(order));
|
order *ord = (order *)malloc(sizeof(order));
|
||||||
return create_order_i(ord, kwd, sptr, persistent, noerror, lang);
|
create_order_i(ord, kwd, sptr, persistent, noerror, lang);
|
||||||
|
return ord;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
|
@ -88,9 +88,9 @@ int get_reservation(const unit * u, const item_type * itype)
|
||||||
{
|
{
|
||||||
reservation *res = u->reservations;
|
reservation *res = u->reservations;
|
||||||
|
|
||||||
if (itype->rtype == get_resourcetype(R_STONE) && (u_race(u)->flags & RCF_STONEGOLEM))
|
if (itype->rtype == get_resourcetype(R_STONE) && (u_race(u)->ec_flags & ECF_STONEGOLEM))
|
||||||
return (u->number * GOLEM_STONE);
|
return (u->number * GOLEM_STONE);
|
||||||
if (itype->rtype == get_resourcetype(R_IRON) && (u_race(u)->flags & RCF_IRONGOLEM))
|
if (itype->rtype == get_resourcetype(R_IRON) && (u_race(u)->ec_flags & ECF_IRONGOLEM))
|
||||||
return (u->number * GOLEM_IRON);
|
return (u->number * GOLEM_IRON);
|
||||||
while (res && res->type != itype)
|
while (res && res->type != itype)
|
||||||
res = res->next;
|
res = res->next;
|
||||||
|
|
|
@ -106,17 +106,18 @@ static void rc_setoption(race *rc, int k, const char *value) {
|
||||||
rc->options->key[1] = RCO_NONE;
|
rc->options->key[1] = RCO_NONE;
|
||||||
v = rc->options->value;
|
v = rc->options->value;
|
||||||
} else {
|
} else {
|
||||||
for (i=0;!v && i < MAXOPTIONS && rc->options->key[i]!=RCO_NONE;++i) {
|
for (i=0;!v && i < MAXOPTIONS;++i) {
|
||||||
if (rc->options->key[i]==key) {
|
if (rc->options->key[i]==key) {
|
||||||
v = rc->options->value+i;
|
v = rc->options->value+i;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
if (rc->options->key[i]==RCO_NONE) {
|
||||||
if (!v) {
|
v = rc->options->value+i;
|
||||||
assert(i<MAXOPTIONS || !"MAXOPTIONS too small for race");
|
rc->options->key[i] = key;
|
||||||
v = rc->options->value+i;
|
if (i+1 < MAXOPTIONS) {
|
||||||
rc->options->key[i] = key;
|
rc->options->key[i+1]=RCO_NONE;
|
||||||
if (i+1<MAXOPTIONS) {
|
}
|
||||||
rc->options->key[i+1]=RCO_NONE;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -226,11 +226,9 @@ extern "C" {
|
||||||
#define RCF_CANSAIL (1<<24) /* Einheit darf Schiffe betreten */
|
#define RCF_CANSAIL (1<<24) /* Einheit darf Schiffe betreten */
|
||||||
#define RCF_INVISIBLE (1<<25) /* not visible in any report */
|
#define RCF_INVISIBLE (1<<25) /* not visible in any report */
|
||||||
#define RCF_SHIPSPEED (1<<26) /* race gets +1 on shipspeed */
|
#define RCF_SHIPSPEED (1<<26) /* race gets +1 on shipspeed */
|
||||||
#define RCF_STONEGOLEM (1<<27) /* race gets stonegolem properties */
|
#define RCF_MIGRANTS (1<<27) /* may have migrant units (human bonus) */
|
||||||
#define RCF_IRONGOLEM (1<<28) /* race gets irongolem properties */
|
#define RCF_FAMILIAR (1<<28) /* may be a familiar */
|
||||||
#define RCF_ATTACK_MOVED (1<<29) /* may attack if it has moved */
|
#define RCF_ATTACK_MOVED (1<<29) /* may attack if it has moved */
|
||||||
#define RCF_MIGRANTS (1<<30) /* may have migrant units (human bonus) */
|
|
||||||
#define RCF_FAMILIAR (1<<31) /* may be a familiar */
|
|
||||||
|
|
||||||
/* Economic flags */
|
/* Economic flags */
|
||||||
#define ECF_GIVEPERSON (1<<2) /* <20>bergibt Personen */
|
#define ECF_GIVEPERSON (1<<2) /* <20>bergibt Personen */
|
||||||
|
@ -238,6 +236,8 @@ extern "C" {
|
||||||
#define ECF_GETITEM (1<<4) /* nimmt Gegenst<73>nde an */
|
#define ECF_GETITEM (1<<4) /* nimmt Gegenst<73>nde an */
|
||||||
#define ECF_REC_ETHEREAL (1<<7) /* Rekrutiert aus dem Nichts */
|
#define ECF_REC_ETHEREAL (1<<7) /* Rekrutiert aus dem Nichts */
|
||||||
#define ECF_REC_UNLIMITED (1<<8) /* Rekrutiert ohne Limit */
|
#define ECF_REC_UNLIMITED (1<<8) /* Rekrutiert ohne Limit */
|
||||||
|
#define ECF_STONEGOLEM (1<<9) /* race gets stonegolem properties */
|
||||||
|
#define ECF_IRONGOLEM (1<<10) /* race gets irongolem properties */
|
||||||
|
|
||||||
/* Battle-Flags */
|
/* Battle-Flags */
|
||||||
#define BF_EQUIPMENT (1<<0) /* Kann Ausr<73>stung benutzen */
|
#define BF_EQUIPMENT (1<<0) /* Kann Ausr<73>stung benutzen */
|
||||||
|
|
|
@ -487,16 +487,11 @@ unit *read_unit(gamedata *data)
|
||||||
log_warning("trim unit %s name to '%s'", itoa36(u->no), obuf);
|
log_warning("trim unit %s name to '%s'", itoa36(u->no), obuf);
|
||||||
}
|
}
|
||||||
u->_name = obuf[0] ? strdup(obuf) : 0;
|
u->_name = obuf[0] ? strdup(obuf) : 0;
|
||||||
if (lomem) {
|
READ_STR(data->store, obuf, sizeof(obuf));
|
||||||
READ_STR(data->store, NULL, 0);
|
if (unicode_utf8_trim(obuf)!=0) {
|
||||||
}
|
log_warning("trim unit %s info to '%s'", itoa36(u->no), obuf);
|
||||||
else {
|
|
||||||
READ_STR(data->store, obuf, sizeof(obuf));
|
|
||||||
if (unicode_utf8_trim(obuf)!=0) {
|
|
||||||
log_warning("trim unit %s info to '%s'", itoa36(u->no), obuf);
|
|
||||||
}
|
|
||||||
u->display = obuf[0] ? strdup(obuf) : 0;
|
|
||||||
}
|
}
|
||||||
|
u->display = obuf[0] ? strdup(obuf) : 0;
|
||||||
READ_INT(data->store, &number);
|
READ_INT(data->store, &number);
|
||||||
set_number(u, number);
|
set_number(u, number);
|
||||||
|
|
||||||
|
@ -509,7 +504,7 @@ unit *read_unit(gamedata *data)
|
||||||
u_setrace(u, rc);
|
u_setrace(u, rc);
|
||||||
|
|
||||||
READ_TOK(data->store, rname, sizeof(rname));
|
READ_TOK(data->store, rname, sizeof(rname));
|
||||||
if (rname[0] && skill_enabled(SK_STEALTH))
|
if (rname[0])
|
||||||
u->irace = rc_find(rname);
|
u->irace = rc_find(rname);
|
||||||
else
|
else
|
||||||
u->irace = NULL;
|
u->irace = NULL;
|
||||||
|
@ -557,24 +552,23 @@ unit *read_unit(gamedata *data)
|
||||||
p = n = 0;
|
p = n = 0;
|
||||||
orderp = &u->orders;
|
orderp = &u->orders;
|
||||||
while (obuf[0]) {
|
while (obuf[0]) {
|
||||||
if (!lomem) {
|
order *ord = parse_order(obuf, u->faction->locale);
|
||||||
order *ord = parse_order(obuf, u->faction->locale);
|
if (ord != NULL) {
|
||||||
|
if (++n < MAXORDERS) {
|
||||||
|
if (!is_persistent(ord) || ++p < MAXPERSISTENT) {
|
||||||
|
*orderp = ord;
|
||||||
|
orderp = &ord->next;
|
||||||
|
ord = NULL;
|
||||||
|
}
|
||||||
|
else if (p == MAXPERSISTENT) {
|
||||||
|
log_info("%s had %d or more persistent orders", unitname(u), MAXPERSISTENT);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (n == MAXORDERS) {
|
||||||
|
log_info("%s had %d or more orders", unitname(u), MAXORDERS);
|
||||||
|
}
|
||||||
if (ord != NULL) {
|
if (ord != NULL) {
|
||||||
if (++n < MAXORDERS) {
|
free_order(ord);
|
||||||
if (!is_persistent(ord) || ++p < MAXPERSISTENT) {
|
|
||||||
*orderp = ord;
|
|
||||||
orderp = &ord->next;
|
|
||||||
ord = NULL;
|
|
||||||
}
|
|
||||||
else if (p == MAXPERSISTENT) {
|
|
||||||
log_info("%s had %d or more persistent orders", unitname(u), MAXPERSISTENT);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else if (n == MAXORDERS) {
|
|
||||||
log_info("%s had %d or more orders", unitname(u), MAXORDERS);
|
|
||||||
}
|
|
||||||
if (ord != NULL)
|
|
||||||
free_order(ord);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
READ_STR(data->store, obuf, sizeof(obuf));
|
READ_STR(data->store, obuf, sizeof(obuf));
|
||||||
|
@ -659,14 +653,9 @@ void write_unit(gamedata *data, const unit * u)
|
||||||
}
|
}
|
||||||
|
|
||||||
static void read_regioninfo(gamedata *data, const region *r, char *info, size_t len) {
|
static void read_regioninfo(gamedata *data, const region *r, char *info, size_t len) {
|
||||||
if (lomem) {
|
READ_STR(data->store, info, len);
|
||||||
READ_STR(data->store, NULL, 0);
|
if (unicode_utf8_trim(info) != 0) {
|
||||||
}
|
log_warning("trim region %d info to '%s'", r->uid, info);
|
||||||
else {
|
|
||||||
READ_STR(data->store, info, len);
|
|
||||||
if (unicode_utf8_trim(info) != 0) {
|
|
||||||
log_warning("trim region %d info to '%s'", r->uid, info);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1288,16 +1277,11 @@ struct building *read_building(gamedata *data) {
|
||||||
log_warning("trim building %s name to '%s'", itoa36(b->no), name);
|
log_warning("trim building %s name to '%s'", itoa36(b->no), name);
|
||||||
}
|
}
|
||||||
b->name = strdup(name);
|
b->name = strdup(name);
|
||||||
if (lomem) {
|
READ_STR(store, name, sizeof(name));
|
||||||
READ_STR(store, NULL, 0);
|
if (unicode_utf8_trim(name)!=0) {
|
||||||
}
|
log_warning("trim building %s info to '%s'", itoa36(b->no), name);
|
||||||
else {
|
|
||||||
READ_STR(store, name, sizeof(name));
|
|
||||||
if (unicode_utf8_trim(name)!=0) {
|
|
||||||
log_warning("trim building %s info to '%s'", itoa36(b->no), name);
|
|
||||||
}
|
|
||||||
b->display = strdup(name);
|
|
||||||
}
|
}
|
||||||
|
b->display = strdup(name);
|
||||||
READ_INT(store, &b->size);
|
READ_INT(store, &b->size);
|
||||||
READ_STR(store, name, sizeof(name));
|
READ_STR(store, name, sizeof(name));
|
||||||
b->type = bt_find(name);
|
b->type = bt_find(name);
|
||||||
|
@ -1347,16 +1331,11 @@ ship *read_ship(gamedata *data)
|
||||||
log_warning("trim ship %s name to '%s'", itoa36(sh->no), name);
|
log_warning("trim ship %s name to '%s'", itoa36(sh->no), name);
|
||||||
}
|
}
|
||||||
sh->name = strdup(name);
|
sh->name = strdup(name);
|
||||||
if (lomem) {
|
READ_STR(store, name, sizeof(name));
|
||||||
READ_STR(store, NULL, 0);
|
if (unicode_utf8_trim(name)!=0) {
|
||||||
}
|
log_warning("trim ship %s info to '%s'", itoa36(sh->no), name);
|
||||||
else {
|
|
||||||
READ_STR(store, name, sizeof(name));
|
|
||||||
if (unicode_utf8_trim(name)!=0) {
|
|
||||||
log_warning("trim ship %s info to '%s'", itoa36(sh->no), name);
|
|
||||||
}
|
|
||||||
sh->display = strdup(name);
|
|
||||||
}
|
}
|
||||||
|
sh->display = strdup(name);
|
||||||
READ_STR(store, name, sizeof(name));
|
READ_STR(store, name, sizeof(name));
|
||||||
sh->type = st_find(name);
|
sh->type = st_find(name);
|
||||||
if (sh->type == NULL) {
|
if (sh->type == NULL) {
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
#include <kernel/config.h>
|
#include <kernel/config.h>
|
||||||
|
#include <kernel/race.h>
|
||||||
#include <util/attrib.h>
|
#include <util/attrib.h>
|
||||||
#include <util/gamedata.h>
|
#include <util/gamedata.h>
|
||||||
#include <attributes/key.h>
|
#include <attributes/key.h>
|
||||||
|
@ -51,6 +52,7 @@ static void test_readwrite_unit(CuTest * tc)
|
||||||
struct unit *u;
|
struct unit *u;
|
||||||
struct region *r;
|
struct region *r;
|
||||||
struct faction *f;
|
struct faction *f;
|
||||||
|
struct race *irace;
|
||||||
int fno;
|
int fno;
|
||||||
|
|
||||||
test_setup();
|
test_setup();
|
||||||
|
@ -60,6 +62,12 @@ static void test_readwrite_unit(CuTest * tc)
|
||||||
u = test_create_unit(f, r);
|
u = test_create_unit(f, r);
|
||||||
unit_setname(u, " Hodor ");
|
unit_setname(u, " Hodor ");
|
||||||
CuAssertStrEquals(tc, " Hodor ", u->_name);
|
CuAssertStrEquals(tc, " Hodor ", u->_name);
|
||||||
|
enable_skill(SK_STEALTH, false);
|
||||||
|
irace = test_create_race("halfling");
|
||||||
|
CuAssertTrue(tc, playerrace(irace));
|
||||||
|
u->irace = irace;
|
||||||
|
CuAssertTrue(tc, irace == u_irace(u));
|
||||||
|
|
||||||
mstream_init(&data.strm);
|
mstream_init(&data.strm);
|
||||||
gamedata_init(&data, &store, RELEASE_VERSION);
|
gamedata_init(&data, &store, RELEASE_VERSION);
|
||||||
write_unit(&data, u);
|
write_unit(&data, u);
|
||||||
|
@ -74,6 +82,7 @@ static void test_readwrite_unit(CuTest * tc)
|
||||||
CuAssertPtrNotNull(tc, u);
|
CuAssertPtrNotNull(tc, u);
|
||||||
CuAssertPtrEquals(tc, f, u->faction);
|
CuAssertPtrEquals(tc, f, u->faction);
|
||||||
CuAssertStrEquals(tc, "Hodor", u->_name);
|
CuAssertStrEquals(tc, "Hodor", u->_name);
|
||||||
|
CuAssertTrue(tc, irace == u_irace(u));
|
||||||
CuAssertPtrEquals(tc, 0, u->region);
|
CuAssertPtrEquals(tc, 0, u->region);
|
||||||
|
|
||||||
mstream_done(&data.strm);
|
mstream_done(&data.strm);
|
||||||
|
|
|
@ -1063,7 +1063,7 @@ void clone_men(const unit * u, unit * dst, int n)
|
||||||
transfer_curse(u, dst, n);
|
transfer_curse(u, dst, n);
|
||||||
}
|
}
|
||||||
set_number(dst, dst->number + n);
|
set_number(dst, dst->number + n);
|
||||||
dst->hp += u->hp * n / u->number;
|
dst->hp += (long long)u->hp * n / u->number;
|
||||||
assert(dst->hp >= dst->number);
|
assert(dst->hp >= dst->number);
|
||||||
/* TODO: Das ist schnarchlahm! und gehoert nicht hierhin */
|
/* TODO: Das ist schnarchlahm! und gehoert nicht hierhin */
|
||||||
a = a_find(dst->attribs, &at_effect);
|
a = a_find(dst->attribs, &at_effect);
|
||||||
|
|
|
@ -544,6 +544,25 @@ static void test_unlimited_units(CuTest *tc) {
|
||||||
test_cleanup();
|
test_cleanup();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void test_clone_men_bug_2386(CuTest *tc) {
|
||||||
|
unit *u1, *u2;
|
||||||
|
region *r;
|
||||||
|
faction *f;
|
||||||
|
|
||||||
|
test_setup();
|
||||||
|
r = test_create_region(0, 0, NULL);
|
||||||
|
f = test_create_faction(NULL);
|
||||||
|
u1 = test_create_unit(f, r);
|
||||||
|
scale_number(u1, 8237);
|
||||||
|
u1->hp = 39 * u1->number;
|
||||||
|
u2 = test_create_unit(f, r);
|
||||||
|
scale_number(u2, 0);
|
||||||
|
clone_men(u1, u2, 8100);
|
||||||
|
CuAssertIntEquals(tc, 8100, u2->number);
|
||||||
|
CuAssertIntEquals(tc, u2->number * 39, u2->hp);
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
static void test_clone_men(CuTest *tc) {
|
static void test_clone_men(CuTest *tc) {
|
||||||
unit *u1, *u2;
|
unit *u1, *u2;
|
||||||
region *r;
|
region *r;
|
||||||
|
@ -597,6 +616,9 @@ CuSuite *get_unit_suite(void)
|
||||||
SUITE_ADD_TEST(suite, test_unit_name_from_race);
|
SUITE_ADD_TEST(suite, test_unit_name_from_race);
|
||||||
SUITE_ADD_TEST(suite, test_update_monster_name);
|
SUITE_ADD_TEST(suite, test_update_monster_name);
|
||||||
SUITE_ADD_TEST(suite, test_clone_men);
|
SUITE_ADD_TEST(suite, test_clone_men);
|
||||||
|
SUITE_ADD_TEST(suite, test_clone_men_bug_2386);
|
||||||
|
SUITE_ADD_TEST(suite, test_transfermen);
|
||||||
|
SUITE_ADD_TEST(suite, test_clone_men_bug_2386);
|
||||||
SUITE_ADD_TEST(suite, test_transfermen);
|
SUITE_ADD_TEST(suite, test_transfermen);
|
||||||
SUITE_ADD_TEST(suite, test_remove_unit);
|
SUITE_ADD_TEST(suite, test_remove_unit);
|
||||||
SUITE_ADD_TEST(suite, test_remove_empty_units);
|
SUITE_ADD_TEST(suite, test_remove_empty_units);
|
||||||
|
|
|
@ -1434,10 +1434,6 @@ static int parse_races(xmlDocPtr doc)
|
||||||
rc->flags |= RCF_DRAGON;
|
rc->flags |= RCF_DRAGON;
|
||||||
if (xml_bvalue(node, "shipspeed", false))
|
if (xml_bvalue(node, "shipspeed", false))
|
||||||
rc->flags |= RCF_SHIPSPEED;
|
rc->flags |= RCF_SHIPSPEED;
|
||||||
if (xml_bvalue(node, "stonegolem", false))
|
|
||||||
rc->flags |= RCF_STONEGOLEM;
|
|
||||||
if (xml_bvalue(node, "irongolem", false))
|
|
||||||
rc->flags |= RCF_IRONGOLEM;
|
|
||||||
|
|
||||||
if (xml_bvalue(node, "giveperson", false))
|
if (xml_bvalue(node, "giveperson", false))
|
||||||
rc->ec_flags |= ECF_GIVEPERSON;
|
rc->ec_flags |= ECF_GIVEPERSON;
|
||||||
|
@ -1449,6 +1445,10 @@ static int parse_races(xmlDocPtr doc)
|
||||||
rc->ec_flags |= ECF_REC_ETHEREAL;
|
rc->ec_flags |= ECF_REC_ETHEREAL;
|
||||||
if (xml_bvalue(node, "recruitunlimited", false))
|
if (xml_bvalue(node, "recruitunlimited", false))
|
||||||
rc->ec_flags |= ECF_REC_UNLIMITED;
|
rc->ec_flags |= ECF_REC_UNLIMITED;
|
||||||
|
if (xml_bvalue(node, "stonegolem", false))
|
||||||
|
rc->ec_flags |= ECF_STONEGOLEM;
|
||||||
|
if (xml_bvalue(node, "irongolem", false))
|
||||||
|
rc->ec_flags |= ECF_IRONGOLEM;
|
||||||
|
|
||||||
if (xml_bvalue(node, "equipment", false))
|
if (xml_bvalue(node, "equipment", false))
|
||||||
rc->battle_flags |= BF_EQUIPMENT; /* TODO: invert this flag, so rc_get_or_create gets simpler */
|
rc->battle_flags |= BF_EQUIPMENT; /* TODO: invert this flag, so rc_get_or_create gets simpler */
|
||||||
|
|
|
@ -87,5 +87,6 @@ extern "C"
|
||||||
const char *keyword(keyword_t kwd);
|
const char *keyword(keyword_t kwd);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -62,7 +62,6 @@ static void load_inifile(void)
|
||||||
set_datapath(str);
|
set_datapath(str);
|
||||||
}
|
}
|
||||||
|
|
||||||
lomem = config_get_int("game.lomem", lomem) ? 1 : 0;
|
|
||||||
verbosity = config_get_int("game.verbose", 2);
|
verbosity = config_get_int("game.verbose", 2);
|
||||||
memdebug = config_get_int("game.memcheck", memdebug);
|
memdebug = config_get_int("game.memcheck", memdebug);
|
||||||
#ifdef USE_CURSES
|
#ifdef USE_CURSES
|
||||||
|
@ -79,7 +78,6 @@ static const char * valid_keys[] = {
|
||||||
"game.locale",
|
"game.locale",
|
||||||
"game.verbose",
|
"game.verbose",
|
||||||
"game.report",
|
"game.report",
|
||||||
"game.lomem",
|
|
||||||
"game.memcheck",
|
"game.memcheck",
|
||||||
"game.email",
|
"game.email",
|
||||||
"game.mailcmd",
|
"game.mailcmd",
|
||||||
|
|
|
@ -155,7 +155,7 @@ newfaction *read_newfactions(const char *filename)
|
||||||
email[0] = '\0';
|
email[0] = '\0';
|
||||||
password[0] = '\0';
|
password[0] = '\0';
|
||||||
|
|
||||||
if (sscanf(buf, "%54s %20s %8s %16s %d %d", email, race, lang,
|
if (sscanf(buf, "%54s %19s %7s %15s %d %d", email, race, lang,
|
||||||
password, &subscription, &alliance) < 3) {
|
password, &subscription, &alliance) < 3) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,7 +9,7 @@
|
||||||
* based on:
|
* based on:
|
||||||
*
|
*
|
||||||
* Atlantis v1.0 13 September 1993 Copyright 1993 by Russell Wallace
|
* Atlantis v1.0 13 September 1993 Copyright 1993 by Russell Wallace
|
||||||
* Atlantis v1.7 Copyright 1996 by Alex Schröder
|
* Atlantis v1.7 Copyright 1996 by Alex Schr<EFBFBD>der
|
||||||
*
|
*
|
||||||
* This program may not be used, modified or distributed without
|
* This program may not be used, modified or distributed without
|
||||||
* prior permission by the authors of Eressea.
|
* prior permission by the authors of Eressea.
|
||||||
|
@ -74,7 +74,7 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
|
|
||||||
#define DRAGON_RANGE 20 /* max. Distanz zum nächsten Drachenziel */
|
#define DRAGON_RANGE 20 /* max. Distanz zum n<EFBFBD>chsten Drachenziel */
|
||||||
#define MOVE_PERCENT 25 /* chance fuer bewegung */
|
#define MOVE_PERCENT 25 /* chance fuer bewegung */
|
||||||
#define MAXILLUSION_TEXTS 3
|
#define MAXILLUSION_TEXTS 3
|
||||||
|
|
||||||
|
@ -359,11 +359,11 @@ static direction_t random_neighbour(region * r, unit * u)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Zufällig eine auswählen */
|
/* Zuf<EFBFBD>llig eine ausw<73>hlen */
|
||||||
|
|
||||||
rr = rng_int() % c;
|
rr = rng_int() % c;
|
||||||
|
|
||||||
/* Durchzählen */
|
/* Durchz<EFBFBD>hlen */
|
||||||
|
|
||||||
c = 0;
|
c = 0;
|
||||||
for (i = 0; i != MAXDIRECTIONS; i++) {
|
for (i = 0; i != MAXDIRECTIONS; i++) {
|
||||||
|
@ -400,11 +400,11 @@ static direction_t treeman_neighbour(region * r)
|
||||||
if (c == 0) {
|
if (c == 0) {
|
||||||
return NODIRECTION;
|
return NODIRECTION;
|
||||||
}
|
}
|
||||||
/* Zufällig eine auswählen */
|
/* Zuf<EFBFBD>llig eine ausw<73>hlen */
|
||||||
|
|
||||||
rr = rng_int() % c;
|
rr = rng_int() % c;
|
||||||
|
|
||||||
/* Durchzählen */
|
/* Durchz<EFBFBD>hlen */
|
||||||
|
|
||||||
c = -1;
|
c = -1;
|
||||||
for (i = 0; i != MAXDIRECTIONS; i++) {
|
for (i = 0; i != MAXDIRECTIONS; i++) {
|
||||||
|
@ -559,7 +559,7 @@ static order *monster_learn(unit * u)
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Monster lernt ein zufälliges Talent aus allen, in denen es schon
|
/* Monster lernt ein zuf<EFBFBD>lliges Talent aus allen, in denen es schon
|
||||||
* Lerntage hat. */
|
* Lerntage hat. */
|
||||||
for (sv = u->skills; sv != u->skills + u->skill_size; ++sv) {
|
for (sv = u->skills; sv != u->skills + u->skill_size; ++sv) {
|
||||||
if (sv->level > 0)
|
if (sv->level > 0)
|
||||||
|
@ -605,7 +605,6 @@ static void recruit_dracoids(unit * dragon, int size)
|
||||||
faction *f = dragon->faction;
|
faction *f = dragon->faction;
|
||||||
region *r = dragon->region;
|
region *r = dragon->region;
|
||||||
const struct item *weapon = NULL;
|
const struct item *weapon = NULL;
|
||||||
order *new_order = NULL;
|
|
||||||
unit *un = create_unit(r, f, size, get_race(RC_DRACOID), 0, NULL, NULL);
|
unit *un = create_unit(r, f, size, get_race(RC_DRACOID), 0, NULL, NULL);
|
||||||
|
|
||||||
fset(un, UFL_ISNEW | UFL_MOVED);
|
fset(un, UFL_ISNEW | UFL_MOVED);
|
||||||
|
@ -617,15 +616,10 @@ static void recruit_dracoids(unit * dragon, int size)
|
||||||
setstatus(un, ST_FIGHT);
|
setstatus(un, ST_FIGHT);
|
||||||
for (weapon = un->items; weapon; weapon = weapon->next) {
|
for (weapon = un->items; weapon; weapon = weapon->next) {
|
||||||
const weapon_type *wtype = weapon->type->rtype->wtype;
|
const weapon_type *wtype = weapon->type->rtype->wtype;
|
||||||
if (wtype && (wtype->flags & WTF_MISSILE)) {
|
if (wtype && wtype->flags & WTF_MISSILE) {
|
||||||
setstatus(un, ST_BEHIND);
|
setstatus(un, ST_BEHIND);
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
new_order = create_order(K_STUDY, f->locale, "'%s'",
|
|
||||||
skillname(weapon->type->rtype->wtype->skill, f->locale));
|
|
||||||
}
|
|
||||||
|
|
||||||
if (new_order != NULL) {
|
|
||||||
addlist(&un->orders, new_order);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -653,7 +647,7 @@ static order *plan_dragon(unit * u)
|
||||||
if (rc == rc_wyrm && !move) {
|
if (rc == rc_wyrm && !move) {
|
||||||
unit *u2;
|
unit *u2;
|
||||||
for (u2 = r->units; u2; u2 = u2->next) {
|
for (u2 = r->units; u2; u2 = u2->next) {
|
||||||
/* wyrme sind einzelgänger */
|
/* wyrme sind einzelg<EFBFBD>nger */
|
||||||
if (u2 == u) {
|
if (u2 == u) {
|
||||||
/* we do not make room for newcomers, so we don't need to look at them */
|
/* we do not make room for newcomers, so we don't need to look at them */
|
||||||
break;
|
break;
|
||||||
|
@ -750,11 +744,11 @@ void plan_monsters(faction * f)
|
||||||
attrib *ta;
|
attrib *ta;
|
||||||
order *long_order = NULL;
|
order *long_order = NULL;
|
||||||
|
|
||||||
/* Ab hier nur noch Befehle für NPC-Einheiten. */
|
/* Ab hier nur noch Befehle f<EFBFBD>r NPC-Einheiten. */
|
||||||
if (u->faction!=f)
|
if (u->faction!=f)
|
||||||
continue;
|
continue;
|
||||||
|
|
||||||
/* Befehle müssen jede Runde neu gegeben werden: */
|
/* Befehle m<EFBFBD>ssen jede Runde neu gegeben werden: */
|
||||||
free_orders(&u->orders);
|
free_orders(&u->orders);
|
||||||
if (skill_enabled(SK_PERCEPTION)) {
|
if (skill_enabled(SK_PERCEPTION)) {
|
||||||
/* Monster bekommen jede Runde ein paar Tage Wahrnehmung dazu */
|
/* Monster bekommen jede Runde ein paar Tage Wahrnehmung dazu */
|
||||||
|
@ -823,7 +817,7 @@ void plan_monsters(faction * f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (long_order == NULL && unit_can_study(u)) {
|
if (long_order == NULL && unit_can_study(u)) {
|
||||||
/* Einheiten, die Waffenlosen Kampf lernen könnten, lernen es um
|
/* Einheiten, die Waffenlosen Kampf lernen k<EFBFBD>nnten, lernen es um
|
||||||
* zu bewachen: */
|
* zu bewachen: */
|
||||||
if (rc->bonus[SK_WEAPONLESS] != -99) {
|
if (rc->bonus[SK_WEAPONLESS] != -99) {
|
||||||
if (effskill(u, SK_WEAPONLESS, 0) < 1) {
|
if (effskill(u, SK_WEAPONLESS, 0) < 1) {
|
||||||
|
@ -868,7 +862,7 @@ unit *spawn_seaserpent(region *r, faction *f) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Drachen und Seeschlangen können entstehen
|
* Drachen und Seeschlangen k<EFBFBD>nnen entstehen
|
||||||
*/
|
*/
|
||||||
void spawn_dragons(void)
|
void spawn_dragons(void)
|
||||||
{
|
{
|
||||||
|
@ -917,7 +911,7 @@ void spawn_dragons(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Untote können entstehen */
|
/** Untote k<EFBFBD>nnen entstehen */
|
||||||
void spawn_undead(void)
|
void spawn_undead(void)
|
||||||
{
|
{
|
||||||
region *r;
|
region *r;
|
||||||
|
@ -937,7 +931,7 @@ void spawn_undead(void)
|
||||||
message *msg;
|
message *msg;
|
||||||
unit *u;
|
unit *u;
|
||||||
/* es ist sinnfrei, wenn irgendwo im Wald 3er-Einheiten Untote entstehen.
|
/* es ist sinnfrei, wenn irgendwo im Wald 3er-Einheiten Untote entstehen.
|
||||||
* Lieber sammeln lassen, bis sie mindestens 5% der Bevölkerung sind, und
|
* Lieber sammeln lassen, bis sie mindestens 5% der Bev<EFBFBD>lkerung sind, und
|
||||||
* dann erst auferstehen. */
|
* dann erst auferstehen. */
|
||||||
int undead = unburied / (rng_int() % 2 + 1);
|
int undead = unburied / (rng_int() % 2 + 1);
|
||||||
const race *rc = NULL;
|
const race *rc = NULL;
|
||||||
|
@ -995,7 +989,7 @@ void spawn_undead(void)
|
||||||
else {
|
else {
|
||||||
int i = deathcount(r);
|
int i = deathcount(r);
|
||||||
if (i) {
|
if (i) {
|
||||||
/* Gräber verwittern, 3% der Untoten finden die ewige Ruhe */
|
/* Gr<EFBFBD>ber verwittern, 3% der Untoten finden die ewige Ruhe */
|
||||||
deathcounts(r, (int)(-i * 0.03));
|
deathcounts(r, (int)(-i * 0.03));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -101,7 +101,7 @@ static unit *unitorders(input *in, faction *f)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
/* Nun wird der Befehl erzeut und eingehängt */
|
/* Nun wird der Befehl erzeut und eingeh<EFBFBD>ngt */
|
||||||
*ordp = parse_order(s, u->faction->locale);
|
*ordp = parse_order(s, u->faction->locale);
|
||||||
if (*ordp) {
|
if (*ordp) {
|
||||||
ordp = &(*ordp)->next;
|
ordp = &(*ordp)->next;
|
||||||
|
@ -136,7 +136,7 @@ static faction *factionorders(void)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
/* Die Partei hat sich zumindest gemeldet, so dass sie noch
|
/* Die Partei hat sich zumindest gemeldet, so dass sie noch
|
||||||
* nicht als untätig gilt */
|
* nicht als unt<EFBFBD>tig gilt */
|
||||||
f->lastorders = turn;
|
f->lastorders = turn;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -151,6 +151,7 @@ int read_orders(input *in)
|
||||||
const char *b;
|
const char *b;
|
||||||
int nfactions = 0;
|
int nfactions = 0;
|
||||||
struct faction *f = NULL;
|
struct faction *f = NULL;
|
||||||
|
const struct locale *lang = default_locale;
|
||||||
|
|
||||||
/* TODO: recognize UTF8 BOM */
|
/* TODO: recognize UTF8 BOM */
|
||||||
b = in->getbuf(in->data);
|
b = in->getbuf(in->data);
|
||||||
|
@ -160,7 +161,6 @@ int read_orders(input *in)
|
||||||
|
|
||||||
while (b) {
|
while (b) {
|
||||||
char token[128];
|
char token[128];
|
||||||
const struct locale *lang = f ? f->locale : default_locale;
|
|
||||||
param_t p;
|
param_t p;
|
||||||
const char *s;
|
const char *s;
|
||||||
init_tokens_str(b);
|
init_tokens_str(b);
|
||||||
|
@ -171,6 +171,7 @@ int read_orders(input *in)
|
||||||
case P_FACTION:
|
case P_FACTION:
|
||||||
f = factionorders();
|
f = factionorders();
|
||||||
if (f) {
|
if (f) {
|
||||||
|
lang = f->locale;
|
||||||
++nfactions;
|
++nfactions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -200,12 +201,13 @@ int read_orders(input *in)
|
||||||
/* Falls in unitorders() abgebrochen wird, steht dort entweder eine neue
|
/* Falls in unitorders() abgebrochen wird, steht dort entweder eine neue
|
||||||
* Partei, eine neue Einheit oder das File-Ende. Das switch() wird erneut
|
* Partei, eine neue Einheit oder das File-Ende. Das switch() wird erneut
|
||||||
* durchlaufen, und die entsprechende Funktion aufgerufen. Man darf buf
|
* durchlaufen, und die entsprechende Funktion aufgerufen. Man darf buf
|
||||||
* auf alle Fälle nicht überschreiben! Bei allen anderen Einträgen hier
|
* auf alle F<EFBFBD>lle nicht <EFBFBD>berschreiben! Bei allen anderen Eintr<EFBFBD>gen hier
|
||||||
* muss buf erneut gefüllt werden, da die betreffende Information in nur
|
* muss buf erneut gef<EFBFBD>llt werden, da die betreffende Information in nur
|
||||||
* einer Zeile steht, und nun die nächste gelesen werden muss. */
|
* einer Zeile steht, und nun die n<EFBFBD>chste gelesen werden muss. */
|
||||||
|
|
||||||
case P_NEXT:
|
case P_NEXT:
|
||||||
f = NULL;
|
f = NULL;
|
||||||
|
lang = default_locale;
|
||||||
b = in->getbuf(in->data);
|
b = in->getbuf(in->data);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
|
|
@ -119,7 +119,12 @@ int a_readstring(attrib * a, void *owner, struct gamedata *data)
|
||||||
do {
|
do {
|
||||||
e = READ_STR(data->store, buf, sizeof(buf));
|
e = READ_STR(data->store, buf, sizeof(buf));
|
||||||
if (result) {
|
if (result) {
|
||||||
result = realloc(result, len + DISPLAYSIZE - 1);
|
char *tmp = realloc(result, len + DISPLAYSIZE - 1);
|
||||||
|
if (!tmp) {
|
||||||
|
free(result);
|
||||||
|
abort();
|
||||||
|
}
|
||||||
|
result = tmp;
|
||||||
strcpy(result + len, buf);
|
strcpy(result + len, buf);
|
||||||
len += DISPLAYSIZE - 1;
|
len += DISPLAYSIZE - 1;
|
||||||
}
|
}
|
||||||
|
|
|
@ -61,7 +61,7 @@ arg_type *find_argtype(const char *name)
|
||||||
message_type *mt_new(const char *name, const char *args[])
|
message_type *mt_new(const char *name, const char *args[])
|
||||||
{
|
{
|
||||||
int i, nparameters = 0;
|
int i, nparameters = 0;
|
||||||
message_type *mtype = (message_type *)malloc(sizeof(message_type));
|
message_type *mtype;
|
||||||
|
|
||||||
assert(name != NULL);
|
assert(name != NULL);
|
||||||
if (name == NULL) {
|
if (name == NULL) {
|
||||||
|
@ -72,6 +72,7 @@ message_type *mt_new(const char *name, const char *args[])
|
||||||
/* count the number of parameters */
|
/* count the number of parameters */
|
||||||
while (args[nparameters]) ++nparameters;
|
while (args[nparameters]) ++nparameters;
|
||||||
}
|
}
|
||||||
|
mtype = (message_type *)malloc(sizeof(message_type));
|
||||||
mtype->key = 0;
|
mtype->key = 0;
|
||||||
mtype->name = strdup(name);
|
mtype->name = strdup(name);
|
||||||
mtype->nparameters = nparameters;
|
mtype->nparameters = nparameters;
|
||||||
|
@ -143,13 +144,14 @@ static void free_arg(const arg_type * atype, variant data)
|
||||||
message *msg_create(const struct message_type *mtype, variant args[])
|
message *msg_create(const struct message_type *mtype, variant args[])
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
message *msg = (message *)malloc(sizeof(message));
|
message *msg;
|
||||||
|
|
||||||
assert(mtype != NULL);
|
assert(mtype != NULL);
|
||||||
if (mtype == NULL) {
|
if (mtype == NULL) {
|
||||||
log_error("Trying to create message with type=0x0\n");
|
log_error("Trying to create message with type=0x0\n");
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
msg = (message *)malloc(sizeof(message));
|
||||||
msg->type = mtype;
|
msg->type = mtype;
|
||||||
msg->parameters = (variant *)(mtype->nparameters ? calloc(mtype->nparameters, sizeof(variant)) : NULL);
|
msg->parameters = (variant *)(mtype->nparameters ? calloc(mtype->nparameters, sizeof(variant)) : NULL);
|
||||||
msg->refcount = 1;
|
msg->refcount = 1;
|
||||||
|
|
Loading…
Reference in a new issue