forked from github/server
cursetyp->cansee funktion gibt sichbarkeitslevel zurück. 0 für 'von
außen', 1 'in Schiff/Gebäude', 2 'Besitzer, eigene Einheit, verursachender Magier'
This commit is contained in:
parent
8462fe496f
commit
3f075092a1
3 changed files with 79 additions and 32 deletions
|
@ -242,6 +242,9 @@ print_curses(FILE * F, const faction * viewer, const void * obj, typ_t typ)
|
||||||
|
|
||||||
c = (curse *)a->data.v;
|
c = (curse *)a->data.v;
|
||||||
if (c->type->curseinfo)
|
if (c->type->curseinfo)
|
||||||
|
if (c->type->cansee){
|
||||||
|
self = c->type->cansee(viewer, obj, typ, c, self);
|
||||||
|
}
|
||||||
dh = c->type->curseinfo(viewer->locale, obj, typ, c, self);
|
dh = c->type->curseinfo(viewer->locale, obj, typ, c, self);
|
||||||
if (dh == 1) {
|
if (dh == 1) {
|
||||||
if (!header) {
|
if (!header) {
|
||||||
|
|
|
@ -219,6 +219,7 @@ typedef struct curse_type {
|
||||||
void (*change_vigour)(curse*, int);
|
void (*change_vigour)(curse*, int);
|
||||||
int (*read)(FILE * F, curse * c);
|
int (*read)(FILE * F, curse * c);
|
||||||
int (*write)(FILE * F, const curse * c);
|
int (*write)(FILE * F, const curse * c);
|
||||||
|
int (*cansee)(const struct faction*, const void*, typ_t, curse *, int);
|
||||||
} curse_type;
|
} curse_type;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,8 @@
|
||||||
#include <nrmessage.h>
|
#include <nrmessage.h>
|
||||||
#include <objtypes.h>
|
#include <objtypes.h>
|
||||||
#include <curse.h>
|
#include <curse.h>
|
||||||
|
#include <unit.h>
|
||||||
|
#include <magic.h>
|
||||||
|
|
||||||
/* util includes */
|
/* util includes */
|
||||||
#include <message.h>
|
#include <message.h>
|
||||||
|
@ -50,11 +52,14 @@ cinfo_region(const struct locale * lang, const void * obj, typ_t typ, struct cur
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* CurseInfo mit Spezialabfragen
|
/* --------------------------------------------------------------------- */
|
||||||
|
/* CurseInfo mit Spezialabfragen
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/* godcursezone */
|
/*
|
||||||
|
* godcursezone
|
||||||
|
*/
|
||||||
static int
|
static int
|
||||||
cinfo_cursed_by_the_gods(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
cinfo_cursed_by_the_gods(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
||||||
{
|
{
|
||||||
|
@ -76,7 +81,10 @@ cinfo_cursed_by_the_gods(const locale * lang, const void * obj, typ_t typ, curse
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
/* C_GBDREAM, */
|
/* --------------------------------------------------------------------- */
|
||||||
|
/*
|
||||||
|
* C_GBDREAM
|
||||||
|
*/
|
||||||
static int
|
static int
|
||||||
cinfo_dreamcurse(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
cinfo_dreamcurse(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
||||||
{
|
{
|
||||||
|
@ -97,7 +105,11 @@ cinfo_dreamcurse(const locale * lang, const void * obj, typ_t typ, curse *c, int
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
/* C_MAGICSTREET */
|
/* --------------------------------------------------------------------- */
|
||||||
|
/*
|
||||||
|
* C_MAGICSTREET
|
||||||
|
* erzeugt Straßennetz
|
||||||
|
*/
|
||||||
static int
|
static int
|
||||||
cinfo_magicstreet(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
cinfo_magicstreet(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
||||||
{
|
{
|
||||||
|
@ -120,6 +132,17 @@ cinfo_magicstreet(const locale * lang, const void * obj, typ_t typ, curse *c, in
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
static struct curse_type ct_magicstreet = {
|
||||||
|
"magicstreet",
|
||||||
|
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR),
|
||||||
|
"Es scheint sich um einen elementarmagischen Zauber zu handeln, der alle "
|
||||||
|
"Pfade und Wege so gut festigt, als wären sie gepflastert. Wie auf einer "
|
||||||
|
"Straße kommt man so viel besser und schneller vorwärts.",
|
||||||
|
cinfo_magicstreet
|
||||||
|
};
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static int
|
||||||
cinfo_antimagiczone(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
cinfo_antimagiczone(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
||||||
{
|
{
|
||||||
|
@ -131,8 +154,8 @@ cinfo_antimagiczone(const locale * lang, const void * obj, typ_t typ, curse *c,
|
||||||
|
|
||||||
assert(typ == TYP_REGION);
|
assert(typ == TYP_REGION);
|
||||||
|
|
||||||
/* Tybied Magier spüren eine Antimagiezone */
|
/* Magier spüren eine Antimagiezone */
|
||||||
if (self != 0){
|
if (self == 2 || self == 1){
|
||||||
msg = msg_message("curseinfo::antimagiczone", "id", c->no);
|
msg = msg_message("curseinfo::antimagiczone", "id", c->no);
|
||||||
nr_render(msg, lang, buf, sizeof(buf), NULL);
|
nr_render(msg, lang, buf, sizeof(buf), NULL);
|
||||||
msg_release(msg);
|
msg_release(msg);
|
||||||
|
@ -141,6 +164,42 @@ cinfo_antimagiczone(const locale * lang, const void * obj, typ_t typ, curse *c,
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
static struct curse_type ct_antimagiczone = {
|
||||||
|
"antimagiczone",
|
||||||
|
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR),
|
||||||
|
"Dieser Zauber scheint magische Energien irgendwie abzuleiten und "
|
||||||
|
"so alle in der Region gezauberten Sprüche in ihrer Wirkung zu "
|
||||||
|
"schwächen oder ganz zu verhindern.",
|
||||||
|
cinfo_antimagiczone
|
||||||
|
};
|
||||||
|
|
||||||
|
/* alle Magier können eine Antimagiezone wahrnehmen */
|
||||||
|
static int
|
||||||
|
cansee_antimagiczone(const struct faction *viewer, curse *c, const void * obj, typ_t typ, int self)
|
||||||
|
{
|
||||||
|
region *r;
|
||||||
|
unit *u = NULL;
|
||||||
|
unit *mage = c->magician;
|
||||||
|
|
||||||
|
unused(typ);
|
||||||
|
|
||||||
|
assert(typ == TYP_REGION);
|
||||||
|
r = (region *)obj;
|
||||||
|
for (u = r->units; u; u = u->next) {
|
||||||
|
if (u->faction==viewer){
|
||||||
|
if (u==mage){
|
||||||
|
self = 2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (is_mage(u)){
|
||||||
|
self = 1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return self;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* --------------------------------------------------------------------- */
|
||||||
static int
|
static int
|
||||||
cinfo_farvision(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
cinfo_farvision(const locale * lang, const void * obj, typ_t typ, curse *c, int self)
|
||||||
{
|
{
|
||||||
|
@ -162,7 +221,13 @@ cinfo_farvision(const locale * lang, const void * obj, typ_t typ, curse *c, int
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --------------------------------------------------------------------- */
|
static struct curse_type ct_farvision = {
|
||||||
|
"farvision",
|
||||||
|
CURSETYP_NORM, 0, (NO_MERGE),
|
||||||
|
"",
|
||||||
|
cinfo_farvision
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
/* --------------------------------------------------------------------- */
|
/* --------------------------------------------------------------------- */
|
||||||
|
|
||||||
|
@ -172,21 +237,6 @@ static struct curse_type ct_fogtrap = {
|
||||||
"",
|
"",
|
||||||
cinfo_region
|
cinfo_region
|
||||||
};
|
};
|
||||||
|
|
||||||
static struct curse_type ct_antimagiczone = {
|
|
||||||
"antimagiczone",
|
|
||||||
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR),
|
|
||||||
"Dieser Zauber scheint magische Energien irgendwie abzuleiten und "
|
|
||||||
"so alle in der Region gezauberten Sprüche in ihrer Wirkung zu "
|
|
||||||
"schwächen oder ganz zu verhindern.",
|
|
||||||
cinfo_antimagiczone
|
|
||||||
};
|
|
||||||
static struct curse_type ct_farvision = {
|
|
||||||
"farvision",
|
|
||||||
CURSETYP_NORM, 0, (NO_MERGE),
|
|
||||||
"",
|
|
||||||
cinfo_farvision
|
|
||||||
};
|
|
||||||
static struct curse_type ct_gbdream = {
|
static struct curse_type ct_gbdream = {
|
||||||
"gbdream",
|
"gbdream",
|
||||||
CURSETYP_NORM, 0, (NO_MERGE),
|
CURSETYP_NORM, 0, (NO_MERGE),
|
||||||
|
@ -264,15 +314,6 @@ static struct curse_type ct_disorientationzone = {
|
||||||
"",
|
"",
|
||||||
cinfo_region
|
cinfo_region
|
||||||
};
|
};
|
||||||
/* erzeugt Straßennetz */
|
|
||||||
static struct curse_type ct_magicstreet = {
|
|
||||||
"magicstreet",
|
|
||||||
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR),
|
|
||||||
"Es scheint sich um einen elementarmagischen Zauber zu handeln, der alle "
|
|
||||||
"Pfade und Wege so gut festigt, als wären sie gepflastert. Wie auf einer "
|
|
||||||
"Straße kommt man so viel besser und schneller vorwärts.",
|
|
||||||
cinfo_magicstreet
|
|
||||||
};
|
|
||||||
/* erniedigt Magieresistenz von nicht-aliierten Einheiten, wirkt nur 1x
|
/* erniedigt Magieresistenz von nicht-aliierten Einheiten, wirkt nur 1x
|
||||||
* pro Einheit */
|
* pro Einheit */
|
||||||
static struct curse_type ct_badmagicresistancezone = {
|
static struct curse_type ct_badmagicresistancezone = {
|
||||||
|
@ -324,6 +365,8 @@ register_regioncurse(void)
|
||||||
register_function((pf_generic)cinfo_dreamcurse, "curseinfo::dreamcurse");
|
register_function((pf_generic)cinfo_dreamcurse, "curseinfo::dreamcurse");
|
||||||
register_function((pf_generic)cinfo_magicstreet, "curseinfo::magicstreet");
|
register_function((pf_generic)cinfo_magicstreet, "curseinfo::magicstreet");
|
||||||
|
|
||||||
|
register_function((pf_generic)cansee_antimagiczone, "cursecansee::antimagiczone");
|
||||||
|
|
||||||
ct_register(&ct_fogtrap);
|
ct_register(&ct_fogtrap);
|
||||||
ct_register(&ct_antimagiczone);
|
ct_register(&ct_antimagiczone);
|
||||||
ct_register(&ct_farvision);
|
ct_register(&ct_farvision);
|
||||||
|
|
Loading…
Reference in a new issue