forked from github/server
make consistent use of get_group.
This commit is contained in:
parent
d7a8a9b406
commit
1e8c7224a4
7 changed files with 30 additions and 50 deletions
|
@ -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 */
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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,12 +294,9 @@ 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) {
|
return alliedgroup(u->faction, f2, g, mask);
|
||||||
group *g = (group *)a->data.v;
|
|
||||||
return alliedgroup(u->faction, f2, g, mask);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
return alliedfaction(u->faction, f2, mask);
|
return alliedfaction(u->faction, f2, mask);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
34
src/laws.c
34
src/laws.c
|
@ -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);
|
ap = &g->attribs;
|
||||||
if (a) {
|
}
|
||||||
group *g = (group *)a->data.v;
|
else {
|
||||||
ap = &g->attribs;
|
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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue