server/src/spells/shipcurse.c

160 lines
3.8 KiB
C
Raw Normal View History

2010-08-08 09:40:42 +02:00
/* vi: set ts=2:
*
* Eressea PB(E)M host Copyright (C) 1998-2003
* 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)
* 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 <platform.h>
#include <kernel/config.h>
#include <kernel/version.h>
#include "shipcurse.h"
/* kernel includes */
#include <kernel/message.h>
#include <kernel/objtypes.h>
#include <kernel/ship.h>
#include <kernel/unit.h>
#include <kernel/curse.h>
/* util includes */
#include <util/base36.h>
#include <util/functions.h>
#include <util/language.h>
#include <util/log.h>
/* libc includes */
#include <string.h>
#include <stdlib.h>
#include <assert.h>
2011-03-07 08:03:10 +01:00
message *cinfo_ship(const void *obj, typ_t typ, const curse * c, int self)
2010-08-08 09:40:42 +02:00
{
2011-03-07 08:03:10 +01:00
message *msg;
2010-08-08 09:40:42 +02:00
unused(typ);
unused(obj);
assert(typ == TYP_SHIP);
2011-03-07 08:03:10 +01:00
if (self != 0) { /* owner or inside */
2010-08-08 09:40:42 +02:00
msg = msg_message(mkname("curseinfo", c->type->cname), "id", c->no);
} else {
msg = msg_message("curseinfo::ship_unknown", "id", c->no);
}
2011-03-07 08:03:10 +01:00
if (msg == NULL) {
2010-08-08 09:40:42 +02:00
log_error(("There is no curseinfo for %s.\n", c->type->cname));
}
return msg;
}
/* CurseInfo mit Spezialabfragen */
/* C_SHIP_NODRIFT */
2011-03-07 08:03:10 +01:00
static message *cinfo_shipnodrift(const void *obj, typ_t typ, const curse * c,
int self)
2010-08-08 09:40:42 +02:00
{
2011-03-07 08:03:10 +01:00
ship *sh = (ship *) obj;
2010-08-08 09:40:42 +02:00
unused(typ);
assert(typ == TYP_SHIP);
if (self != 0) {
2011-03-07 08:03:10 +01:00
return msg_message("curseinfo::shipnodrift_1", "ship duration id", sh,
c->duration, c->no);
2010-08-08 09:40:42 +02:00
}
return msg_message("curseinfo::shipnodrift_0", "ship id", sh, c->no);
}
static struct curse_type ct_stormwind = { "stormwind",
CURSETYP_NORM, 0, NO_MERGE, cinfo_ship
};
2011-03-07 08:03:10 +01:00
static int flyingship_read(storage * store, curse * c, void *target)
{
ship *sh = (ship *) target;
2010-08-08 09:40:42 +02:00
c->data.v = sh;
2011-03-07 08:03:10 +01:00
if (store->version < FOSS_VERSION) {
2010-08-08 09:40:42 +02:00
sh->flags |= SF_FLYING;
return 0;
}
2011-03-07 08:03:10 +01:00
assert(sh->flags & SF_FLYING);
2010-08-08 09:40:42 +02:00
return 0;
}
2011-03-07 08:03:10 +01:00
static int flyingship_write(storage * store, const curse * c,
const void *target)
{
const ship *sh = (const ship *)target;
assert(sh->flags & SF_FLYING);
2010-08-08 09:40:42 +02:00
return 0;
}
2011-03-07 08:03:10 +01:00
static int flyingship_age(curse * c)
{
ship *sh = (ship *) c->data.v;
if (sh && c->duration == 1) {
2010-08-08 09:40:42 +02:00
freset(sh, SF_FLYING);
return 1;
}
return 0;
}
static struct curse_type ct_flyingship = { "flyingship",
2011-03-07 08:03:10 +01:00
CURSETYP_NORM, 0, NO_MERGE, cinfo_ship, NULL, flyingship_read,
flyingship_write, NULL, flyingship_age
2010-08-08 09:40:42 +02:00
};
2011-03-07 08:03:10 +01:00
2010-08-08 09:40:42 +02:00
static struct curse_type ct_nodrift = { "nodrift",
2011-03-07 08:03:10 +01:00
CURSETYP_NORM, 0, (M_DURATION | M_VIGOUR), cinfo_shipnodrift
2010-08-08 09:40:42 +02:00
};
2011-03-07 08:03:10 +01:00
2010-08-08 09:40:42 +02:00
static struct curse_type ct_shipspeedup = { "shipspeedup",
CURSETYP_NORM, 0, 0, cinfo_ship
};
2011-03-07 08:03:10 +01:00
curse *shipcurse_flyingship(ship * sh, unit * mage, double power, int duration)
2010-08-08 09:40:42 +02:00
{
2011-03-07 08:03:10 +01:00
static const curse_type *ct_flyingship = NULL;
2010-08-08 09:40:42 +02:00
if (!ct_flyingship) {
ct_flyingship = ct_find("flyingship");
assert(ct_flyingship);
}
if (curse_active(get_curse(sh->attribs, ct_flyingship))) {
return NULL;
} else if (is_cursed(sh->attribs, C_SHIP_SPEEDUP, 0)) {
return NULL;
} else {
/* mit C_SHIP_NODRIFT haben wir kein Problem */
2011-03-07 08:03:10 +01:00
curse *c =
create_curse(mage, &sh->attribs, ct_flyingship, power, duration, 0.0, 0);
2010-08-08 09:40:42 +02:00
c->data.v = sh;
2011-03-07 08:03:10 +01:00
if (c && c->duration > 0) {
2010-08-08 09:40:42 +02:00
sh->flags |= SF_FLYING;
}
return c;
}
}
2011-03-07 08:03:10 +01:00
int levitate_ship(ship * sh, unit * mage, double power, int duration)
2010-08-08 09:40:42 +02:00
{
2011-03-07 08:03:10 +01:00
curse *c = shipcurse_flyingship(sh, mage, power, duration);
2010-08-08 09:40:42 +02:00
if (c) {
return c->no;
}
return 0;
}
2011-03-07 08:03:10 +01:00
void register_shipcurse(void)
2010-08-08 09:40:42 +02:00
{
ct_register(&ct_stormwind);
ct_register(&ct_flyingship);
ct_register(&ct_nodrift);
ct_register(&ct_shipspeedup);
}