use race::flags|RCF_NOGIVE instead of race::ec_flags|GIVEITEM

None of this has tests, it'd going to be years before a change like this can be made without fear D-:
This commit is contained in:
Enno Rehling 2014-07-05 23:31:34 -07:00
parent b21cb8f5c7
commit 5ec3f5b83a
10 changed files with 28 additions and 33 deletions

View file

@ -776,7 +776,7 @@ static void give_cmd(unit * u, order * ord)
else if (p == P_HERBS) {
bool given = false;
if (!(u_race(u)->ec_flags & GIVEITEM) && u2 != NULL) {
if (fval(u_race(u), RCF_NOGIVE) && u2 != NULL) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, ord, "race_nogive", "race", u_race(u)));
return;
@ -847,7 +847,7 @@ static void give_cmd(unit * u, order * ord)
if (*s == 0) { /* GIVE ALL items that you have */
/* do these checks once, not for each item we have: */
if (!(u_race(u)->ec_flags & GIVEITEM) && u2 != NULL) {
if (fval(u_race(u), RCF_NOGIVE) && u2 != NULL) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, ord, "race_nogive", "race", u_race(u)));
return;
@ -885,7 +885,8 @@ static void give_cmd(unit * u, order * ord)
n = u->number;
give_men(n, u, u2, ord);
}
} else if (!(u_race(u)->ec_flags & GIVEITEM) && u2 != NULL) {
}
else if (fval(u_race(u), RCF_NOGIVE) && u2 != NULL) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, ord, "race_nogive", "race", u_race(u)));
} else if (u2 && !(u_race(u2)->ec_flags & GETITEM)) {
@ -935,7 +936,7 @@ static void give_cmd(unit * u, order * ord)
}
if (u2 != NULL) {
if (!(u_race(u)->ec_flags & GIVEITEM) && u2 != NULL) {
if (fval(u_race(u), RCF_NOGIVE) && u2 != NULL) {
ADDMSG(&u->faction->msgs,
msg_feedback(u, ord, "race_nogive", "race", u_race(u)));
return;

View file

@ -214,7 +214,7 @@ int armedmen(const unit * u, bool siege_weapons)
{
item *itm;
int n = 0;
if (!(urace(u)->flags & RCF_NOWEAPONS)) {
if (!fval(u_race(u), RCF_NOWEAPONS)) {
if (effskill(u, SK_WEAPONLESS) >= 1) {
/* kann ohne waffen bewachen: fuer drachen */
n = u->number;
@ -784,7 +784,7 @@ weapon_effskill(troop t, troop enemy, const weapon * w, bool attacking,
skill += CavalryBonus(tu, enemy, BONUS_SKILL);
if (wtype)
skill =
skillmod(urace(tu)->attribs, tu, tu->region, wtype->skill, skill,
skillmod(u_race(tu)->attribs, tu, tu->region, wtype->skill, skill,
SMF_RIDING);
}

View file

@ -332,7 +332,8 @@ static void json_race(cJSON *json, race *rc) {
"noteach", "horse", "desert",
"illusionary", "absorbpeasants", "noheal",
"noweapons", "shapeshift", "", "undead", "dragon",
"coastal", "", "cansail", 0
"coastal", "", "cansail", "invisible", "shipspeed",
"stonegolem", "irongolem", "nogive", 0
};
if (json->type!=cJSON_Object) {
log_error_n("race %s is not a json object: %d", json->string, json->type);

View file

@ -39,6 +39,7 @@ static void test_flags(CuTest *tc) {
check_flag(tc, "undead", RCF_UNDEAD);
check_flag(tc, "dragon", RCF_DRAGON);
check_flag(tc, "fly", RCF_FLY);
check_flag(tc, "nogive", RCF_NOGIVE);
test_cleanup();
}

View file

@ -182,7 +182,7 @@ get_pooled(const unit * u, const resource_type * rtype, unsigned int mode,
if (v->items == NULL && rtype->uget == NULL)
continue;
if ((urace(v)->ec_flags & GIVEITEM) == 0)
if (fval(u_race(v), RCF_NOGIVE))
continue;
if (v->faction == f) {
@ -232,7 +232,7 @@ use_pooled(unit * u, const resource_type * rtype, unsigned int mode, int count)
for (v = r->units; use > 0 && v != NULL; v = v->next)
if (u != v) {
int mask;
if ((urace(v)->ec_flags & GIVEITEM) == 0)
if (fval(u_race(v), RCF_NOGIVE))
continue;
if (v->items == NULL && rtype->uget == NULL)
continue;

View file

@ -213,6 +213,7 @@ extern "C" {
#define RCF_SHIPSPEED (1<<26) /* race gets +1 on shipspeed */
#define RCF_STONEGOLEM (1<<27) /* race gets stonegolem properties */
#define RCF_IRONGOLEM (1<<28) /* race gets irongolem properties */
#define RCF_NOGIVE (1<<29) /* will not GIVE anything away */
/* Economic flags */
#define GIVEITEM (1<<1) /* gibt Gegenstände weg */

View file

@ -196,10 +196,9 @@ static buddy *get_friends(const unit * u, int *numfriends)
nf->unit = u2;
nf->number = 0;
*fr = nf;
} else if (nf->faction == u2->faction
&& (u_race(u2)->ec_flags & GIVEITEM)) {
} else if (nf->faction == u2->faction && !fval(u_race(u2), RCF_NOGIVE)) {
/* we don't like to gift it to units that won't give it back */
if ((u_race(nf->unit)->ec_flags & GIVEITEM) == 0) {
if (fval(u_race(nf->unit), RCF_NOGIVE)) {
nf->unit = u2;
}
}
@ -226,7 +225,7 @@ int gift_items(unit * u, int flags)
item **itm_p = &u->items;
int retval = 0;
int rule = rule_give();
assert(u->region);
assert(u->faction);
@ -239,20 +238,20 @@ int gift_items(unit * u, int flags)
flags -= GIFT_SELF;
}
if (u->items == NULL || fval(u_race(u), RCF_ILLUSIONARY))
return 0;
if ((u_race(u)->ec_flags & GIVEITEM) == 0)
if (u->items == NULL || fval(u_race(u), RCF_ILLUSIONARY) || fval(u_race(u), RCF_NOGIVE)) {
return 0;
}
/* at first, I should try giving my crap to my own units in this region */
if (u->faction && (u->faction->flags & FFL_QUIT) == 0 && (flags & GIFT_SELF)) {
unit *u2, *u3 = NULL;
for (u2 = r->units; u2; u2 = u2->next) {
if (u2 != u && u2->faction == u->faction && u2->number > 0) {
const race * rc = u_race(u2);
/* some units won't take stuff: */
if (u_race(u2)->ec_flags & GETITEM) {
if (rc->ec_flags & GETITEM) {
/* we don't like to gift it to units that won't give it back */
if (u_race(u2)->ec_flags & GIVEITEM) {
if (!fval(rc, RCF_NOGIVE)) {
i_merge(&u2->items, &u->items);
u->items = NULL;
break;
@ -861,11 +860,6 @@ bool leave(unit * u, bool force)
return true;
}
const struct race *urace(const struct unit *u)
{
return u->race_;
}
bool can_survive(const unit * u, const region * r)
{
if ((fval(r->terrain, WALK_INTO) && (u_race(u)->flags & RCF_WALK))

View file

@ -141,8 +141,6 @@ extern "C" {
struct unit *utarget(const struct unit *u);
void usettarget(struct unit *u, const struct unit *b);
extern const struct race *urace(const struct unit *u);
const char *uprivate(const struct unit *u);
void usetprivate(struct unit *u, const char *c);

View file

@ -1721,8 +1721,9 @@ static int parse_races(xmlDocPtr doc)
if (xml_bvalue(node, "irongolem", false))
rc->flags |= RCF_IRONGOLEM;
if (xml_bvalue(node, "giveitem", false))
rc->ec_flags |= GIVEITEM;
if (xml_bvalue(node, "giveitem", false)) {
rc->flags |= RCF_NOGIVE;
}
if (xml_bvalue(node, "giveperson", false))
rc->ec_flags |= GIVEPERSON;
if (xml_bvalue(node, "giveunit", false))

View file

@ -138,9 +138,7 @@ static void checkorders(void)
static bool help_money(const unit * u)
{
if (u_race(u)->ec_flags & GIVEITEM)
return true;
return false;
return !fval(u_race(u), RCF_NOGIVE);
}
static void help_feed(unit * donor, unit * u, int *need_p)
@ -3263,7 +3261,7 @@ static building *age_building(building * b)
bt_blessed = bt_find("blessedstonecircle");
ct_astralblock = ct_find("astralblock");
/* blesses stone circles create an astral protection in the astral region
/* blessed stone circles create an astral protection in the astral region
* above the shield, which prevents chaos suction and other spells.
* The shield is created when a magician enters the blessed stone circle,
* and lasts for as long as his skill level / 2 is, at no mana cost.
@ -3279,7 +3277,7 @@ static building *age_building(building * b)
* find out if there's a magician in there. */
for (u = r->units; u; u = u->next) {
if (b == u->building && inside_building(u)) {
if (!(u_race(u)->ec_flags & GIVEITEM) == 0) {
if (!fval(u_race(u), RCF_NOGIVE)) {
int n, unicorns = 0;
for (n = 0; n != u->number; ++n) {
if (chance(0.02)) {
@ -4041,7 +4039,7 @@ int pay_cmd(unit * u, struct order *ord)
int reserve_cmd(unit * u, struct order *ord)
{
if (u->number > 0 && (urace(u)->ec_flags & GETITEM)) {
if (u->number > 0 && (u_race(u)->ec_flags & GETITEM)) {
int use, count;
const resource_type *rtype;
const char *s;