forked from github/server
shock: apply also to units with 0 people, because they need to e.g. kill familiar-attributes.
This commit is contained in:
parent
61a6a52665
commit
da213e5f16
3 changed files with 53 additions and 45 deletions
|
@ -28,7 +28,6 @@ extern "C" {
|
||||||
|
|
||||||
/* Prototypen */
|
/* Prototypen */
|
||||||
|
|
||||||
void do_shock(struct unit *u, const char *reason);
|
|
||||||
int use_item_power(struct region * r, struct unit * u);
|
int use_item_power(struct region * r, struct unit * u);
|
||||||
int use_item_regeneration(struct region * r, struct unit * u);
|
int use_item_regeneration(struct region * r, struct unit * u);
|
||||||
void showspells(struct region *r, struct unit *u);
|
void showspells(struct region *r, struct unit *u);
|
||||||
|
|
|
@ -107,45 +107,6 @@ report_failure(unit * mage, struct order * ord) {
|
||||||
cmistake(mage, ord, 180, MSG_MAGIC);
|
cmistake(mage, ord, 180, MSG_MAGIC);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
|
||||||
/* do_shock - Schockt die Einheit, z.B. bei Verlust eines */
|
|
||||||
/* Vertrauten. */
|
|
||||||
/* ------------------------------------------------------------- */
|
|
||||||
|
|
||||||
void
|
|
||||||
do_shock(unit *u, const char *reason)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
if(u->number == 0) return;
|
|
||||||
|
|
||||||
/* HP - Verlust */
|
|
||||||
u->hp = (unit_max_hp(u) * u->number)/10;
|
|
||||||
u->hp = max(1, u->hp);
|
|
||||||
/* Aura - Verlust */
|
|
||||||
if(is_mage(u)) {
|
|
||||||
set_spellpoints(u, max_spellpoints(u->region,u)/10);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Evt. Talenttageverlust */
|
|
||||||
for (i=0;i!=u->skill_size;++i) if (rand()%5==0) {
|
|
||||||
skill * sv = u->skills+i;
|
|
||||||
int weeks = (sv->level * sv->level - sv->level) / 2;
|
|
||||||
int change = (weeks+9) / 10;
|
|
||||||
reduce_skill(u, sv, change);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Dies ist ein Hack, um das skillmod und familiar-Attribut beim Mage
|
|
||||||
* zu löschen wenn der Familiar getötet wird. Da sollten wir über eine
|
|
||||||
* saubere Implementation nachdenken. */
|
|
||||||
|
|
||||||
if(!strcmp(reason, "trigger")) {
|
|
||||||
remove_familiar(u);
|
|
||||||
}
|
|
||||||
|
|
||||||
ADDMSG(&u->faction->msgs, msg_message("shock",
|
|
||||||
"mage reason", u, strdup(reason)));
|
|
||||||
}
|
|
||||||
|
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
/* Spruchanalyse - Ausgabe von curse->info und curse->name */
|
/* Spruchanalyse - Ausgabe von curse->info und curse->name */
|
||||||
/* ------------------------------------------------------------- */
|
/* ------------------------------------------------------------- */
|
||||||
|
|
|
@ -17,9 +17,13 @@
|
||||||
#include "shock.h"
|
#include "shock.h"
|
||||||
|
|
||||||
/* kernel includes */
|
/* kernel includes */
|
||||||
#include <curse.h>
|
#include <kernel/curse.h>
|
||||||
#include <spell.h>
|
#include <kernel/faction.h>
|
||||||
#include <unit.h>
|
#include <kernel/magic.h>
|
||||||
|
#include <kernel/message.h>
|
||||||
|
#include <kernel/skill.h>
|
||||||
|
#include <kernel/spell.h>
|
||||||
|
#include <kernel/unit.h>
|
||||||
|
|
||||||
/* util includes */
|
/* util includes */
|
||||||
#include <event.h>
|
#include <event.h>
|
||||||
|
@ -27,12 +31,55 @@
|
||||||
#include <base36.h>
|
#include <base36.h>
|
||||||
|
|
||||||
/* libc includes */
|
/* libc includes */
|
||||||
|
#include <assert.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
#include <string.h>
|
||||||
/***
|
/***
|
||||||
** shock
|
** shock
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------- */
|
||||||
|
/* do_shock - Schockt die Einheit, z.B. bei Verlust eines */
|
||||||
|
/* Vertrauten. */
|
||||||
|
/* ------------------------------------------------------------- */
|
||||||
|
|
||||||
|
static void
|
||||||
|
do_shock(unit *u, const char *reason)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
|
||||||
|
if (u->number > 0) {
|
||||||
|
/* HP - Verlust */
|
||||||
|
u->hp = (unit_max_hp(u) * u->number)/10;
|
||||||
|
u->hp = max(1, u->hp);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Aura - Verlust */
|
||||||
|
if (is_mage(u)) {
|
||||||
|
set_spellpoints(u, max_spellpoints(u->region,u)/10);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Evt. Talenttageverlust */
|
||||||
|
for (i=0;i!=u->skill_size;++i) if (rand()%5==0) {
|
||||||
|
skill * sv = u->skills+i;
|
||||||
|
int weeks = (sv->level * sv->level - sv->level) / 2;
|
||||||
|
int change = (weeks+9) / 10;
|
||||||
|
reduce_skill(u, sv, change);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Dies ist ein Hack, um das skillmod und familiar-Attribut beim Mage
|
||||||
|
* zu löschen wenn der Familiar getötet wird. Da sollten wir über eine
|
||||||
|
* saubere Implementation nachdenken. */
|
||||||
|
|
||||||
|
if (strcmp(reason, "trigger")==0) {
|
||||||
|
remove_familiar(u);
|
||||||
|
}
|
||||||
|
|
||||||
|
ADDMSG(&u->faction->msgs, msg_message("shock",
|
||||||
|
"mage reason", u, strdup(reason)));
|
||||||
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
shock_handle(trigger * t, void * data)
|
shock_handle(trigger * t, void * data)
|
||||||
{
|
{
|
||||||
|
@ -40,8 +87,9 @@ shock_handle(trigger * t, void * data)
|
||||||
unit * u = (unit*)t->data.v;
|
unit * u = (unit*)t->data.v;
|
||||||
if (u!=NULL) {
|
if (u!=NULL) {
|
||||||
do_shock(u, "trigger");
|
do_shock(u, "trigger");
|
||||||
} else
|
} else {
|
||||||
log_error(("could not perform shock::handle()\n"));
|
log_error(("could not perform shock::handle()\n"));
|
||||||
|
}
|
||||||
unused(data);
|
unused(data);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue