server/src/common/triggers/createcurse.c

152 lines
3.6 KiB
C
Raw Normal View History

2001-01-25 10:37:55 +01:00
/* vi: set ts=2:
*
*
* Eressea PB(E)M host Copyright (C) 1998-2003
2001-01-25 10:37:55 +01:00
* Christian Schlittchen (corwin@amber.kn-bremen.de)
* Katja Zedel (katze@felidae.kn-bremen.de)
* Henning Peters (faroul@beyond.kn-bremen.de)
* Enno Rehling (enno@eressea.de)
2001-01-25 10:37:55 +01:00
* Ingo Wilken (Ingo.Wilken@informatik.uni-oldenburg.de)
*
* This program may not be used, modified or distributed without
* prior permission by the authors of Eressea.
*/
#include <config.h>
#include <kernel/eressea.h>
2001-01-25 10:37:55 +01:00
#include "createcurse.h"
/* kernel includes */
#include <kernel/version.h>
#include <kernel/curse.h>
#include <kernel/unit.h>
2001-01-25 10:37:55 +01:00
/* util includes */
2007-06-20 02:34:02 +02:00
#include <util/attrib.h>
#include <util/event.h>
2007-08-05 14:19:56 +02:00
#include <util/log.h>
2007-06-20 02:34:02 +02:00
#include <util/resolve.h>
#include <util/storage.h>
2007-06-20 02:34:02 +02:00
#include <util/base36.h>
2001-01-25 10:37:55 +01:00
/* ansi includes */
#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <stdio.h>
/***
** restore a mage that was turned into a toad
**/
typedef struct createcurse_data {
struct unit * mage;
struct unit * target;
const curse_type * type;
double vigour;
2001-01-25 10:37:55 +01:00
int duration;
int effect;
int men;
} createcurse_data;
static void
createcurse_init(trigger * t)
{
t->data.v = calloc(sizeof(createcurse_data), 1);
}
static void
createcurse_free(trigger * t)
{
free(t->data.v);
}
static int
createcurse_handle(trigger * t, void * data)
{
2008-05-24 19:38:38 +02:00
/* call an event handler on createcurse.
* data.v -> ( variant event, int timer )
*/
createcurse_data * td = (createcurse_data*)t->data.v;
if (td->mage && td->target && td->mage->number && td->target->number) {
variant var;
var.i = td->effect;
2008-05-24 19:38:38 +02:00
create_curse(td->mage, &td->target->attribs,
td->type, td->vigour, td->duration, var, td->men);
} else {
log_error(("could not perform createcurse::handle()\n"));
}
unused(data);
return 0;
2001-01-25 10:37:55 +01:00
}
static void
createcurse_write(const trigger * t, struct storage * store)
2001-01-25 10:37:55 +01:00
{
createcurse_data * td = (createcurse_data*)t->data.v;
write_unit_reference(td->mage, store);
write_unit_reference(td->target, store);
store->w_tok(store, td->type->cname);
store->w_flt(store, (float)td->vigour);
store->w_int(store, td->duration);
store->w_int(store, td->effect);
store->w_int(store, td->men);
2001-01-25 10:37:55 +01:00
}
static int
createcurse_read(trigger * t, struct storage * store)
2001-01-25 10:37:55 +01:00
{
createcurse_data * td = (createcurse_data*)t->data.v;
char zText[128];
read_reference(&td->mage, store, read_unit_reference, resolve_unit);
read_reference(&td->target, store, read_unit_reference, resolve_unit);
if (store->version<CURSETYPE_VERSION) {
int id1, id2;
id1 = store->r_int(store);
id2 = store->r_int(store);
assert(id2==0);
td->vigour = store->r_flt(store);
td->duration = store->r_int(store);
td->effect = store->r_int(store);
td->men = store->r_int(store);
td->type = ct_find(oldcursename(id1));
} else {
store->r_tok_buf(store, zText, sizeof(zText));
td->type = ct_find(zText);
td->vigour = store->r_flt(store);
td->duration = store->r_int(store);
td->effect = store->r_int(store);
td->men = store->r_int(store);
}
return AT_READ_OK;
2001-01-25 10:37:55 +01:00
}
trigger_type tt_createcurse = {
"createcurse",
createcurse_init,
createcurse_free,
createcurse_handle,
createcurse_write,
createcurse_read
};
trigger *
trigger_createcurse(struct unit * mage, struct unit * target,
const curse_type * ct, double vigour, int duration,
int effect, int men)
2001-01-25 10:37:55 +01:00
{
trigger * t = t_new(&tt_createcurse);
createcurse_data * td = (createcurse_data*)t->data.v;
td->mage = mage;
td->target = target;
td->type = ct;
2001-01-25 10:37:55 +01:00
td->vigour = vigour;
td->duration = duration;
td->effect = effect;
td->men = men;
return t;
}