server/src/kernel/spell.h

181 lines
6.1 KiB
C
Raw Normal View History

2010-08-08 10:06:34 +02:00
/*
2015-01-30 22:10:29 +01:00
Copyright (c) 1998-2015, Enno Rehling <enno@eressea.de>
Katja Zedel <katze@felidae.kn-bremen.de
Christian Schlittchen <corwin@amber.kn-bremen.de>
2010-08-08 10:06:34 +02:00
Permission to use, copy, modify, and/or distribute this software for any
purpose with or without fee is hereby granted, provided that the above
copyright notice and this permission notice appear in all copies.
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
**/
#ifndef H_KRNL_SPELL
#define H_KRNL_SPELL
#ifdef __cplusplus
extern "C" {
#endif
struct castorder;
struct unit;
struct region;
struct spell;
struct spell_component;
struct selist;
struct attrib_type;
typedef int(*spell_f)(struct castorder * co);
typedef void(*fumble_f)(const struct castorder * co);
typedef struct spell {
char *sname;
char *syntax;
char *parameter;
int sptyp;
int rank; /* Reihenfolge der Zauber */
struct spell_component *components;
} spell;
2010-08-08 10:06:34 +02:00
typedef struct spellref {
char * _name;
struct spell *sp;
} spellref;
void add_fumble(const char *sname, fumble_f fun);
fumble_f get_fumble(const char *sname);
void add_spellcast(const char *sname, spell_f fun);
spell_f get_spellcast(const char *sname);
struct spellref *spellref_create(struct spell *sp, const char *name);
void spellref_free(struct spellref *spref);
struct spell *spellref_get(struct spellref *spref);
const char *spellref_name(const struct spellref *spref);
void spellref_init(struct spellref *spref, struct spell *sp, const char *name);
void spellref_done(struct spellref *spref);
int sp_antimagiczone(struct castorder *co);
2010-08-08 10:06:34 +02:00
struct spell * create_spell(const char * name);
struct spell * find_spell(const char *name);
void add_spell(struct selist **slistp, spell * sp);
void free_spells(void);
2010-08-08 10:06:34 +02:00
/** globals **/
extern struct attrib_type at_unitdissolve;
extern struct attrib_type at_wdwpyramid;
extern struct selist * spells;
2010-08-08 10:06:34 +02:00
#ifdef __cplusplus
}
#endif
#endif
2019-02-07 14:48:51 +01:00
/**
* Erlaeuterungen zu den Spruchdefinitionen
2010-08-08 10:06:34 +02:00
*
* Spruchstukturdefinition:
* spell{
* id, name,
* beschreibung,
* syntax,
* parameter,
* magietyp,
* sptyp,
* rank,level,
* costtyp, aura,
* komponenten[5][2][faktorart],
* &funktion, patzer}
*
* id:
* SPL_NOSPELL muss der letzte Spruch in der Liste spelldaten sein,
* denn nicht auf die Reihenfolge in der Liste sondern auf die id wird
2019-02-07 14:48:51 +01:00
* geprueft
2010-08-08 10:06:34 +02:00
*
* sptyp:
* besondere Spruchtypen und Flags
* (Regionszauber, Kampfzauber, Farcastbar, Stufe variable, ..)
*
* rank:
2019-02-07 14:48:51 +01:00
* gibt die Prioritaet und damit die Reihenfolge an, in der der Spruch
2010-08-08 10:06:34 +02:00
* gezaubert wird.
2019-02-07 14:48:51 +01:00
* 1: Aura uebertragen
2010-08-08 10:06:34 +02:00
* 2: Antimagie
2019-02-07 14:48:51 +01:00
* 3: Magierveraendernde Sprueche (Magic Boost, ..)
2010-08-08 10:06:34 +02:00
* 4: Monster erschaffen
* 5: Standartlevel
* 7: Teleport
*
2019-02-07 14:48:51 +01:00
* Komponenten[Anzahl moegl. Items][Art:Anzahl:Kostentyp]
2010-08-08 10:06:34 +02:00
*
* R_AURA:
2019-02-07 14:48:51 +01:00
* Grundkosten fuer einen Zauber. Soviel Mp muessen mindestens investiert
* werden, um den Spruch zu wirken. Zusaetzliche Mp koennen unterschiedliche
2010-08-08 10:06:34 +02:00
* Auswirkungen haben, die in der Spruchfunktionsroutine definiert werden.
*
* R_PERMAURA:
* Kosten an permantenter Aura
*
* Komponenten Kostentyp:
2019-02-07 14:48:51 +01:00
* SPC_LEVEL == Spruch mit Levelabhaengigen Magiekosten. Die angegeben
* Kosten muessen fuer Stufe 1 berechnet s
2010-08-08 10:06:34 +02:00
* SPC_FIX == Feste Kosten
*
* Wenn keine spezielle Syntax angegeben ist, wird die
* Syntaxbeschreibung aus sptyp generiert:
* FARCASTING: ZAUBER [REGION x y]
* SPELLLEVEL: ZAUBER [STUFE n]
* UNITSPELL : ZAUBER <spruchname> <Einheit-Nr> [<Einheit-Nr> ..]
* SHIPSPELL : ZAUBER <spruchname> <Schiff-Nr> [<Schiff-Nr> ..]
* BUILDINGSPELL: ZAUBER <spruchname> <Gebaeude-Nr> [<Gebaeude-Nr> ..]
* PRECOMBATSPELL : KAMPFZAUBER [STUFE n] <spruchname>
* COMBATSPELL : KAMPFZAUBER [STUFE n] <spruchname>
* POSTCOMBATSPELL: KAMPFZAUBER [STUFE n] <spruchname>
*
* Das Parsing
*
* Der String spell->parameter gibt die Syntax an, nach der die
* Parameter des Spruches in add_spellparameter() geparst werden sollen.
*
* u : eine Einheitennummer
* r : hier kommen zwei Regionskoordinaten x y
2017-02-02 16:52:32 +01:00
* b : Geb<EFBFBD>ude- oder Burgnummer
2010-08-08 10:06:34 +02:00
* s : Schiffsnummer
2017-02-02 16:52:32 +01:00
* c : String, wird ohne Weiterverarbeitung <EFBFBD>bergeben
* i : Zahl (int), wird ohne Weiterverarbeitung <EFBFBD>bergeben
2010-08-08 10:06:34 +02:00
* k : Keywort - dieser String gibt den Paramter an, der folgt. Der
* Parameter wird mit findparam() identifiziert.
2017-02-02 16:52:32 +01:00
* k muss immer von einem c als Platzhalter f<EFBFBD>r das Objekt gefolgt
2010-08-08 10:06:34 +02:00
* werden.
2017-02-02 16:52:32 +01:00
* Ein gutes Beispiel sind hierf<EFBFBD>r die Spr<EFBFBD>che zur Magieanalyse.
2010-08-08 10:06:34 +02:00
* + : gibt an, das der vorherige Parameter mehrfach vorkommen kann. Da
* ein Ende nicht definiert werden kann, muss dies immer am Schluss
* kommen.
*
2017-02-02 16:52:32 +01:00
* Flags f<EFBFBD>r das Parsing:
2010-08-08 10:06:34 +02:00
* TESTRESISTANCE : alle Zielobjekte, also alle Parameter vom Typ Unit,
* Burg, Schiff oder Region, werden auf ihre
2017-02-02 16:52:32 +01:00
* Magieresistenz <EFBFBD>berpr<EFBFBD>ft
2010-08-08 10:06:34 +02:00
* TESTCANSEE : jedes Objekt vom Typ Einheit wird auf seine
2017-02-02 16:52:32 +01:00
* Sichtbarkeit <EFBFBD>berpr<EFBFBD>ft
2010-08-08 10:06:34 +02:00
* SEARCHLOCAL : die Zielobjekte werden nur regional gesucht
* REGIONSPELL : Ziel ist die Region, auch wenn kein Zielobjekt
* angegeben wird. Ist TESTRESISTANCE gesetzt, so wird
2017-02-02 16:52:32 +01:00
* die Magieresistenz der Region <EFBFBD>berpr<EFBFBD>ft
2010-08-08 10:06:34 +02:00
*
* Bei fehlendem Ziel oder wenn dieses dem Zauber widersteht, wird die
* Spruchfunktion nicht aufgerufen.
* Sind zu wenig Parameter vorhanden, wird der Zauber ebenfalls nicht
2017-02-02 16:52:32 +01:00
* ausgef<EFBFBD>hrt.
2010-08-08 10:06:34 +02:00
* Ist eins von mehreren Zielobjekten resistent, so wird das Flag
* pa->param[n]->flag == TARGET_RESISTS
* Ist eins von mehreren Zielobjekten nicht gefunden worden, so ist
* pa->param[n]->flag == TARGET_NOTFOUND
*
2011-03-07 08:02:35 +01:00
*//* ------------------------------------------------------------- */