forked from github/server
make tests pass through valgrind
introduce more #ifdef LOMEM to bitfield structs.
This commit is contained in:
parent
5e835618f3
commit
68aa903130
5 changed files with 40 additions and 1 deletions
|
@ -21,7 +21,9 @@ static char *strip(char *str) {
|
|||
for (; *b && isspace(*b); ++b) {};
|
||||
for (e = b; *e && !isspace(*e); ++e) {};
|
||||
while (*b) {
|
||||
memcpy(s, b, e - b);
|
||||
if (s!=b) {
|
||||
memcpy(s, b, e - b);
|
||||
}
|
||||
s += e - b;
|
||||
for (b = e; *b && isspace(*b); ++b) {};
|
||||
for (e = b; *e && !isspace(*e); ++e) {};
|
||||
|
|
|
@ -117,8 +117,13 @@ extern "C" {
|
|||
typedef struct weapon {
|
||||
int count, used;
|
||||
const struct weapon_type *type;
|
||||
# ifdef LOMEM
|
||||
int attackskill:8;
|
||||
int defenseskill:8;
|
||||
# else
|
||||
int attackskill;
|
||||
int defenseskill;
|
||||
# endif
|
||||
} weapon;
|
||||
|
||||
/*** fighter::person::flags ***/
|
||||
|
@ -165,6 +170,7 @@ extern "C" {
|
|||
int catmsg; /* Merkt sich, ob Katapultmessage schon generiert. */
|
||||
struct person {
|
||||
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 */
|
||||
|
@ -174,6 +180,16 @@ extern "C" {
|
|||
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 defence;
|
||||
int damage;
|
||||
int damage_rear;
|
||||
int flags;
|
||||
int speed;
|
||||
int reload;
|
||||
int last_action;
|
||||
#endif
|
||||
struct weapon *missile; /* missile weapon */
|
||||
struct weapon *melee; /* melee weapon */
|
||||
} *person;
|
||||
|
|
|
@ -45,8 +45,13 @@ static int nlocales = 0;
|
|||
|
||||
typedef struct order_data {
|
||||
char *_str;
|
||||
# ifdef LOMEM
|
||||
int _refcount:20;
|
||||
int _lindex:4;
|
||||
# else
|
||||
int _refcount;
|
||||
int _lindex;
|
||||
# endif
|
||||
keyword_t _keyword;
|
||||
} order_data;
|
||||
|
||||
|
|
|
@ -22,12 +22,21 @@ extern "C" {
|
|||
|
||||
typedef struct rawmaterial {
|
||||
const struct rawmaterial_type *type;
|
||||
#ifdef LOMEM
|
||||
int amount:16;
|
||||
int level:8;
|
||||
int flags:8;
|
||||
int base:8;
|
||||
int divisor:8;
|
||||
int startlevel:8;
|
||||
#else
|
||||
int amount;
|
||||
int level;
|
||||
int flags;
|
||||
int base;
|
||||
int divisor;
|
||||
int startlevel;
|
||||
#endif
|
||||
struct rawmaterial *next;
|
||||
} rawmaterial;
|
||||
|
||||
|
|
|
@ -25,10 +25,17 @@ extern "C" {
|
|||
#define SMF_RIDING (1<<2) /* Bonus für berittene - an der rasse */
|
||||
|
||||
typedef struct skill {
|
||||
#ifdef LOMEM
|
||||
int id:8;
|
||||
unsigned int level:8;
|
||||
unsigned int weeks:8;
|
||||
unsigned int old:8;
|
||||
#else
|
||||
int id;
|
||||
unsigned int level;
|
||||
unsigned int weeks;
|
||||
unsigned int old;
|
||||
#endif
|
||||
} skill;
|
||||
|
||||
typedef int (*skillmod_fun) (const struct unit *, const struct region *,
|
||||
|
|
Loading…
Reference in a new issue