forked from github/server
Bugfix Wolfsgeheul und sonstige Sprüche (Hamo's Tod)
Behebung der restlichen double->int conversion warnings
This commit is contained in:
parent
afe4e48a30
commit
567117932c
17 changed files with 228 additions and 1276 deletions
|
@ -3436,10 +3436,6 @@ defaultorders (void)
|
||||||
list_next(r);
|
list_next(r);
|
||||||
}
|
}
|
||||||
|
|
||||||
#ifdef SKILLFIX_SAVE
|
|
||||||
void write_skillfix(void);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* ************************************************************ */
|
/* ************************************************************ */
|
||||||
/* GANZ WICHTIG! ALLE GEÄNDERTEN SPRÜCHE NEU ANZEIGEN */
|
/* GANZ WICHTIG! ALLE GEÄNDERTEN SPRÜCHE NEU ANZEIGEN */
|
||||||
/* GANZ WICHTIG! FÜGT AUCH NEUE ZAUBER IN DIE LISTE DER BEKANNTEN EIN */
|
/* GANZ WICHTIG! FÜGT AUCH NEUE ZAUBER IN DIE LISTE DER BEKANNTEN EIN */
|
||||||
|
@ -3675,9 +3671,6 @@ processorders (void)
|
||||||
puts(" - Attribute altern");
|
puts(" - Attribute altern");
|
||||||
ageing();
|
ageing();
|
||||||
|
|
||||||
#ifdef SKILLFIX_SAVE
|
|
||||||
write_skillfix();
|
|
||||||
#endif
|
|
||||||
/* immer ausführen, wenn neue Sprüche dazugekommen sind, oder sich
|
/* immer ausführen, wenn neue Sprüche dazugekommen sind, oder sich
|
||||||
* Beschreibungen geändert haben */
|
* Beschreibungen geändert haben */
|
||||||
update_spells();
|
update_spells();
|
||||||
|
|
|
@ -982,11 +982,7 @@ plan_monsters(void)
|
||||||
}
|
}
|
||||||
else a_remove(&u->attribs, ta);
|
else a_remove(&u->attribs, ta);
|
||||||
}
|
}
|
||||||
#ifdef CONVERT_TRIGGER
|
|
||||||
ta = set_new_dragon_target(u, r, DRAGON_RANGE);
|
|
||||||
#else
|
|
||||||
ta = a_find(u->attribs, &at_targetregion);
|
ta = a_find(u->attribs, &at_targetregion);
|
||||||
#endif
|
|
||||||
if (ta!=NULL) {
|
if (ta!=NULL) {
|
||||||
tr = (region *) ta->data.v;
|
tr = (region *) ta->data.v;
|
||||||
if (tr != r) is_moving = true;
|
if (tr != r) is_moving = true;
|
||||||
|
|
|
@ -434,10 +434,6 @@ teach(region * r, unit * u)
|
||||||
}
|
}
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
||||||
#ifdef SKILLFIX_SAVE
|
|
||||||
extern void skillfix(struct unit *, skill_t, int, int, int);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
void
|
void
|
||||||
learn(void)
|
learn(void)
|
||||||
{
|
{
|
||||||
|
@ -668,13 +664,6 @@ learn(void)
|
||||||
if (is_cursed(r->attribs,C_BADLEARN,0)) {
|
if (is_cursed(r->attribs,C_BADLEARN,0)) {
|
||||||
teach->value -= u->number * 10;
|
teach->value -= u->number * 10;
|
||||||
}
|
}
|
||||||
#ifdef SKILLFIX_SAVE
|
|
||||||
if (teach && teach->value) {
|
|
||||||
int skill = get_skill(u, sk);
|
|
||||||
skillfix(u, sk, skill,
|
|
||||||
(int)(u->number * 30 * multi), teach->value);
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
days = (int)((u->number * 30 + teach->value) * multi);
|
days = (int)((u->number * 30 + teach->value) * multi);
|
||||||
if (fval(u, UFL_HUNGER)) days = days / 2;
|
if (fval(u, UFL_HUNGER)) days = days / 2;
|
||||||
|
|
|
@ -1297,15 +1297,6 @@ terminate(troop dt, troop at, int type, const char *damage, boolean missile)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
|
||||||
lovar(int n)
|
|
||||||
{
|
|
||||||
assert(n > 0);
|
|
||||||
if (n == 1) return rand()%2;
|
|
||||||
n /= 2;
|
|
||||||
return (rand() % n + 1) + (rand() % n + 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
int
|
int
|
||||||
count_enemies(battle * b, side * as, int mask, int minrow, int maxrow)
|
count_enemies(battle * b, side * as, int mask, int minrow, int maxrow)
|
||||||
|
@ -1446,7 +1437,7 @@ do_combatmagic(battle *b, combatmagic_t was)
|
||||||
region *r = b->region;
|
region *r = b->region;
|
||||||
castorder *co;
|
castorder *co;
|
||||||
castorder *cll[MAX_SPELLRANK];
|
castorder *cll[MAX_SPELLRANK];
|
||||||
int level, power;
|
int level;
|
||||||
int spellrank;
|
int spellrank;
|
||||||
int sl;
|
int sl;
|
||||||
|
|
||||||
|
@ -1464,6 +1455,7 @@ do_combatmagic(battle *b, combatmagic_t was)
|
||||||
|
|
||||||
level = eff_skill(mage, SK_MAGIC, r);
|
level = eff_skill(mage, SK_MAGIC, r);
|
||||||
if (level > 0) {
|
if (level > 0) {
|
||||||
|
double power;
|
||||||
const struct locale * lang = mage->faction->locale;
|
const struct locale * lang = mage->faction->locale;
|
||||||
char cmd[128];
|
char cmd[128];
|
||||||
|
|
||||||
|
@ -1520,10 +1512,10 @@ do_combatmagic(battle *b, combatmagic_t was)
|
||||||
}
|
}
|
||||||
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
for (spellrank = 0; spellrank < MAX_SPELLRANK; spellrank++) {
|
||||||
for (co = cll[spellrank]; co; co = co->next) {
|
for (co = cll[spellrank]; co; co = co->next) {
|
||||||
fig = (fighter*)co->magician;
|
fighter * fig = (fighter*)co->magician;
|
||||||
sp = co->sp;
|
spell * sp = co->sp;
|
||||||
level = co->level;
|
int level = co->level;
|
||||||
power = co->force;
|
double power = co->force;
|
||||||
|
|
||||||
level = ((cspell_f)sp->sp_function)(fig, level, power, sp);
|
level = ((cspell_f)sp->sp_function)(fig, level, power, sp);
|
||||||
if (level > 0) {
|
if (level > 0) {
|
||||||
|
@ -1548,7 +1540,8 @@ do_combatspell(troop at, int row)
|
||||||
unit *mage = fi->unit;
|
unit *mage = fi->unit;
|
||||||
battle *b = fi->side->battle;
|
battle *b = fi->side->battle;
|
||||||
region *r = b->region;
|
region *r = b->region;
|
||||||
int level, power;
|
int level;
|
||||||
|
double power;
|
||||||
int fumblechance = 0;
|
int fumblechance = 0;
|
||||||
void **mg;
|
void **mg;
|
||||||
int sl;
|
int sl;
|
||||||
|
@ -2747,7 +2740,7 @@ weapon_weight(const weapon * w, boolean missile)
|
||||||
}
|
}
|
||||||
|
|
||||||
fighter *
|
fighter *
|
||||||
make_fighter(battle * b, unit * u, boolean attack)
|
make_fighter(battle * b, unit * u, side * s1, boolean attack)
|
||||||
{
|
{
|
||||||
#define WMAX 16
|
#define WMAX 16
|
||||||
weapon weapons[WMAX];
|
weapon weapons[WMAX];
|
||||||
|
@ -2758,7 +2751,7 @@ make_fighter(battle * b, unit * u, boolean attack)
|
||||||
item * itm;
|
item * itm;
|
||||||
fighter *fig = NULL;
|
fighter *fig = NULL;
|
||||||
int i, t = eff_skill(u, SK_TACTICS, r);
|
int i, t = eff_skill(u, SK_TACTICS, r);
|
||||||
side *s2, *s1 = NULL;
|
side *s2;
|
||||||
int h;
|
int h;
|
||||||
int berserk;
|
int berserk;
|
||||||
int strongmen;
|
int strongmen;
|
||||||
|
@ -2775,6 +2768,7 @@ make_fighter(battle * b, unit * u, boolean attack)
|
||||||
if (fval(u->race, RCF_ILLUSIONARY) || idle(u->faction))
|
if (fval(u->race, RCF_ILLUSIONARY) || idle(u->faction))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
if (s1==NULL) {
|
||||||
cv_foreach(s2, b->sides) {
|
cv_foreach(s2, b->sides) {
|
||||||
if (s2->bf->faction == u->faction
|
if (s2->bf->faction == u->faction
|
||||||
&& s2->stealth==stealth
|
&& s2->stealth==stealth
|
||||||
|
@ -2791,6 +2785,7 @@ make_fighter(battle * b, unit * u, boolean attack)
|
||||||
if (!s1) s1 = make_side(b, u->faction, g, stealth, stealthfaction);
|
if (!s1) s1 = make_side(b, u->faction, g, stealth, stealthfaction);
|
||||||
/* Zu diesem Zeitpunkt ist attacked noch 0, da die Einheit für noch
|
/* Zu diesem Zeitpunkt ist attacked noch 0, da die Einheit für noch
|
||||||
* keinen Kampf ausgewählt wurde (sonst würde ein fighter existieren) */
|
* keinen Kampf ausgewählt wurde (sonst würde ein fighter existieren) */
|
||||||
|
}
|
||||||
fig = calloc(1, sizeof(struct fighter));
|
fig = calloc(1, sizeof(struct fighter));
|
||||||
|
|
||||||
cv_pushback(&s1->fighters, fig);
|
cv_pushback(&s1->fighters, fig);
|
||||||
|
@ -3043,7 +3038,7 @@ join_battle(battle * b, unit * u, boolean attack)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
cv_next(fig);
|
cv_next(fig);
|
||||||
if (!c) c = make_fighter(b, u, attack);
|
if (!c) c = make_fighter(b, u, NULL, attack);
|
||||||
return c;
|
return c;
|
||||||
}
|
}
|
||||||
static const char *
|
static const char *
|
||||||
|
|
|
@ -227,7 +227,7 @@ extern boolean helping(struct side * as, struct side * ds);
|
||||||
extern void rmfighter(fighter *df, int i);
|
extern void rmfighter(fighter *df, int i);
|
||||||
extern struct region * fleeregion(const struct unit * u);
|
extern struct region * fleeregion(const struct unit * u);
|
||||||
extern struct troop select_corpse(struct battle * b, struct fighter * af);
|
extern struct troop select_corpse(struct battle * b, struct fighter * af);
|
||||||
extern fighter * make_fighter(struct battle * b, struct unit * u, boolean attack);
|
extern fighter * make_fighter(struct battle * b, struct unit * u, side * s, boolean attack);
|
||||||
extern int statusrow(int status);
|
extern int statusrow(int status);
|
||||||
extern void drain_exp(struct unit *u, int d);
|
extern void drain_exp(struct unit *u, int d);
|
||||||
extern void rmtroop(troop dt);
|
extern void rmtroop(troop dt);
|
||||||
|
|
|
@ -796,7 +796,7 @@ sp_shadowcall(fighter * fi, int level, int power, spell * sp)
|
||||||
a->data.ca[1] = 100;
|
a->data.ca[1] = 100;
|
||||||
a_add(&u->attribs, a);
|
a_add(&u->attribs, a);
|
||||||
|
|
||||||
make_fighter(b, u, true);
|
make_fighter(b, u, fi->side, fval(fi, FIG_ATTACKED));
|
||||||
sprintf(buf, "%s ruft %d %s zu Hilfe", unitname(mage), force,
|
sprintf(buf, "%s ruft %d %s zu Hilfe", unitname(mage), force,
|
||||||
racename(default_locale, u, u->race));
|
racename(default_locale, u, u->race));
|
||||||
battlerecord(b, buf);
|
battlerecord(b, buf);
|
||||||
|
@ -829,7 +829,7 @@ sp_wolfhowl(fighter * fi, int level, int power, spell * sp)
|
||||||
a->data.ca[1] = 100;
|
a->data.ca[1] = 100;
|
||||||
a_add(&u->attribs, a);
|
a_add(&u->attribs, a);
|
||||||
|
|
||||||
make_fighter(b, u, true);
|
make_fighter(b, u, fi->side, fval(fi, FIG_ATTACKED));
|
||||||
sprintf(buf, "%s ruft %d %s zu Hilfe", unitname(mage), force,
|
sprintf(buf, "%s ruft %d %s zu Hilfe", unitname(mage), force,
|
||||||
racename(default_locale, u, u->race));
|
racename(default_locale, u, u->race));
|
||||||
battlerecord(b, buf);
|
battlerecord(b, buf);
|
||||||
|
@ -863,7 +863,7 @@ sp_shadowknights(fighter * fi, int level, int power, spell * sp)
|
||||||
a->data.ca[1] = 100;
|
a->data.ca[1] = 100;
|
||||||
a_add(&u->attribs, a);
|
a_add(&u->attribs, a);
|
||||||
|
|
||||||
make_fighter(b, u, true);
|
make_fighter(b, u, fi->side, fval(fi, FIG_ATTACKED));
|
||||||
|
|
||||||
sprintf(buf, "%s beschwört Trugbilder herauf", unitname(mage));
|
sprintf(buf, "%s beschwört Trugbilder herauf", unitname(mage));
|
||||||
battlerecord(b, buf);
|
battlerecord(b, buf);
|
||||||
|
|
|
@ -2949,6 +2949,14 @@ produceexp(struct unit * u, skill_t sk, int n)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
lovar(double xpct_x2)
|
||||||
|
{
|
||||||
|
int n = (int)(xpct_x2 * 500)+1;
|
||||||
|
if (n==0) return 0;
|
||||||
|
return (rand() % n + rand() % n)/1000;
|
||||||
|
}
|
||||||
|
|
||||||
boolean
|
boolean
|
||||||
teure_talente (const struct unit * u)
|
teure_talente (const struct unit * u)
|
||||||
{
|
{
|
||||||
|
|
|
@ -977,7 +977,8 @@ boolean cansee_durchgezogen(const struct faction * f, const struct region * r, c
|
||||||
boolean seefaction(const struct faction * f, const struct region * r, const struct unit * u, int modifier);
|
boolean seefaction(const struct faction * f, const struct region * r, const struct unit * u, int modifier);
|
||||||
extern int effskill(const struct unit * u, skill_t sk);
|
extern int effskill(const struct unit * u, skill_t sk);
|
||||||
|
|
||||||
int lovar(int n);
|
extern int lovar(double xpct_x2);
|
||||||
|
/* returns a value between [0..xpct_2], generated with two dice */
|
||||||
|
|
||||||
int distribute(int old, int new_value, int n);
|
int distribute(int old, int new_value, int n);
|
||||||
|
|
||||||
|
|
|
@ -812,7 +812,8 @@ use_antimagiccrystal(region * r, unit * mage, int amount, strlist * cmdstrings)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
for (i=0;i!=amount;++i) {
|
for (i=0;i!=amount;++i) {
|
||||||
int effect, force, duration = 2;
|
int effect, duration = 2;
|
||||||
|
double force;
|
||||||
spell *sp = find_spellbyid(SPL_ANTIMAGICZONE);
|
spell *sp = find_spellbyid(SPL_ANTIMAGICZONE);
|
||||||
attrib ** ap = &r->attribs;
|
attrib ** ap = &r->attribs;
|
||||||
unused(cmdstrings);
|
unused(cmdstrings);
|
||||||
|
|
|
@ -2361,7 +2361,7 @@ add_spellparameter(region *target_r, unit *u, const char *syntax,
|
||||||
|
|
||||||
castorder *
|
castorder *
|
||||||
new_castorder(void *u, unit *u2, spell *sp, region *r, int lev,
|
new_castorder(void *u, unit *u2, spell *sp, region *r, int lev,
|
||||||
int force, int range, char *cmd, spellparameter *p)
|
double force, int range, char *cmd, spellparameter *p)
|
||||||
{
|
{
|
||||||
castorder *corder;
|
castorder *corder;
|
||||||
|
|
||||||
|
|
|
@ -173,7 +173,7 @@ struct castorder {
|
||||||
den Vertrauten gezaubert wird */
|
den Vertrauten gezaubert wird */
|
||||||
struct spell *sp; /* Spruch */
|
struct spell *sp; /* Spruch */
|
||||||
int level; /* gewünschte Stufe oder Stufe des Magiers */
|
int level; /* gewünschte Stufe oder Stufe des Magiers */
|
||||||
float force; /* Stärke des Zaubers */
|
double force; /* Stärke des Zaubers */
|
||||||
struct region *rt; /* Zielregion des Spruchs */
|
struct region *rt; /* Zielregion des Spruchs */
|
||||||
int distance; /* Entfernung zur Zielregion */
|
int distance; /* Entfernung zur Zielregion */
|
||||||
char *order; /* Befehl */
|
char *order; /* Befehl */
|
||||||
|
@ -187,7 +187,7 @@ typedef void (*spell_f) (void*);
|
||||||
/* normale zauber: */
|
/* normale zauber: */
|
||||||
typedef int (*nspell_f)(castorder*);
|
typedef int (*nspell_f)(castorder*);
|
||||||
/* kampfzauber: */
|
/* kampfzauber: */
|
||||||
typedef int (*cspell_f) (struct fighter*, int, int, struct spell * sp);
|
typedef int (*cspell_f) (struct fighter*, int, double, struct spell * sp);
|
||||||
/* zauber-patzer: */
|
/* zauber-patzer: */
|
||||||
typedef void (*pspell_f) (castorder *);
|
typedef void (*pspell_f) (castorder *);
|
||||||
|
|
||||||
|
@ -335,7 +335,7 @@ boolean fumble (struct region *r, struct unit *u, spell *spruch, int cast_level)
|
||||||
|
|
||||||
/* */
|
/* */
|
||||||
castorder *new_castorder(void *u, struct unit *familiar, spell *sp, struct region *r,
|
castorder *new_castorder(void *u, struct unit *familiar, spell *sp, struct region *r,
|
||||||
int lev, int force, int distance, char *cmd, spellparameter *p);
|
int lev, double force, int distance, char *cmd, spellparameter *p);
|
||||||
/* Zwischenspreicher für Zauberbefehle, notwendig für Prioritäten */
|
/* Zwischenspreicher für Zauberbefehle, notwendig für Prioritäten */
|
||||||
void add_castorder(castorder **cll, castorder *co);
|
void add_castorder(castorder **cll, castorder *co);
|
||||||
/* Hänge c-order co an die letze c-order von cll an */
|
/* Hänge c-order co an die letze c-order von cll an */
|
||||||
|
|
|
@ -882,11 +882,7 @@ readgame(const char * filename, int backup)
|
||||||
global.data_version = ri(F);
|
global.data_version = ri(F);
|
||||||
assert(global.data_version>=MIN_VERSION || !"unsupported data format");
|
assert(global.data_version>=MIN_VERSION || !"unsupported data format");
|
||||||
assert(global.data_version<=RELEASE_VERSION || !"unsupported data format");
|
assert(global.data_version<=RELEASE_VERSION || !"unsupported data format");
|
||||||
#ifdef CONVERT_TRIGGER
|
|
||||||
assert(global.data_version < NEWSOURCE_VERSION);
|
|
||||||
#else
|
|
||||||
assert(global.data_version >= NEWSOURCE_VERSION);
|
assert(global.data_version >= NEWSOURCE_VERSION);
|
||||||
#endif
|
|
||||||
if(global.data_version >= SAVEXMLNAME_VERSION) {
|
if(global.data_version >= SAVEXMLNAME_VERSION) {
|
||||||
char basefile[1024];
|
char basefile[1024];
|
||||||
const char *basearg = "(null)";
|
const char *basearg = "(null)";
|
||||||
|
|
|
@ -161,35 +161,34 @@ do_shock(unit *u, const char *reason)
|
||||||
/* Spruchanalyse - Ausgabe von curse->info und curse->name */
|
/* Spruchanalyse - Ausgabe von curse->info und curse->name */
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
||||||
static int
|
static double
|
||||||
curse_chance(const struct curse * c, int force)
|
curse_chance(const struct curse * c, double force)
|
||||||
{
|
{
|
||||||
return 100 + (int)((force - c->vigour)*10);
|
return 1.0 + (force - c->vigour) * 0.1;
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
magicanalyse_region(region *r, unit *mage, int force)
|
magicanalyse_region(region *r, unit *mage, double force)
|
||||||
{
|
{
|
||||||
attrib *a;
|
attrib *a;
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
const struct locale * lang = mage->faction->locale;
|
const struct locale * lang = mage->faction->locale;
|
||||||
|
|
||||||
for (a=r->attribs;a;a=a->next) {
|
for (a=r->attribs;a;a=a->next) {
|
||||||
curse * c;
|
curse * c = (curse*)a->data.v;
|
||||||
int chance;
|
double probability;
|
||||||
int mon;
|
int mon;
|
||||||
|
|
||||||
if (!fval(a->type, ATF_CURSE)) continue;
|
if (!fval(a->type, ATF_CURSE)) continue;
|
||||||
|
|
||||||
c = (curse*)a->data.v;
|
|
||||||
|
|
||||||
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
||||||
* mehr als 100% chance und damit immer ein Erfolg. */
|
* mehr als 100% probability und damit immer ein Erfolg. */
|
||||||
chance = curse_chance(c, force);
|
probability = curse_chance(c, force);
|
||||||
mon = c->duration + (rand()%10) - 5;
|
mon = c->duration + (rand()%10) - 5;
|
||||||
mon = max(1, mon);
|
mon = max(1, mon);
|
||||||
found = true;
|
found = true;
|
||||||
|
|
||||||
if(rand()%100 < chance){ /* Analyse geglückt */
|
if (chance(probability)) { /* Analyse geglückt */
|
||||||
if(c->flag & CURSE_NOAGE) {
|
if(c->flag & CURSE_NOAGE) {
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"analyse_region_noage%u:mage%r:region%s:spell",
|
"analyse_region_noage%u:mage%r:region%s:spell",
|
||||||
|
@ -210,8 +209,8 @@ magicanalyse_region(region *r, unit *mage, int force)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
magicanalyse_unit(unit *u, unit *mage, int force)
|
magicanalyse_unit(unit *u, unit *mage, double force)
|
||||||
{
|
{
|
||||||
attrib *a;
|
attrib *a;
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
|
@ -219,18 +218,18 @@ magicanalyse_unit(unit *u, unit *mage, int force)
|
||||||
|
|
||||||
for (a=u->attribs;a;a=a->next) {
|
for (a=u->attribs;a;a=a->next) {
|
||||||
curse * c;
|
curse * c;
|
||||||
int chance;
|
double probability;
|
||||||
int mon;
|
int mon;
|
||||||
if (!fval(a->type, ATF_CURSE)) continue;
|
if (!fval(a->type, ATF_CURSE)) continue;
|
||||||
|
|
||||||
c = (curse*)a->data.v;
|
c = (curse*)a->data.v;
|
||||||
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
||||||
* mehr als 100% chance und damit immer ein Erfolg. */
|
* mehr als 100% probability und damit immer ein Erfolg. */
|
||||||
chance = curse_chance(c, force);
|
probability = curse_chance(c, force);
|
||||||
mon = c->duration + (rand()%10) - 5;
|
mon = c->duration + (rand()%10) - 5;
|
||||||
mon = max(1,mon);
|
mon = max(1,mon);
|
||||||
|
|
||||||
if(rand()%100 < chance){ /* Analyse geglückt */
|
if (chance(probability)) { /* Analyse geglückt */
|
||||||
if(c->flag & CURSE_NOAGE){
|
if(c->flag & CURSE_NOAGE){
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"analyse_unit_noage%u:mage%u:unit%s:spell",
|
"analyse_unit_noage%u:mage%u:unit%s:spell",
|
||||||
|
@ -251,8 +250,8 @@ magicanalyse_unit(unit *u, unit *mage, int force)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
magicanalyse_building(building *b, unit *mage, int force)
|
magicanalyse_building(building *b, unit *mage, double force)
|
||||||
{
|
{
|
||||||
attrib *a;
|
attrib *a;
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
|
@ -260,18 +259,19 @@ magicanalyse_building(building *b, unit *mage, int force)
|
||||||
|
|
||||||
for (a=b->attribs;a;a=a->next) {
|
for (a=b->attribs;a;a=a->next) {
|
||||||
curse * c;
|
curse * c;
|
||||||
int chance;
|
double probability;
|
||||||
int mon;
|
int mon;
|
||||||
|
|
||||||
if (!fval(a->type, ATF_CURSE)) continue;
|
if (!fval(a->type, ATF_CURSE)) continue;
|
||||||
|
|
||||||
c = (curse*)a->data.v;
|
c = (curse*)a->data.v;
|
||||||
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
||||||
* mehr als 100% chance und damit immer ein Erfolg. */
|
* mehr als 100% probability und damit immer ein Erfolg. */
|
||||||
chance = curse_chance(c, force);
|
probability = curse_chance(c, force);
|
||||||
mon = c->duration + (rand()%10) - 5;
|
mon = c->duration + (rand()%10) - 5;
|
||||||
mon = max(1,mon);
|
mon = max(1,mon);
|
||||||
|
|
||||||
if(rand()%100 < chance){ /* Analyse geglückt */
|
if (chance(probability)) { /* Analyse geglückt */
|
||||||
if(c->flag & CURSE_NOAGE){
|
if(c->flag & CURSE_NOAGE){
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"analyse_building_age%u:mage%b:building%s:spell",
|
"analyse_building_age%u:mage%b:building%s:spell",
|
||||||
|
@ -293,8 +293,8 @@ magicanalyse_building(building *b, unit *mage, int force)
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
static void
|
||||||
magicanalyse_ship(ship *sh, unit *mage, int force)
|
magicanalyse_ship(ship *sh, unit *mage, double force)
|
||||||
{
|
{
|
||||||
attrib *a;
|
attrib *a;
|
||||||
boolean found = false;
|
boolean found = false;
|
||||||
|
@ -302,18 +302,18 @@ magicanalyse_ship(ship *sh, unit *mage, int force)
|
||||||
|
|
||||||
for (a=sh->attribs;a;a=a->next) {
|
for (a=sh->attribs;a;a=a->next) {
|
||||||
curse * c;
|
curse * c;
|
||||||
int chance;
|
double probability;
|
||||||
int mon;
|
int mon;
|
||||||
if (!fval(a->type, ATF_CURSE)) continue;
|
if (!fval(a->type, ATF_CURSE)) continue;
|
||||||
|
|
||||||
c = (curse*)a->data.v;
|
c = (curse*)a->data.v;
|
||||||
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
/* ist der curse schwächer als der Analysezauber, so ergibt sich
|
||||||
* mehr als 100% chance und damit immer ein Erfolg. */
|
* mehr als 100% probability und damit immer ein Erfolg. */
|
||||||
chance = curse_chance(c, force);
|
probability = curse_chance(c, force);
|
||||||
mon = c->duration + (rand()%10) - 5;
|
mon = c->duration + (rand()%10) - 5;
|
||||||
mon = max(1,mon);
|
mon = max(1,mon);
|
||||||
|
|
||||||
if(rand()%100 < chance){ /* Analyse geglückt */
|
if (chance(probability)) { /* Analyse geglückt */
|
||||||
if(c->flag & CURSE_NOAGE){
|
if(c->flag & CURSE_NOAGE){
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"analyse_ship_noage%u:mage%h:ship%s:spell",
|
"analyse_ship_noage%u:mage%h:ship%s:spell",
|
||||||
|
@ -351,10 +351,9 @@ double
|
||||||
destr_curse(curse* c, int cast_level, double force)
|
destr_curse(curse* c, int cast_level, double force)
|
||||||
{
|
{
|
||||||
if (cast_level < c->vigour) { /* Zauber ist nicht stark genug */
|
if (cast_level < c->vigour) { /* Zauber ist nicht stark genug */
|
||||||
double chance;
|
double probability = 0.1 + (cast_level - c->vigour)*0.2;
|
||||||
/* pro Stufe Unterschied -20% */
|
/* pro Stufe Unterschied -20% */
|
||||||
chance = 0.1 + (cast_level - c->vigour)*0.2;
|
if (chance(probability)) {
|
||||||
if (rand()%100 >= chance*100) {
|
|
||||||
force -= c->vigour;
|
force -= c->vigour;
|
||||||
if (c->type->change_vigour){
|
if (c->type->change_vigour){
|
||||||
c->type->change_vigour(c, -(cast_level+1/2));
|
c->type->change_vigour(c, -(cast_level+1/2));
|
||||||
|
@ -2232,7 +2231,7 @@ sp_fog_of_confusion(castorder *co)
|
||||||
regionlist *rl,*rl2;
|
regionlist *rl,*rl2;
|
||||||
|
|
||||||
range = (power-11)/3-1;
|
range = (power-11)/3-1;
|
||||||
duration = ((power-11)/3)*2+1;
|
duration = (int)((power-11)/1.5)+1;
|
||||||
|
|
||||||
rl = all_in_range(r, (int)range);
|
rl = all_in_range(r, (int)range);
|
||||||
|
|
||||||
|
@ -2341,21 +2340,18 @@ sp_stormwinds(castorder *co)
|
||||||
faction *f;
|
faction *f;
|
||||||
ship *sh;
|
ship *sh;
|
||||||
unit *u;
|
unit *u;
|
||||||
int n, force;
|
|
||||||
int erfolg = 0;
|
int erfolg = 0;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
int n, force = (int)power;
|
||||||
force = power;
|
|
||||||
|
|
||||||
/* melden vorbereiten */
|
/* melden vorbereiten */
|
||||||
for(f = factions; f; f = f->next ) freset(f, FL_DH);
|
for(f = factions; f; f = f->next ) freset(f, FL_DH);
|
||||||
|
|
||||||
for (n = 0; n < pa->length; n++) {
|
for (n = 0; n < pa->length; n++) {
|
||||||
if (!force)
|
if (force<=0) break;
|
||||||
break;
|
|
||||||
|
|
||||||
if(pa->param[n]->flag == TARGET_RESISTS
|
if(pa->param[n]->flag == TARGET_RESISTS
|
||||||
|| pa->param[n]->flag == TARGET_NOTFOUND)
|
|| pa->param[n]->flag == TARGET_NOTFOUND)
|
||||||
|
@ -2552,35 +2548,32 @@ sp_forest_fire(castorder *co)
|
||||||
{
|
{
|
||||||
unit *u;
|
unit *u;
|
||||||
region *nr;
|
region *nr;
|
||||||
int prozent, chance, vernichtet;
|
|
||||||
#if GROWING_TREES
|
|
||||||
int vernichtet_schoesslinge;
|
|
||||||
#endif
|
|
||||||
direction_t i;
|
direction_t i;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
|
double probability;
|
||||||
|
double percentage = (rand() % 8 + 1) * 0.1; /* 10 - 80% */
|
||||||
|
|
||||||
prozent = (rand() % 71) + 10; /* 10 - 80% */
|
|
||||||
#if GROWING_TREES
|
#if GROWING_TREES
|
||||||
vernichtet = rtrees(r,2) * prozent / 100;
|
int vernichtet_schoesslinge = (int)(rtrees(r, 1) * percentage);
|
||||||
vernichtet_schoesslinge = rtrees(r,1) * prozent / 100;
|
int destroyed = (int)(rtrees(r, 2) * percentage);
|
||||||
#else
|
#else
|
||||||
vernichtet = rtrees(r) * prozent / 100;
|
int destroyed = (int)(rtrees(r) * percentage);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
if(!vernichtet ) {
|
if (destroyed<1) {
|
||||||
cmistake(mage, strdup(co->order), 198, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 198, MSG_MAGIC);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
#if GROWING_TREES
|
#if GROWING_TREES
|
||||||
rsettrees(r, 2, rtrees(r,2) - vernichtet);
|
rsettrees(r, 2, rtrees(r,2) - destroyed);
|
||||||
rsettrees(r, 1, rtrees(r,1) - vernichtet_schoesslinge);
|
rsettrees(r, 1, rtrees(r,1) - vernichtet_schoesslinge);
|
||||||
#else
|
#else
|
||||||
rsettrees(r, rtrees(r) - vernichtet);
|
rsettrees(r, rtrees(r) - destroyed);
|
||||||
#endif
|
#endif
|
||||||
chance = vernichtet / 10; /* Chance, dass es sich ausbreitet */
|
probability = destroyed * 0.001; /* Chance, dass es sich ausbreitet */
|
||||||
|
|
||||||
/* melden, 1x pro Partei */
|
/* melden, 1x pro Partei */
|
||||||
for (u = r->units; u; u = u->next) freset(u->faction, FL_DH);
|
for (u = r->units; u; u = u->next) freset(u->faction, FL_DH);
|
||||||
|
@ -2591,20 +2584,20 @@ sp_forest_fire(castorder *co)
|
||||||
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
||||||
"den Flammen zum Opfer.",
|
"den Flammen zum Opfer.",
|
||||||
cansee(u->faction, r, mage, 0) ? unitname(mage) : "Jemand",
|
cansee(u->faction, r, mage, 0) ? unitname(mage) : "Jemand",
|
||||||
vernichtet,
|
destroyed,
|
||||||
vernichtet == 1 ? "Baum fiel" : "Bäume fielen");
|
destroyed == 1 ? "Baum fiel" : "Bäume fielen");
|
||||||
addmessage(r, u->faction, buf, MSG_EVENT, ML_INFO);
|
addmessage(r, u->faction, buf, MSG_EVENT, ML_INFO);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(!fval(mage->faction, FL_DH)){
|
if(!fval(mage->faction, FL_DH)){
|
||||||
#if GROWING_TREES
|
#if GROWING_TREES
|
||||||
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
||||||
"den Flammen zum Opfer.", unitname(mage), vernichtet+vernichtet_schoesslinge,
|
"den Flammen zum Opfer.", unitname(mage), destroyed+vernichtet_schoesslinge,
|
||||||
vernichtet+vernichtet_schoesslinge == 1 ? "Baum fiel" : "Bäume fielen");
|
destroyed+vernichtet_schoesslinge == 1 ? "Baum fiel" : "Bäume fielen");
|
||||||
#else
|
#else
|
||||||
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
sprintf(buf, "%s erzeugt eine verheerende Feuersbrunst. %d %s "
|
||||||
"den Flammen zum Opfer.", unitname(mage), vernichtet,
|
"den Flammen zum Opfer.", unitname(mage), destroyed,
|
||||||
vernichtet == 1 ? "Baum fiel" : "Bäume fielen");
|
destroyed == 1 ? "Baum fiel" : "Bäume fielen");
|
||||||
#endif
|
#endif
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
||||||
}
|
}
|
||||||
|
@ -2612,28 +2605,28 @@ sp_forest_fire(castorder *co)
|
||||||
for(i = 0; i < MAXDIRECTIONS; i++ ) {
|
for(i = 0; i < MAXDIRECTIONS; i++ ) {
|
||||||
nr = rconnect(r, i);
|
nr = rconnect(r, i);
|
||||||
assert(nr);
|
assert(nr);
|
||||||
vernichtet = 0;
|
destroyed = 0;
|
||||||
|
|
||||||
#if GROWING_TREES
|
#if GROWING_TREES
|
||||||
if(rtrees(nr,2) + rtrees(nr,1) >= 800) {
|
if(rtrees(nr,2) + rtrees(nr,1) >= 800) {
|
||||||
if((rand() % 100) < chance ) {
|
if (chance(probability)) {
|
||||||
vernichtet = rtrees(nr,2) * prozent / 200;
|
destroyed = (int)(rtrees(nr,2) * percentage/2);
|
||||||
vernichtet_schoesslinge = rtrees(nr,1) * prozent / 200;
|
vernichtet_schoesslinge = (int)(rtrees(nr,1) * percentage/2);
|
||||||
}
|
}
|
||||||
} else if (rtrees(nr,2) + rtrees(nr,1) >= 600) {
|
} else if (rtrees(nr,2) + rtrees(nr,1) >= 600) {
|
||||||
if((rand() % 100) < chance / 2 ) {
|
if (chance(probability/2)) {
|
||||||
vernichtet = rtrees(nr,2) * prozent / 400;
|
destroyed = (int)(rtrees(nr,2) * percentage/4);
|
||||||
vernichtet_schoesslinge = rtrees(nr,1) * prozent / 400;
|
vernichtet_schoesslinge = (int)(rtrees(nr,1) * percentage/4);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if(vernichtet > 0 || vernichtet_schoesslinge > 0) {
|
if (destroyed > 0 || vernichtet_schoesslinge > 0) {
|
||||||
rsettrees(nr, 2, rtrees(nr,2) - vernichtet);
|
rsettrees(nr, 2, rtrees(nr,2) - destroyed);
|
||||||
rsettrees(nr, 1, rtrees(nr,1) - vernichtet_schoesslinge);
|
rsettrees(nr, 1, rtrees(nr,1) - vernichtet_schoesslinge);
|
||||||
sprintf(buf, "Der Waldbrand in %s griff auch auf %s "
|
sprintf(buf, "Der Waldbrand in %s griff auch auf %s "
|
||||||
"über und %d %s.",
|
"über und %d %s.",
|
||||||
regionid(r), regionid(nr), vernichtet+vernichtet_schoesslinge,
|
regionid(r), regionid(nr), destroyed+vernichtet_schoesslinge,
|
||||||
vernichtet+vernichtet_schoesslinge == 1 ? "Baum verbrannte" : "Bäume verbrannten");
|
destroyed+vernichtet_schoesslinge == 1 ? "Baum verbrannte" : "Bäume verbrannten");
|
||||||
for (u = nr->units; u; u = u->next) freset(u->faction, FL_DH);
|
for (u = nr->units; u; u = u->next) freset(u->faction, FL_DH);
|
||||||
for(u = nr->units; u; u = u->next ) {
|
for(u = nr->units; u; u = u->next ) {
|
||||||
if(!fval(u->faction, FL_DH) ) {
|
if(!fval(u->faction, FL_DH) ) {
|
||||||
|
@ -2647,17 +2640,17 @@ sp_forest_fire(castorder *co)
|
||||||
}
|
}
|
||||||
#else
|
#else
|
||||||
if (rtrees(nr) >= 800) {
|
if (rtrees(nr) >= 800) {
|
||||||
if((rand() % 100) < chance ) vernichtet = rtrees(nr) * prozent / 200;
|
if (chance(probability)) destroyed = (int)(rtrees(nr) * percentage/2);
|
||||||
} else if (rtrees(nr) >= 600) {
|
} else if (rtrees(nr) >= 600) {
|
||||||
if((rand() % 100) < chance / 2 ) vernichtet = rtrees(nr) * prozent / 400;
|
if(chance(probability/2)) destroyed = (int)(rtrees(nr) * percentage/4);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(vernichtet > 0 ) {
|
if (destroyed > 0 ) {
|
||||||
rsettrees(nr, rtrees(nr) - vernichtet);
|
rsettrees(nr, rtrees(nr) - destroyed);
|
||||||
sprintf(buf, "Der Waldbrand in %s griff auch auf %s "
|
sprintf(buf, "Der Waldbrand in %s griff auch auf %s "
|
||||||
"über und %d %s.",
|
"über und %d %s.",
|
||||||
regionid(r), regionid(nr), vernichtet,
|
regionid(r), regionid(nr), destroyed,
|
||||||
vernichtet == 1 ? "Baum verbrannte" : "Bäume verbrannten");
|
destroyed == 1 ? "Baum verbrannte" : "Bäume verbrannten");
|
||||||
for (u = nr->units; u; u = u->next) freset(u->faction, FL_DH);
|
for (u = nr->units; u; u = u->next) freset(u->faction, FL_DH);
|
||||||
for(u = nr->units; u; u = u->next ) {
|
for(u = nr->units; u; u = u->next ) {
|
||||||
if(!fval(u->faction, FL_DH) ) {
|
if(!fval(u->faction, FL_DH) ) {
|
||||||
|
@ -2698,10 +2691,10 @@ sp_fumblecurse(castorder *co)
|
||||||
unit *target;
|
unit *target;
|
||||||
int rx, sx;
|
int rx, sx;
|
||||||
int duration;
|
int duration;
|
||||||
int effect;
|
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
|
int effect = (int)(force/2);
|
||||||
curse * c;
|
curse * c;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
|
||||||
|
@ -2714,8 +2707,6 @@ sp_fumblecurse(castorder *co)
|
||||||
sx = cast_level - effskill(target, SK_MAGIC);
|
sx = cast_level - effskill(target, SK_MAGIC);
|
||||||
duration = max(sx, rx) + 1;
|
duration = max(sx, rx) + 1;
|
||||||
|
|
||||||
effect = force/2;
|
|
||||||
|
|
||||||
c = create_curse(mage, &target->attribs, ct_find("fumble"),
|
c = create_curse(mage, &target->attribs, ct_find("fumble"),
|
||||||
force, duration, effect, 0);
|
force, duration, effect, 0);
|
||||||
if (c == NULL) {
|
if (c == NULL) {
|
||||||
|
@ -2736,12 +2727,10 @@ patzer_fumblecurse(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int effect;
|
int effect = (int)(force/2);
|
||||||
curse * c;
|
curse * c;
|
||||||
int duration = (cast_level/2)+1;
|
int duration = (cast_level/2)+1;
|
||||||
|
|
||||||
effect = force/2;
|
|
||||||
|
|
||||||
c = create_curse(mage, &mage->attribs, ct_find("fumble"), force,
|
c = create_curse(mage, &mage->attribs, ct_find("fumble"), force,
|
||||||
duration, effect, 0);
|
duration, effect, 0);
|
||||||
if (c!=NULL) {
|
if (c!=NULL) {
|
||||||
|
@ -3079,12 +3068,12 @@ sp_firewall(castorder *co)
|
||||||
if (b==NULL) {
|
if (b==NULL) {
|
||||||
b = new_border(&bt_firewall, r, r2);
|
b = new_border(&bt_firewall, r, r2);
|
||||||
fd = (wall_data*)b->data;
|
fd = (wall_data*)b->data;
|
||||||
fd->force = (force+1)/2;
|
fd->force = (int)(force/2+0.5);
|
||||||
fd->mage = mage;
|
fd->mage = mage;
|
||||||
fd->active = false;
|
fd->active = false;
|
||||||
} else {
|
} else {
|
||||||
fd = (wall_data*)b->data;
|
fd = (wall_data*)b->data;
|
||||||
fd->force = max(fd->force, (force+1)/2);
|
fd->force = (int)max(fd->force, force/2+0.5);
|
||||||
}
|
}
|
||||||
|
|
||||||
a = a_find(b->attribs, &at_countdown);
|
a = a_find(b->attribs, &at_countdown);
|
||||||
|
@ -3166,7 +3155,7 @@ sp_wisps(castorder *co)
|
||||||
|
|
||||||
b = new_border(&bt_wisps, r, r2);
|
b = new_border(&bt_wisps, r, r2);
|
||||||
fd = (wall_data*)b->data;
|
fd = (wall_data*)b->data;
|
||||||
fd->force = (force+1)/2;
|
fd->force = (int)(force/2+0.5);
|
||||||
fd->mage = mage;
|
fd->mage = mage;
|
||||||
fd->active = false;
|
fd->active = false;
|
||||||
|
|
||||||
|
@ -3216,7 +3205,7 @@ sp_unholypower(castorder *co)
|
||||||
int n;
|
int n;
|
||||||
int wounds;
|
int wounds;
|
||||||
|
|
||||||
n = dice(co->force, 10);
|
n = dice((int)co->force, 10);
|
||||||
|
|
||||||
for (i = 0; i < pa->length && n > 0; i++) {
|
for (i = 0; i < pa->length && n > 0; i++) {
|
||||||
const race * target_race;
|
const race * target_race;
|
||||||
|
@ -3465,7 +3454,7 @@ sp_summonshadow(castorder *co)
|
||||||
unit *u;
|
unit *u;
|
||||||
int val;
|
int val;
|
||||||
|
|
||||||
u = createunit(r, mage->faction, force*force, new_race[RC_SHADOW]);
|
u = createunit(r, mage->faction, (int)(force*force), new_race[RC_SHADOW]);
|
||||||
if (r==mage->region) {
|
if (r==mage->region) {
|
||||||
u->building = mage->building;
|
u->building = mage->building;
|
||||||
u->ship = mage->ship;
|
u->ship = mage->ship;
|
||||||
|
@ -3512,7 +3501,7 @@ sp_summonshadowlords(castorder *co)
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
|
|
||||||
u = createunit(r, mage->faction, force*force, new_race[RC_SHADOWLORD]);
|
u = createunit(r, mage->faction, (int)(force*force), new_race[RC_SHADOWLORD]);
|
||||||
if (r==mage->region) {
|
if (r==mage->region) {
|
||||||
u->building = mage->building;
|
u->building = mage->building;
|
||||||
u->ship = mage->ship;
|
u->ship = mage->ship;
|
||||||
|
@ -3673,14 +3662,14 @@ sp_bloodsacrifice(castorder *co)
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int aura;
|
int aura;
|
||||||
int skill = eff_skill(mage, SK_MAGIC, mage->region);
|
int skill = eff_skill(mage, SK_MAGIC, mage->region);
|
||||||
double hp = co->force*4;
|
int hp = (int)(co->force*8);
|
||||||
|
|
||||||
if (hp <= 0) {
|
if (hp <= 0) {
|
||||||
report_failure(mage, co->order);
|
report_failure(mage, co->order);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
aura = lovar(hp*2);
|
aura = lovar(hp);
|
||||||
|
|
||||||
if (skill < 8) {
|
if (skill < 8) {
|
||||||
aura /= 4;
|
aura /= 4;
|
||||||
|
@ -3729,7 +3718,7 @@ sp_summonundead(castorder *co)
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
int force = (int)(co->force*10);
|
||||||
const race * race = new_race[RC_SKELETON];
|
const race * race = new_race[RC_SKELETON];
|
||||||
|
|
||||||
if (!r->land || deathcount(r) == 0) {
|
if (!r->land || deathcount(r) == 0) {
|
||||||
|
@ -3739,7 +3728,7 @@ sp_summonundead(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
undead = min(deathcount(r), 2 + lovar(force * 10));
|
undead = min(deathcount(r), 2 + lovar(force));
|
||||||
|
|
||||||
if(cast_level <= 8) {
|
if(cast_level <= 8) {
|
||||||
race = new_race[RC_SKELETON];
|
race = new_race[RC_SKELETON];
|
||||||
|
@ -4027,7 +4016,7 @@ sp_charmingsong(castorder *co)
|
||||||
|
|
||||||
/* Magieresistensbonus für mehr als Stufe Personen */
|
/* Magieresistensbonus für mehr als Stufe Personen */
|
||||||
if (target->number > force) {
|
if (target->number > force) {
|
||||||
resist_bonus += (target->number - force) * 10;
|
resist_bonus += (int)((target->number - force) * 10);
|
||||||
}
|
}
|
||||||
/* Magieresistensbonus für höhere Talentwerte */
|
/* Magieresistensbonus für höhere Talentwerte */
|
||||||
for(i = 0; i < MAXSKILLS; i++){
|
for(i = 0; i < MAXSKILLS; i++){
|
||||||
|
@ -4096,7 +4085,7 @@ sp_song_resistmagic(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
create_curse(mage, &r->attribs, ct_find("goodmagicresistancezone"),
|
create_curse(mage, &r->attribs, ct_find("goodmagicresistancezone"),
|
||||||
force, duration, mr_bonus, 0);
|
force, duration, mr_bonus, 0);
|
||||||
|
@ -4127,7 +4116,7 @@ sp_song_susceptmagic(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
create_curse(mage, &r->attribs, ct_find("badmagicresistancezone"),
|
create_curse(mage, &r->attribs, ct_find("badmagicresistancezone"),
|
||||||
force, duration, mr_malus, 0);
|
force, duration, mr_malus, 0);
|
||||||
|
@ -4227,7 +4216,7 @@ sp_raisepeasantmob(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
anteil += rand()%4;
|
anteil += rand()%4;
|
||||||
|
|
||||||
|
@ -4406,10 +4395,8 @@ sp_song_of_peace(castorder *co)
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
|
|
||||||
if(force < 2)
|
if (force < 2) duration = 0;
|
||||||
duration = 0;
|
else duration = lovar(force/2);
|
||||||
else
|
|
||||||
duration = lovar(force/2);
|
|
||||||
|
|
||||||
create_curse(mage,&r->attribs, ct_find("peacezone"), force, duration, 1,0);
|
create_curse(mage,&r->attribs, ct_find("peacezone"), force, duration, 1,0);
|
||||||
|
|
||||||
|
@ -4450,7 +4437,7 @@ sp_generous(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
if(is_cursed(r->attribs, C_DEPRESSION, 0)){
|
if(is_cursed(r->attribs, C_DEPRESSION, 0)){
|
||||||
sprintf(buf, "%s in %s: Die Stimmung in %s ist so schlecht, das "
|
sprintf(buf, "%s in %s: Die Stimmung in %s ist so schlecht, das "
|
||||||
|
@ -4559,9 +4546,7 @@ sp_bigrecruit(castorder *co)
|
||||||
}
|
}
|
||||||
/* Für vergleichbare Erfolge bei unterschiedlichen Rassen die
|
/* Für vergleichbare Erfolge bei unterschiedlichen Rassen die
|
||||||
* Rekrutierungskosten mit einfliessen lassen. */
|
* Rekrutierungskosten mit einfliessen lassen. */
|
||||||
n = (int)((force * force * 1000)/f->race->recruitcost);
|
n = (int)force + lovar((force * force * 1000)/f->race->recruitcost);
|
||||||
/* Zufälliger Wert mit n/2 Maximum, mindestens aber force Anzahl */
|
|
||||||
n = force+lovar(n);
|
|
||||||
/* natürlich nur maximal soviele Bauern, wie auch in der Region sind */
|
/* natürlich nur maximal soviele Bauern, wie auch in der Region sind */
|
||||||
n = min(rpeasants(r), n);
|
n = min(rpeasants(r), n);
|
||||||
|
|
||||||
|
@ -4711,7 +4696,7 @@ sp_seduce(castorder *co)
|
||||||
loot += rand() % 2;
|
loot += rand() % 2;
|
||||||
}
|
}
|
||||||
if (loot > 0) {
|
if (loot > 0) {
|
||||||
loot = min(loot, force * 5);
|
loot = (int)min(loot, force * 5);
|
||||||
scat(", ");
|
scat(", ");
|
||||||
icat(loot);
|
icat(loot);
|
||||||
scat(" ");
|
scat(" ");
|
||||||
|
@ -4773,7 +4758,6 @@ sp_create_nimblefingerring(castorder *co)
|
||||||
static int
|
static int
|
||||||
sp_calm_monster(castorder *co)
|
sp_calm_monster(castorder *co)
|
||||||
{
|
{
|
||||||
int duration;
|
|
||||||
curse * c;
|
curse * c;
|
||||||
unit *target;
|
unit *target;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
|
@ -4783,8 +4767,6 @@ sp_calm_monster(castorder *co)
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
spell *sp = co->sp;
|
spell *sp = co->sp;
|
||||||
|
|
||||||
duration = force;
|
|
||||||
|
|
||||||
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
||||||
if(pa->param[0]->flag == TARGET_NOTFOUND) return 0;
|
if(pa->param[0]->flag == TARGET_NOTFOUND) return 0;
|
||||||
|
|
||||||
|
@ -4797,8 +4779,8 @@ sp_calm_monster(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
c = create_curse(mage, &target->attribs, ct_find("calmmonster"), force, duration,
|
c = create_curse(mage, &target->attribs, ct_find("calmmonster"), force,
|
||||||
(int)mage->faction, 0);
|
(int)force, (int)mage->faction, 0);
|
||||||
if (c==NULL) {
|
if (c==NULL) {
|
||||||
report_failure(mage, co->order);
|
report_failure(mage, co->order);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -4899,7 +4881,7 @@ sp_raisepeasants(castorder *co)
|
||||||
MSG_MAGIC, ML_MISTAKE);
|
MSG_MAGIC, ML_MISTAKE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
bauern = min(rpeasants(r),power*250);
|
bauern = (int)min(rpeasants(r), power*250);
|
||||||
rsetpeasants(r, rpeasants(r) - bauern);
|
rsetpeasants(r, rpeasants(r) - bauern);
|
||||||
|
|
||||||
u2 = create_unit(r,mage->faction, bauern, new_race[RC_PEASANT], 0,"Wilder Bauernmob",mage);
|
u2 = create_unit(r,mage->faction, bauern, new_race[RC_PEASANT], 0,"Wilder Bauernmob",mage);
|
||||||
|
@ -4944,7 +4926,7 @@ sp_depression(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
create_curse(mage,&r->attribs, ct_find("depression"), force, duration, 0, 0);
|
create_curse(mage,&r->attribs, ct_find("depression"), force, duration, 0, 0);
|
||||||
|
|
||||||
|
@ -5066,9 +5048,9 @@ sp_puttorest(castorder *co)
|
||||||
{
|
{
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int laid_to_rest = 0;
|
int dead = deathcount(r);
|
||||||
laid_to_rest = dice(co->force * 2, 100);
|
int laid_to_rest = dice((int)(co->force * 2), 100);
|
||||||
laid_to_rest = max(laid_to_rest, deathcount(r));
|
laid_to_rest = max(laid_to_rest, dead);
|
||||||
|
|
||||||
deathcounts(r, -laid_to_rest);
|
deathcounts(r, -laid_to_rest);
|
||||||
|
|
||||||
|
@ -5191,7 +5173,7 @@ sp_illusionary_shapeshift(castorder *co)
|
||||||
}
|
}
|
||||||
{
|
{
|
||||||
trigger * trestore = trigger_changerace(u, NULL, u->irace);
|
trigger * trestore = trigger_changerace(u, NULL, u->irace);
|
||||||
add_trigger(&u->attribs, "timer", trigger_timeout(power+2, trestore));
|
add_trigger(&u->attribs, "timer", trigger_timeout((int)power+2, trestore));
|
||||||
}
|
}
|
||||||
u->irace = rc;
|
u->irace = rc;
|
||||||
|
|
||||||
|
@ -5328,7 +5310,7 @@ sp_baddreams(castorder *co)
|
||||||
|
|
||||||
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
|
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
|
||||||
* also duration+2 */
|
* also duration+2 */
|
||||||
duration = max(1, power/2); /* Stufe 1 macht sonst mist */
|
duration = (int)max(1, power/2); /* Stufe 1 macht sonst mist */
|
||||||
duration = 2 + rand()%duration;
|
duration = 2 + rand()%duration;
|
||||||
|
|
||||||
/* Nichts machen als ein entsprechendes Attribut in die Region legen. */
|
/* Nichts machen als ein entsprechendes Attribut in die Region legen. */
|
||||||
|
@ -5367,7 +5349,7 @@ sp_gooddreams(castorder *co)
|
||||||
|
|
||||||
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
|
/* wirkt erst in der Folgerunde, soll mindestens eine Runde wirken,
|
||||||
* also duration+2 */
|
* also duration+2 */
|
||||||
duration = max(1, power/2); /* Stufe 1 macht sonst mist */
|
duration = (int)max(1, power/2); /* Stufe 1 macht sonst mist */
|
||||||
duration = 2 + rand()%duration;
|
duration = 2 + rand()%duration;
|
||||||
c = create_curse(mage, &r->attribs, ct_find("gbdream"), power, duration, 1, 0);
|
c = create_curse(mage, &r->attribs, ct_find("gbdream"), power, duration, 1, 0);
|
||||||
curse_setflag(c, CURSE_ISNEW);
|
curse_setflag(c, CURSE_ISNEW);
|
||||||
|
@ -5482,8 +5464,8 @@ sp_sweetdreams(castorder *co)
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
int men, n;
|
int men, n;
|
||||||
int duration = 1+(power/2);
|
int duration = (int)(power/2)+1;
|
||||||
int opfer = power*power;
|
int opfer = (int)(power*power);
|
||||||
|
|
||||||
/* Schleife über alle angegebenen Einheiten */
|
/* Schleife über alle angegebenen Einheiten */
|
||||||
for (n = 0; n < pa->length; n++) {
|
for (n = 0; n < pa->length; n++) {
|
||||||
|
@ -5533,7 +5515,7 @@ sp_disturbingdreams(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
int duration = 1 + (power/6);
|
int duration = 1 + (int)(power/6);
|
||||||
curse * c = create_curse(mage, &r->attribs, ct_find("badlearn"), power, duration, 10, 0);
|
curse * c = create_curse(mage, &r->attribs, ct_find("badlearn"), power, duration, 10, 0);
|
||||||
curse_setflag(c, CURSE_ISNEW);
|
curse_setflag(c, CURSE_ISNEW);
|
||||||
|
|
||||||
|
@ -5554,7 +5536,7 @@ sp_dream_of_confusion(castorder *co)
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
double range = (power-14)/2-1;
|
double range = (power-14)/2-1;
|
||||||
int duration = ((power-14)/2)*2+1;
|
int duration = (int)(power-14)+1;
|
||||||
|
|
||||||
rl = all_in_range(r, (int)range);
|
rl = all_in_range(r, (int)range);
|
||||||
|
|
||||||
|
@ -5665,7 +5647,7 @@ sp_itemcloak(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
int duration = power+1;
|
int duration = (int)power+1;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
|
||||||
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
/* wenn kein Ziel gefunden, Zauber abbrechen */
|
||||||
|
@ -5709,7 +5691,7 @@ sp_resist_magic_bonus(castorder *co)
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
|
||||||
/* Pro Stufe können bis zu 5 Personen verzaubert werden */
|
/* Pro Stufe können bis zu 5 Personen verzaubert werden */
|
||||||
opfer = power * 5;
|
opfer = (int)(power * 5);
|
||||||
|
|
||||||
/* Schleife über alle angegebenen Einheiten */
|
/* Schleife über alle angegebenen Einheiten */
|
||||||
for (n = 0; n < pa->length; n++) {
|
for (n = 0; n < pa->length; n++) {
|
||||||
|
@ -5802,7 +5784,7 @@ sp_enterastral(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
remaining_cap = (power-3) * 1500;
|
remaining_cap = (int)((power-3) * 1500);
|
||||||
|
|
||||||
/* für jede Einheit in der Kommandozeile */
|
/* für jede Einheit in der Kommandozeile */
|
||||||
for (n = 0; n < pa->length; n++) {
|
for (n = 0; n < pa->length; n++) {
|
||||||
|
@ -5927,7 +5909,7 @@ sp_pullastral(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
remaining_cap = (power-3) * 1500;
|
remaining_cap = (int)((power-3) * 1500);
|
||||||
|
|
||||||
/* für jede Einheit in der Kommandozeile */
|
/* für jede Einheit in der Kommandozeile */
|
||||||
for (n = 1; n < pa->length; n++) {
|
for (n = 1; n < pa->length; n++) {
|
||||||
|
@ -6042,15 +6024,13 @@ sp_leaveastral(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(!ro
|
if (ro==NULL || is_cursed(ro->attribs, C_ASTRALBLOCK, 0) || is_cursed(rt->attribs, C_ASTRALBLOCK, 0)) {
|
||||||
|| is_cursed(ro->attribs, C_ASTRALBLOCK, 0)
|
|
||||||
|| is_cursed(rt->attribs, C_ASTRALBLOCK, 0)) {
|
|
||||||
sprintf(buf, "Die Wege aus dieser astralen Region sind blockiert.");
|
sprintf(buf, "Die Wege aus dieser astralen Region sind blockiert.");
|
||||||
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
addmessage(r, mage->faction, buf, MSG_MAGIC, ML_MISTAKE);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
remaining_cap = (power-3) * 1500;
|
remaining_cap = (int)((power-3) * 1500);
|
||||||
|
|
||||||
/* für jede Einheit in der Kommandozeile */
|
/* für jede Einheit in der Kommandozeile */
|
||||||
for (n = 1; n < pa->length; n++) {
|
for (n = 1; n < pa->length; n++) {
|
||||||
|
@ -6157,7 +6137,7 @@ sp_fetchastral(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
remaining_cap = (power-3) * 1500;
|
remaining_cap = (int)((power-3) * 1500);
|
||||||
|
|
||||||
/* für jede Einheit in der Kommandozeile */
|
/* für jede Einheit in der Kommandozeile */
|
||||||
for (n = 0; n < pa->length; n++) {
|
for (n = 0; n < pa->length; n++) {
|
||||||
|
@ -6379,7 +6359,7 @@ sp_disruptastral(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double power = co->force;
|
double power = co->force;
|
||||||
int duration = (power/3)+1;
|
int duration = (int)(power/3)+1;
|
||||||
|
|
||||||
switch(getplaneid(r)) {
|
switch(getplaneid(r)) {
|
||||||
case 0:
|
case 0:
|
||||||
|
@ -6399,7 +6379,7 @@ sp_disruptastral(castorder *co)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
rl = all_in_range(rt, power/5);
|
rl = all_in_range(rt, (int)(power/5));
|
||||||
|
|
||||||
for(rl2=rl; rl; rl=rl->next) {
|
for(rl2=rl; rl; rl=rl->next) {
|
||||||
attrib *a, *a2;
|
attrib *a, *a2;
|
||||||
|
@ -6848,13 +6828,13 @@ sp_create_antimagiccrystal(castorder *co)
|
||||||
int
|
int
|
||||||
sp_antimagiczone(castorder *co)
|
sp_antimagiczone(castorder *co)
|
||||||
{
|
{
|
||||||
int power;
|
double power;
|
||||||
int effect;
|
int effect;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
int duration = force+1;
|
int duration = (int)force+1;
|
||||||
|
|
||||||
/* Hält Sprüche bis zu einem summierten Gesamtlevel von power aus.
|
/* Hält Sprüche bis zu einem summierten Gesamtlevel von power aus.
|
||||||
* Jeder Zauber reduziert die 'Lebenskraft' (vigour) der Antimagiezone
|
* Jeder Zauber reduziert die 'Lebenskraft' (vigour) der Antimagiezone
|
||||||
|
@ -7111,7 +7091,6 @@ sp_destroy_curse(castorder *co)
|
||||||
attrib **ap;
|
attrib **ap;
|
||||||
int obj;
|
int obj;
|
||||||
curse * c;
|
curse * c;
|
||||||
int succ = 0;
|
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
|
@ -7176,10 +7155,9 @@ sp_destroy_curse(castorder *co)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* curse auflösen, wenn zauber stärker (force > vigour)*/
|
/* curse auflösen, wenn zauber stärker (force > vigour)*/
|
||||||
succ = c->vigour - force;
|
c->vigour -= force;
|
||||||
c->vigour = max(0, succ);
|
|
||||||
|
|
||||||
if(succ <= 0) {
|
if (c->vigour <= 0.0) {
|
||||||
remove_curse(ap, c);
|
remove_curse(ap, c);
|
||||||
|
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
|
@ -7247,10 +7225,9 @@ sp_earn_silver(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
double force = co->force;
|
double force = co->force;
|
||||||
region *r = co->rt;
|
region *r = co->rt;
|
||||||
int wanted, earned;
|
int wanted = (int)(force * 50);
|
||||||
|
int earned = min(rmoney(r), wanted);
|
||||||
|
|
||||||
wanted = force * 50;
|
|
||||||
earned = min(rmoney(r), wanted);
|
|
||||||
rsetmoney(r, rmoney(r) - earned);
|
rsetmoney(r, rmoney(r) - earned);
|
||||||
change_money(mage, earned);
|
change_money(mage, earned);
|
||||||
/* TODO klären: ist das Silber damit schon reserviert? */
|
/* TODO klären: ist das Silber damit schon reserviert? */
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
ObjectFile=".\Debug/"
|
ObjectFile=".\Debug/"
|
||||||
ProgramDataBaseFileName=".\Debug/"
|
ProgramDataBaseFileName=".\Debug/"
|
||||||
WarningLevel="4"
|
WarningLevel="4"
|
||||||
SuppressStartupBanner="FALSE"
|
SuppressStartupBanner="TRUE"
|
||||||
DebugInformationFormat="1"
|
DebugInformationFormat="1"
|
||||||
CompileAs="0"/>
|
CompileAs="0"/>
|
||||||
<Tool
|
<Tool
|
||||||
|
|
|
@ -40,7 +40,7 @@ typedef struct createcurse_data {
|
||||||
struct unit * mage;
|
struct unit * mage;
|
||||||
struct unit * target;
|
struct unit * target;
|
||||||
const curse_type * type;
|
const curse_type * type;
|
||||||
int vigour;
|
double vigour;
|
||||||
int duration;
|
int duration;
|
||||||
int effect;
|
int effect;
|
||||||
int men;
|
int men;
|
||||||
|
@ -81,7 +81,7 @@ createcurse_write(const trigger * t, FILE * F)
|
||||||
createcurse_data * td = (createcurse_data*)t->data.v;
|
createcurse_data * td = (createcurse_data*)t->data.v;
|
||||||
fprintf(F, "%s ", itoa36(td->mage->no));
|
fprintf(F, "%s ", itoa36(td->mage->no));
|
||||||
fprintf(F, "%s ", itoa36(td->target->no));
|
fprintf(F, "%s ", itoa36(td->target->no));
|
||||||
fprintf(F, "%s %d %d %d %d ", td->type->cname, td->vigour, td->duration, td->effect, td->men);
|
fprintf(F, "%s %lf %d %d %d ", td->type->cname, td->vigour, td->duration, td->effect, td->men);
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
|
@ -103,11 +103,11 @@ createcurse_read(trigger * t, FILE * F)
|
||||||
|
|
||||||
if (global.data_version<CURSETYPE_VERSION) {
|
if (global.data_version<CURSETYPE_VERSION) {
|
||||||
int id1, id2;
|
int id1, id2;
|
||||||
fscanf(F, "%d %d %d %d %d %d ", &id1, &id2, &td->vigour, &td->duration, &td->effect, &td->men);
|
fscanf(F, "%d %d %lf %d %d %d ", &id1, &id2, &td->vigour, &td->duration, &td->effect, &td->men);
|
||||||
assert(id2==0);
|
assert(id2==0);
|
||||||
td->type = ct_find(oldcursename(id1));
|
td->type = ct_find(oldcursename(id1));
|
||||||
} else {
|
} else {
|
||||||
fscanf(F, "%s %d %d %d %d ", zText, &td->vigour, &td->duration, &td->effect, &td->men);
|
fscanf(F, "%s %lf %d %d %d ", zText, &td->vigour, &td->duration, &td->effect, &td->men);
|
||||||
td->type = ct_find(zText);
|
td->type = ct_find(zText);
|
||||||
}
|
}
|
||||||
return AT_READ_OK;
|
return AT_READ_OK;
|
||||||
|
@ -124,7 +124,7 @@ trigger_type tt_createcurse = {
|
||||||
|
|
||||||
trigger *
|
trigger *
|
||||||
trigger_createcurse(struct unit * mage, struct unit * target,
|
trigger_createcurse(struct unit * mage, struct unit * target,
|
||||||
const curse_type * ct, int vigour, int duration,
|
const curse_type * ct, double vigour, int duration,
|
||||||
int effect, int men)
|
int effect, int men)
|
||||||
{
|
{
|
||||||
trigger * t = t_new(&tt_createcurse);
|
trigger * t = t_new(&tt_createcurse);
|
||||||
|
|
|
@ -28,7 +28,7 @@ struct unit;
|
||||||
|
|
||||||
extern struct trigger_type tt_createcurse;
|
extern struct trigger_type tt_createcurse;
|
||||||
|
|
||||||
extern struct trigger * trigger_createcurse(struct unit * mage, struct unit * target, const struct curse_type * ct, int vigour, int duration, int effect, int men);
|
extern struct trigger * trigger_createcurse(struct unit * mage, struct unit * target, const struct curse_type * ct, double vigour, int duration, int effect, int men);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
File diff suppressed because it is too large
Load diff
Loading…
Reference in a new issue