forked from github/server
verbessertes ZAUBER Stufe 1 handling
This commit is contained in:
parent
caf0af013d
commit
132a7c0ef4
1 changed files with 22 additions and 15 deletions
|
@ -844,6 +844,7 @@ sp_goodwinds(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int power = co->force;
|
int power = co->force;
|
||||||
|
int duration = cast_level+1;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
ship *sh;
|
ship *sh;
|
||||||
unit *u;
|
unit *u;
|
||||||
|
@ -855,7 +856,7 @@ sp_goodwinds(castorder *co)
|
||||||
|
|
||||||
/* keine Probleme mit C_SHIP_SPEEDUP und C_SHIP_FLYING */
|
/* keine Probleme mit C_SHIP_SPEEDUP und C_SHIP_FLYING */
|
||||||
/* NODRIFT bewirkt auch +1 Geschwindigkeit */
|
/* NODRIFT bewirkt auch +1 Geschwindigkeit */
|
||||||
create_curse(mage, &sh->attribs, ct_find("nodrift"), power, cast_level, 0, 0);
|
create_curse(mage, &sh->attribs, ct_find("nodrift"), power, duration, 0, 0);
|
||||||
|
|
||||||
/* melden, 1x pro Partei */
|
/* melden, 1x pro Partei */
|
||||||
freset(mage->faction, FL_DH);
|
freset(mage->faction, FL_DH);
|
||||||
|
@ -900,6 +901,7 @@ sp_magicstreet(castorder *co)
|
||||||
int power = co->force;
|
int power = co->force;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
direction_t dir;
|
direction_t dir;
|
||||||
|
int duration = cast_level+1;
|
||||||
|
|
||||||
if(!(landregion(rterrain(r)))){
|
if(!(landregion(rterrain(r)))){
|
||||||
cmistake(mage, strdup(co->order), 186, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 186, MSG_MAGIC);
|
||||||
|
@ -913,7 +915,7 @@ sp_magicstreet(castorder *co)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* wirkt schon in der Zauberrunde! */
|
/* wirkt schon in der Zauberrunde! */
|
||||||
create_curse(mage, &r->attribs, ct_find("magicstreet"), power, cast_level, 0, 0);
|
create_curse(mage, &r->attribs, ct_find("magicstreet"), power, duration, 0, 0);
|
||||||
|
|
||||||
/* melden, 1x pro Partei */
|
/* melden, 1x pro Partei */
|
||||||
{
|
{
|
||||||
|
@ -1063,6 +1065,7 @@ sp_maelstrom(castorder *co)
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
curse * c;
|
curse * c;
|
||||||
int power = co->force;
|
int power = co->force;
|
||||||
|
int duration = power+1;
|
||||||
|
|
||||||
if(rterrain(r) != T_OCEAN) {
|
if(rterrain(r) != T_OCEAN) {
|
||||||
cmistake(mage, strdup(co->order), 205, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 205, MSG_MAGIC);
|
||||||
|
@ -1073,7 +1076,7 @@ sp_maelstrom(castorder *co)
|
||||||
/* Attribut auf Region.
|
/* Attribut auf Region.
|
||||||
* Existiert schon ein curse, so wird dieser verstärkt
|
* Existiert schon ein curse, so wird dieser verstärkt
|
||||||
* (Max(Dauer), Max(Stärke))*/
|
* (Max(Dauer), Max(Stärke))*/
|
||||||
c = create_curse(mage, &mage->attribs, ct_find("maelstrom"), power, power, power,0);
|
c = create_curse(mage, &mage->attribs, ct_find("maelstrom"), power, duration, power,0);
|
||||||
curse_setflag(c, CURSE_ISNEW);
|
curse_setflag(c, CURSE_ISNEW);
|
||||||
|
|
||||||
/* melden, 1x pro Partei */
|
/* melden, 1x pro Partei */
|
||||||
|
@ -1152,11 +1155,12 @@ sp_blessedharvest(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int power = co->force;
|
int power = co->force;
|
||||||
|
int duration = power+1;
|
||||||
|
|
||||||
/* Attribut auf Region.
|
/* Attribut auf Region.
|
||||||
* Existiert schon ein curse, so wird dieser verstärkt
|
* Existiert schon ein curse, so wird dieser verstärkt
|
||||||
* (Max(Dauer), Max(Stärke))*/
|
* (Max(Dauer), Max(Stärke))*/
|
||||||
create_curse(mage,&r->attribs, ct_find("blessedharvest"), power, power, 1, 0);
|
create_curse(mage,&r->attribs, ct_find("blessedharvest"), power, duration, 1, 0);
|
||||||
{
|
{
|
||||||
message * seen = msg_message("harvest_effect", "mage", mage);
|
message * seen = msg_message("harvest_effect", "mage", mage);
|
||||||
message * unseen = msg_message("harvest_effect", "mage", NULL);
|
message * unseen = msg_message("harvest_effect", "mage", NULL);
|
||||||
|
@ -1413,7 +1417,7 @@ sp_kaelteschutz(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int force = co->force;
|
int force = co->force;
|
||||||
int duration = max(cast_level, force);
|
int duration = max(cast_level, force) + 1;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
|
||||||
|
|
||||||
|
@ -1473,6 +1477,7 @@ sp_sparkle(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
spellparameter *pa = co->par;
|
spellparameter *pa = co->par;
|
||||||
|
int duration = cast_level+1;
|
||||||
|
|
||||||
/* 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;
|
||||||
|
@ -1483,7 +1488,7 @@ sp_sparkle(castorder *co)
|
||||||
|
|
||||||
u = pa->param[0]->data.u;
|
u = pa->param[0]->data.u;
|
||||||
create_curse(mage, &u->attribs, ct_find("sparkle"), cast_level,
|
create_curse(mage, &u->attribs, ct_find("sparkle"), cast_level,
|
||||||
cast_level, rand(), u->number);
|
duration, rand(), u->number);
|
||||||
|
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"sparkle_effect%u:mage%u:target", mage, u));
|
"sparkle_effect%u:mage%u:target", mage, u));
|
||||||
|
@ -1657,6 +1662,7 @@ sp_great_drought(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int force = co->force;
|
int force = co->force;
|
||||||
|
int duration = 2;
|
||||||
|
|
||||||
if(rterrain(r) == T_OCEAN ) {
|
if(rterrain(r) == T_OCEAN ) {
|
||||||
cmistake(mage, strdup(co->order), 189, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 189, MSG_MAGIC);
|
||||||
|
@ -1676,7 +1682,7 @@ sp_great_drought(castorder *co)
|
||||||
rsethorses(r, rhorses(r)/2);
|
rsethorses(r, rhorses(r)/2);
|
||||||
|
|
||||||
/* Arbeitslohn = 1/4 */
|
/* Arbeitslohn = 1/4 */
|
||||||
create_curse(mage, &r->attribs, ct_find("drought"), force, 1, 4, 0);
|
create_curse(mage, &r->attribs, ct_find("drought"), force, duration, 4, 0);
|
||||||
|
|
||||||
/* terraforming */
|
/* terraforming */
|
||||||
if (rand() % 100 < 25){
|
if (rand() % 100 < 25){
|
||||||
|
@ -2099,7 +2105,6 @@ sp_homestone(castorder *co)
|
||||||
cmistake(mage, strdup(co->order), 206, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 206, MSG_MAGIC);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
curse_setflag(c, CURSE_NOAGE|CURSE_ONLYONE);
|
curse_setflag(c, CURSE_NOAGE|CURSE_ONLYONE);
|
||||||
|
|
||||||
/* Magieresistenz der Burg erhöht sich um 50% */
|
/* Magieresistenz der Burg erhöht sich um 50% */
|
||||||
|
@ -2148,6 +2153,7 @@ sp_drought(castorder *co)
|
||||||
unit *mage = (unit *)co->magician;
|
unit *mage = (unit *)co->magician;
|
||||||
int cast_level = co->level;
|
int cast_level = co->level;
|
||||||
int power = co->force;
|
int power = co->force;
|
||||||
|
int duration = power+1;
|
||||||
|
|
||||||
if(rterrain(r) == T_OCEAN ) {
|
if(rterrain(r) == T_OCEAN ) {
|
||||||
cmistake(mage, strdup(co->order), 189, MSG_MAGIC);
|
cmistake(mage, strdup(co->order), 189, MSG_MAGIC);
|
||||||
|
@ -2190,7 +2196,7 @@ sp_drought(castorder *co)
|
||||||
#endif
|
#endif
|
||||||
rsethorses(r, rhorses(r)/2);
|
rsethorses(r, rhorses(r)/2);
|
||||||
|
|
||||||
create_curse(mage, &r->attribs, ct_find("drought"), power, power, 4, 0);
|
create_curse(mage, &r->attribs, ct_find("drought"), power, duration, 4, 0);
|
||||||
}
|
}
|
||||||
return cast_level;
|
return cast_level;
|
||||||
}
|
}
|
||||||
|
@ -2222,7 +2228,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;
|
duration = ((power-11)/3)*2+1;
|
||||||
|
|
||||||
rl = all_in_range(r, range);
|
rl = all_in_range(r, range);
|
||||||
|
|
||||||
|
@ -2702,12 +2708,12 @@ sp_fumblecurse(castorder *co)
|
||||||
|
|
||||||
rx = rand()%3;
|
rx = rand()%3;
|
||||||
sx = cast_level - effskill(target, SK_MAGIC);
|
sx = cast_level - effskill(target, SK_MAGIC);
|
||||||
duration = max(sx, rx);
|
duration = max(sx, rx) + 1;
|
||||||
|
|
||||||
effect = force/2;
|
effect = force/2;
|
||||||
|
|
||||||
c = create_curse(mage, &target->attribs, ct_find("fumble"),
|
c = create_curse(mage, &target->attribs, ct_find("fumble"),
|
||||||
force, duration+1, effect, 0);
|
force, duration, effect, 0);
|
||||||
if (c == NULL) {
|
if (c == NULL) {
|
||||||
report_failure(mage, co->order);
|
report_failure(mage, co->order);
|
||||||
return 0;
|
return 0;
|
||||||
|
@ -2728,11 +2734,12 @@ patzer_fumblecurse(castorder *co)
|
||||||
int force = co->force;
|
int force = co->force;
|
||||||
int effect;
|
int effect;
|
||||||
curse * c;
|
curse * c;
|
||||||
|
int duration = (cast_level/2)+1;
|
||||||
|
|
||||||
effect = force/2;
|
effect = force/2;
|
||||||
|
|
||||||
c = create_curse(mage, &mage->attribs, ct_find("fumble"), force,
|
c = create_curse(mage, &mage->attribs, ct_find("fumble"), force,
|
||||||
(cast_level/2)+1, effect, 0);
|
duration, effect, 0);
|
||||||
if (c!=NULL) {
|
if (c!=NULL) {
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
"magic_fumble%u:unit%r:region%s:command",
|
"magic_fumble%u:unit%r:region%s:command",
|
||||||
|
@ -4063,10 +4070,10 @@ 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;
|
||||||
int force = co->force;
|
int force = co->force;
|
||||||
|
int duration = force+1;
|
||||||
|
|
||||||
create_curse(mage, &r->attribs, ct_find("goodmagicresistancezone"),
|
create_curse(mage, &r->attribs, ct_find("goodmagicresistancezone"),
|
||||||
force, force, mr_bonus, 0);
|
force, duration, mr_bonus, 0);
|
||||||
|
|
||||||
/* Erfolg melden */
|
/* Erfolg melden */
|
||||||
add_message(&mage->faction->msgs, new_message(mage->faction,
|
add_message(&mage->faction->msgs, new_message(mage->faction,
|
||||||
|
|
Loading…
Reference in a new issue