CURSE_ISNEW moved so that it's generally defined by the curse_type, since most spells actually start working in the same round.

This commit is contained in:
Enno Rehling 2007-04-22 00:30:12 +00:00
parent af0a7b225a
commit 614aa80bdf
6 changed files with 39 additions and 26 deletions

View file

@ -69,7 +69,7 @@ attrib_type at_variable = {
const char *
get_variable(attrib *a, const char *key)
{
attrib *ap = a_find(a, &at_variable);;
attrib *ap = a_find(a, &at_variable);
while (ap && ap->type==&at_variable) {
variable * var = (variable *)ap->data.v;

View file

@ -58,6 +58,21 @@
#define MAXENTITYHASH 7919
curse *cursehash[MAXENTITYHASH];
/* -------------------------------------------------------------------------- */
void
c_setflag(curse *c, unsigned int flags)
{
assert(c);
c->flags = (c->flags & ~flags) | (flags & (c->type->flags ^ flags));
}
/* -------------------------------------------------------------------------- */
void
c_clearflag(curse *c, unsigned int flags)
{
assert(c);
c->flags = (c->flags & ~flags) | (c->type->flags & flags);
}
void
chash(curse *c)
{
@ -139,7 +154,8 @@ curse_done(attrib * a) {
/* ------------------------------------------------------------- */
int
curse_read(attrib * a, FILE * f) {
curse_read(attrib * a, FILE * f)
{
variant mageid;
curse * c = (curse*)a->data.v;
const curse_type * ct;
@ -165,6 +181,7 @@ curse_read(attrib * a, FILE * f) {
} else {
c->flags = flags;
}
c_clearflag(c, CURSE_ISNEW);
#ifdef CONVERT_DBLINK
if (global.data_version<DBLINK_VERSION) {
@ -200,15 +217,17 @@ curse_read(attrib * a, FILE * f) {
}
void
curse_write(const attrib * a, FILE * f) {
curse_write(const attrib * a, FILE * f)
{
unsigned int flags;
int mage_no;
curse * c = (curse*)a->data.v;
const curse_type * ct = c->type;
flags = (c->flags & ~(CURSE_ISNEW));
/* copied from c_clearflag */
flags = (c->flags & ~CURSE_ISNEW) | (c->type->flags & CURSE_ISNEW);
if (c->magician){
if (c->magician) {
mage_no = c->magician->no;
} else {
mage_no = -1;
@ -440,14 +459,6 @@ set_cursedmen(curse *c, int cursedmen)
}
}
/* ------------------------------------------------------------- */
void
c_setflag(curse *c, unsigned int flags)
{
assert(c);
c->flags = (c->flags & ~flags) | (flags & (c->type->flags ^ flags));
}
/* ------------------------------------------------------------- */
/* Legt eine neue Verzauberung an. Sollte es schon einen Zauber
* dieses Typs geben, gibt es den bestehenden zurück.
@ -464,7 +475,7 @@ make_curse(unit *mage, attrib **ap, const curse_type *ct, double vigour,
c = (curse*)a->data.v;
c->type = ct;
c->flags = CURSE_ISNEW;
c->flags = 0;
c->vigour = vigour;
c->duration = duration;
c->effect = effect;

View file

@ -277,7 +277,8 @@ extern int get_cursedmen(struct unit *u, struct curse *c);
* betroffenen Personen zurück. Ansonsten wird 0 zurückgegeben. */
extern void c_setflag(curse * c, unsigned int flag);
/* setzt Spezialflag einer Verzauberung (zB 'dauert ewig') */
extern void c_clearflag(curse *c, unsigned int flags);
/* setzt/loescht Spezialflag einer Verzauberung (zB 'dauert ewig') */
void transfer_curse(struct unit * u, struct unit * u2, int n);
/* sorgt dafür, das bei der Übergabe von Personen die curse-attribute

View file

@ -44,7 +44,7 @@
static message *
cinfo_cursed_by_the_gods(const void * obj, typ_t typ, const curse *c, int self)
{
region *r = (region *)obj;;
region *r = (region *)obj;
unused(typ);
unused(self);
@ -58,7 +58,7 @@ cinfo_cursed_by_the_gods(const void * obj, typ_t typ, const curse *c, int self)
static struct curse_type ct_godcursezone = {
"godcursezone",
CURSETYP_NORM, CURSE_IMMUNE, (NO_MERGE),
CURSETYP_NORM, CURSE_IMMUNE|CURSE_ISNEW, (NO_MERGE),
"Diese Region wurde von den Göttern verflucht. Stinkende Nebel ziehen "
"über die tote Erde, furchbare Kreaturen ziehen über das Land. Die Brunnen "
"sind vergiftet, und die wenigen essbaren Früchte sind von einem rosa Pilz "
@ -87,7 +87,7 @@ cinfo_dreamcurse(const void * obj, typ_t typ, const curse *c, int self)
static struct curse_type ct_gbdream = {
"gbdream",
CURSETYP_NORM, 0, (NO_MERGE),
CURSETYP_NORM, CURSE_ISNEW, (NO_MERGE),
"",
cinfo_dreamcurse
};
@ -208,7 +208,7 @@ static struct curse_type ct_fogtrap = {
};
static struct curse_type ct_maelstrom = {
"maelstrom",
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR),
CURSETYP_NORM, CURSE_ISNEW, (M_DURATION | M_VIGOUR),
"Dieser Zauber verursacht einen gigantischen magischen Strudel. Der "
"Mahlstrom wird alle Schiffe, die in seinen Sog geraten, schwer "
"beschädigen.",
@ -229,7 +229,7 @@ static struct curse_type ct_drought = {
};
static struct curse_type ct_badlearn = {
"badlearn",
CURSETYP_NORM, 0, ( M_DURATION | M_VIGOUR ),
CURSETYP_NORM, CURSE_ISNEW, ( M_DURATION | M_VIGOUR ),
"Dieser Zauber scheint die Ursache für die Schlaflosigkeit und "
"Mattigkeit zu sein, unter der die meisten Leute hier leiden und "
"die dazu führt, das Lernen weniger Erfolg bringt. ",
@ -273,7 +273,7 @@ static struct curse_type ct_peacezone = {
/* erschwert geordnete Bewegungen */
static struct curse_type ct_disorientationzone = {
"disorientationzone",
CURSETYP_NORM, 0, NO_MERGE,
CURSETYP_NORM, CURSE_ISNEW, NO_MERGE,
"",
cinfo_simple
};

View file

@ -178,7 +178,7 @@ cinfo_unit(const void * obj, typ_t typ, const curse *c, int self)
static struct curse_type ct_orcish = {
"orcish",
CURSETYP_UNIT, CURSE_SPREADMODULO, M_MEN,
CURSETYP_UNIT, CURSE_SPREADMODULO|CURSE_ISNEW, M_MEN,
"Dieser Zauber scheint die Einheit zu 'orkisieren'. Wie bei Orks "
"ist eine deutliche Neigung zur Fortpflanzung zu beobachten.",
cinfo_unit

View file

@ -26,9 +26,10 @@
#include <kernel/unit.h>
/* util includes */
#include <event.h>
#include <resolve.h>
#include <base36.h>
#include <util/base36.h>
#include <util/event.h>
#include <util/resolve.h>
#include <util/rng.h>
/* libc includes */
#include <assert.h>
@ -61,7 +62,7 @@ do_shock(unit *u, const char *reason)
}
/* Evt. Talenttageverlust */
for (i=0;i!=u->skill_size;++i) if (rand()%5==0) {
for (i=0;i!=u->skill_size;++i) if (rng_int()%5==0) {
skill * sv = u->skills+i;
int weeks = (sv->level * sv->level - sv->level) / 2;
int change = (weeks+9) / 10;