forked from github/server
"Blick in die Realität mit falschem Namen" - make invisible races disappear from the CR.
This commit is contained in:
parent
16c3b68114
commit
16d55c2eaf
6 changed files with 11 additions and 7 deletions
|
@ -664,6 +664,8 @@ cr_output_unit(FILE * F, const region * r,
|
||||||
static const curse_type * itemcloak_ct = 0;
|
static const curse_type * itemcloak_ct = 0;
|
||||||
static boolean init = false;
|
static boolean init = false;
|
||||||
|
|
||||||
|
if (fval(u->race, RCF_INVISIBLE)) return;
|
||||||
|
|
||||||
if (!init) {
|
if (!init) {
|
||||||
init = true;
|
init = true;
|
||||||
itemcloak_ct = ct_find("itemcloak");
|
itemcloak_ct = ct_find("itemcloak");
|
||||||
|
|
|
@ -659,7 +659,7 @@ rpunit(FILE * F, const faction * f, const unit * u, int indent, int mode)
|
||||||
boolean isbattle = (boolean)(mode == see_battle);
|
boolean isbattle = (boolean)(mode == see_battle);
|
||||||
char buf[8192];
|
char buf[8192];
|
||||||
|
|
||||||
if (u->race == new_race[RC_SPELL]) return;
|
if (fval(u->race, RCF_INVISIBLE)) return;
|
||||||
|
|
||||||
{
|
{
|
||||||
rnl(F);
|
rnl(F);
|
||||||
|
@ -1181,7 +1181,7 @@ statistics(FILE * F, const region * r, const faction * f)
|
||||||
|
|
||||||
/* count */
|
/* count */
|
||||||
for (u = r->units; u; u = u->next) {
|
for (u = r->units; u; u = u->next) {
|
||||||
if (u->faction == f && u->race != new_race[RC_SPELL]) {
|
if (u->faction == f && !fval(u->race, RCF_INVISIBLE)) {
|
||||||
for (itm=u->items;itm;itm=itm->next) {
|
for (itm=u->items;itm;itm=itm->next) {
|
||||||
i_change(&items, itm->type, itm->number);
|
i_change(&items, itm->type, itm->number);
|
||||||
}
|
}
|
||||||
|
@ -1391,7 +1391,7 @@ report_template(const char * filename, report_context * ctx, const char * charse
|
||||||
if (sr->mode<see_unit) continue;
|
if (sr->mode<see_unit) continue;
|
||||||
|
|
||||||
for (u = r->units; u; u = u->next) {
|
for (u = r->units; u; u = u->next) {
|
||||||
if (u->faction == f && u->race != new_race[RC_SPELL]) {
|
if (u->faction == f && !fval(u->race, RCF_INVISIBLE)) {
|
||||||
order * ord;
|
order * ord;
|
||||||
if (!dh) {
|
if (!dh) {
|
||||||
rps_nowrap(F, "");
|
rps_nowrap(F, "");
|
||||||
|
|
|
@ -1040,7 +1040,7 @@ cansee(const faction * f, const region * r, const unit * u, int modifier)
|
||||||
|
|
||||||
if (u->faction == f || omniscient(f)) {
|
if (u->faction == f || omniscient(f)) {
|
||||||
return true;
|
return true;
|
||||||
} else if (u->race == new_race[RC_SPELL]) {
|
} else if (fval(u->race, RCF_INVISIBLE)) {
|
||||||
return false;
|
return false;
|
||||||
} else if (u->number == 0) {
|
} else if (u->number == 0) {
|
||||||
attrib *a = a_find(u->attribs, &at_creator);
|
attrib *a = a_find(u->attribs, &at_creator);
|
||||||
|
@ -1091,7 +1091,7 @@ boolean
|
||||||
cansee_unit(const unit * u, const unit * target, int modifier)
|
cansee_unit(const unit * u, const unit * target, int modifier)
|
||||||
/* target->region kann != u->region sein, wenn es um durchreisen geht */
|
/* target->region kann != u->region sein, wenn es um durchreisen geht */
|
||||||
{
|
{
|
||||||
if (target->race == new_race[RC_SPELL] || target->number == 0) return false;
|
if (fval(target->race, RCF_INVISIBLE) || target->number == 0) return false;
|
||||||
else if (target->faction == u->faction) return true;
|
else if (target->faction == u->faction) return true;
|
||||||
else {
|
else {
|
||||||
int n, rings, o;
|
int n, rings, o;
|
||||||
|
@ -1131,7 +1131,7 @@ cansee_durchgezogen(const faction * f, const region * r, const unit * u, int mod
|
||||||
int n;
|
int n;
|
||||||
unit *u2;
|
unit *u2;
|
||||||
|
|
||||||
if (u->race == new_race[RC_SPELL] || u->number == 0) return false;
|
if (fval(u->race, RCF_INVISIBLE) || u->number == 0) return false;
|
||||||
else if (u->faction == f) return true;
|
else if (u->faction == f) return true;
|
||||||
else {
|
else {
|
||||||
int rings;
|
int rings;
|
||||||
|
|
|
@ -133,6 +133,7 @@ extern int rc_specialdamage(const race *, const race *, const struct weapon_type
|
||||||
#define RCF_COASTAL (1<<22) /* kann in Landregionen an der Küste sein */
|
#define RCF_COASTAL (1<<22) /* kann in Landregionen an der Küste sein */
|
||||||
#define RCF_UNARMEDGUARD (1<<23) /* kann ohne Waffen bewachen */
|
#define RCF_UNARMEDGUARD (1<<23) /* kann ohne Waffen bewachen */
|
||||||
#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 */
|
||||||
|
|
||||||
/* Economic flags */
|
/* Economic flags */
|
||||||
#define NOGIVE (1<<0) /* gibt niemals nix */
|
#define NOGIVE (1<<0) /* gibt niemals nix */
|
||||||
|
|
|
@ -1473,6 +1473,7 @@ parse_races(xmlDocPtr doc)
|
||||||
if (xml_bvalue(node, "cansail", true)) rc->flags |= RCF_CANSAIL;
|
if (xml_bvalue(node, "cansail", true)) rc->flags |= RCF_CANSAIL;
|
||||||
if (xml_bvalue(node, "cannotmove", false)) rc->flags |= RCF_CANNOTMOVE;
|
if (xml_bvalue(node, "cannotmove", false)) rc->flags |= RCF_CANNOTMOVE;
|
||||||
if (xml_bvalue(node, "fly", false)) rc->flags |= RCF_FLY;
|
if (xml_bvalue(node, "fly", false)) rc->flags |= RCF_FLY;
|
||||||
|
if (xml_bvalue(node, "invisible", false)) rc->flags |= RCF_INVISIBLE;
|
||||||
if (xml_bvalue(node, "coastal", false)) rc->flags |= RCF_COASTAL;
|
if (xml_bvalue(node, "coastal", false)) rc->flags |= RCF_COASTAL;
|
||||||
if (xml_bvalue(node, "unarmedguard", false)) rc->flags |= RCF_UNARMEDGUARD;
|
if (xml_bvalue(node, "unarmedguard", false)) rc->flags |= RCF_UNARMEDGUARD;
|
||||||
if (xml_bvalue(node, "swim", false)) rc->flags |= RCF_SWIM;
|
if (xml_bvalue(node, "swim", false)) rc->flags |= RCF_SWIM;
|
||||||
|
|
|
@ -679,7 +679,7 @@
|
||||||
<skill name="weaponsmithing" modifier="14"/>
|
<skill name="weaponsmithing" modifier="14"/>
|
||||||
<attack type="4" damage="2d8+4"/>
|
<attack type="4" damage="2d8+4"/>
|
||||||
</race>
|
</race>
|
||||||
<race name="spell" magres="0.000000" maxaura="1.000000" regaura="0.100000" recruitcost="0" weight="0" capacity="0" speed="0.000000" hp="1" damage="1d4" unarmedattack="-2" unarmeddefense="-2" canlearn="no" noheal="yes" noweapons="yes" illusionary="yes" fly="yes" swim="yes" walk="yes">
|
<race name="spell" magres="0.000000" maxaura="1.000000" regaura="0.100000" recruitcost="0" weight="0" capacity="0" speed="0.000000" hp="1" damage="1d4" unarmedattack="-2" unarmeddefense="-2" canlearn="no" noheal="yes" noweapons="yes" illusionary="yes" invisible="yes" fly="yes" swim="yes" walk="yes">
|
||||||
<ai splitsize="1"/>
|
<ai splitsize="1"/>
|
||||||
<attack type="1" damage="1d4"/>
|
<attack type="1" damage="1d4"/>
|
||||||
</race>
|
</race>
|
||||||
|
|
Loading…
Reference in a new issue