make consistent use of get_group.

This commit is contained in:
Enno Rehling 2018-10-26 22:12:43 +02:00
parent d7a8a9b406
commit 1e8c7224a4
7 changed files with 30 additions and 50 deletions

View file

@ -3108,9 +3108,7 @@ fighter *make_fighter(battle * b, unit * u, side * s1, bool attack)
if (fval(u, UFL_ANON_FACTION) != 0) if (fval(u, UFL_ANON_FACTION) != 0)
flags |= SIDE_STEALTH; flags |= SIDE_STEALTH;
if (!(AllianceAuto() & HELP_FIGHT) && fval(u, UFL_GROUP)) { if (!(AllianceAuto() & HELP_FIGHT) && fval(u, UFL_GROUP)) {
const attrib *agroup = a_find(u->attribs, &at_group); g = get_group(u);
if (agroup != NULL)
g = (const group *)agroup->data.v;
} }
/* Illusionen und Zauber kaempfen nicht */ /* Illusionen und Zauber kaempfen nicht */

View file

@ -799,13 +799,11 @@ void cr_output_unit(stream *out, const faction * f,
} }
if (u->faction == f) { if (u->faction == f) {
const attrib *a = NULL;
unit *mage; unit *mage;
group * g;
if (fval(u, UFL_GROUP)) g = get_group(u);
a = a_find(u->attribs, &at_group); if (g) {
if (a != NULL) {
const group *g = (const group *)a->data.v;
stream_printf(out, "%d;gruppe\n", g->gid); stream_printf(out, "%d;gruppe\n", g->gid);
} }
mage = get_familiar_mage(u); mage = get_familiar_mage(u);

View file

@ -282,6 +282,8 @@ int alliedunit(const unit * u, const faction * f2, int mask)
return 0; return 0;
} }
if (u->faction != NULL && f2 != NULL) { if (u->faction != NULL && f2 != NULL) {
group *g;
if (mask & HELP_FIGHT) { if (mask & HELP_FIGHT) {
if ((u->flags & UFL_DEFENDER) || (u->faction->flags & FFL_DEFENDER)) { if ((u->flags & UFL_DEFENDER) || (u->faction->flags & FFL_DEFENDER)) {
faction *owner = region_get_owner(u->region); faction *owner = region_get_owner(u->region);
@ -292,13 +294,10 @@ int alliedunit(const unit * u, const faction * f2, int mask)
} }
} }
if (fval(u, UFL_GROUP)) { g = get_group(u);
const attrib *a = a_find(u->attribs, &at_group); if (g) {
if (a != NULL) {
group *g = (group *)a->data.v;
return alliedgroup(u->faction, f2, g, mask); return alliedgroup(u->faction, f2, g, mask);
} }
}
return alliedfaction(u->faction, f2, mask); return alliedfaction(u->faction, f2, mask);
} }
return 0; return 0;

View file

@ -531,14 +531,9 @@ const char *rc_name_s(const race * rc, name_t n)
const char *raceprefix(const unit * u) const char *raceprefix(const unit * u)
{ {
attrib *asource = u->faction->attribs; group *g = get_group(u);
attrib *attr = g ? g->attribs : u->faction->attribs;
if (fval(u, UFL_GROUP)) { return get_prefix(attr);
attrib *agroup = a_find(u->attribs, &at_group);
if (agroup != NULL)
asource = ((const group *)(agroup->data.v))->attribs;
}
return get_prefix(asource);
} }
const char *racename(const struct locale *loc, const unit * u, const race * rc) const char *racename(const struct locale *loc, const unit * u, const race * rc)

View file

@ -1454,10 +1454,9 @@ unit *create_unit(region * r, faction * f, int number, const struct race *urace,
} }
/* Gruppen */ /* Gruppen */
if (creator->faction == f && fval(creator, UFL_GROUP)) { if (creator->faction == f) {
a = a_find(creator->attribs, &at_group); group *g = get_group(creator);
if (a) { if (g) {
group *g = (group *)a->data.v;
set_group(u, g); set_group(u, g);
} }
} }

View file

@ -1317,9 +1317,9 @@ int ally_cmd(unit * u, struct order *ord)
sfp = &u->faction->allies; sfp = &u->faction->allies;
if (fval(u, UFL_GROUP)) { if (fval(u, UFL_GROUP)) {
attrib *a = a_find(u->attribs, &at_group); group *g = get_group(u);
if (a) { if (g) {
sfp = &((group *)a->data.v)->allies; sfp = &g->allies;
} }
} }
@ -1453,12 +1453,8 @@ int prefix_cmd(unit * u, struct order *ord)
s = gettoken(token, sizeof(token)); s = gettoken(token, sizeof(token));
if (!s || !*s) { if (!s || !*s) {
attrib *a = NULL; group *g = get_group(u);
if (fval(u, UFL_GROUP)) { if (g) {
a = a_find(u->attribs, &at_group);
}
if (a) {
group *g = (group *)a->data.v;
a_removeall(&g->attribs, &at_raceprefix); a_removeall(&g->attribs, &at_raceprefix);
} }
else { else {
@ -1473,13 +1469,12 @@ int prefix_cmd(unit * u, struct order *ord)
cmistake(u, ord, 299, MSG_EVENT); cmistake(u, ord, 299, MSG_EVENT);
} }
else { else {
ap = &u->faction->attribs; group *g = get_group(u);
if (fval(u, UFL_GROUP)) { if (g) {
attrib *a = a_find(u->attribs, &at_group);
if (a) {
group *g = (group *)a->data.v;
ap = &g->attribs; ap = &g->attribs;
} }
else {
ap = &u->faction->attribs;
} }
set_prefix(ap, race_prefixes[var.i]); set_prefix(ap, race_prefixes[var.i]);
} }
@ -1839,11 +1834,8 @@ int name_cmd(struct unit *u, struct order *ord)
case P_GROUP: case P_GROUP:
{ {
attrib *a = NULL; group *g = get_group(u);
if (fval(u, UFL_GROUP)) if (g) {
a = a_find(u->attribs, &at_group);
if (a) {
group *g = (group *)a->data.v;
s = &g->name; s = &g->name;
break; break;
} }

View file

@ -697,9 +697,8 @@ bufunit(const faction * f, const unit * u, seen_mode mode, char *buf,
if (!isbattle) { if (!isbattle) {
if (u->faction == f) { if (u->faction == f) {
if (fval(u, UFL_GROUP)) { if (fval(u, UFL_GROUP)) {
attrib *a = a_find(u->attribs, &at_group); group *g = get_group(u);
if (a) { if (g) {
group *g = (group *)a->data.v;
bufp = STRLCPY(bufp, ", ", size); bufp = STRLCPY(bufp, ", ", size);
bufp = STRLCPY(bufp, groupid(g, f), size); bufp = STRLCPY(bufp, groupid(g, f), size);
} }