2010-08-08 10:06:34 +02:00
|
|
|
#ifndef H_KRNL_SPELL
|
|
|
|
#define H_KRNL_SPELL
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2014-11-01 13:10:22 +01:00
|
|
|
struct castorder;
|
|
|
|
struct unit;
|
|
|
|
struct region;
|
|
|
|
struct spell;
|
|
|
|
struct spell_component;
|
2017-01-26 17:41:21 +01:00
|
|
|
struct selist;
|
2014-11-01 13:10:22 +01:00
|
|
|
struct attrib_type;
|
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
typedef int(*spell_f)(struct castorder * co);
|
|
|
|
typedef void(*fumble_f)(const struct castorder * co);
|
2012-05-26 07:25:23 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
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
|
|
|
|
2017-01-28 19:42:20 +01:00
|
|
|
typedef struct spellref {
|
2018-05-05 07:38:11 +02:00
|
|
|
char * _name;
|
2017-01-28 19:42:20 +01:00
|
|
|
struct spell *sp;
|
|
|
|
} spellref;
|
|
|
|
|
2017-04-30 03:27:28 +02:00
|
|
|
void add_fumble(const char *sname, fumble_f fun);
|
|
|
|
fumble_f get_fumble(const char *sname);
|
|
|
|
|
2017-04-30 22:15:18 +02:00
|
|
|
void add_spellcast(const char *sname, spell_f fun);
|
|
|
|
spell_f get_spellcast(const char *sname);
|
|
|
|
|
2017-02-02 20:08:04 +01:00
|
|
|
struct spellref *spellref_create(struct spell *sp, const char *name);
|
2017-01-28 19:42:20 +01:00
|
|
|
void spellref_free(struct spellref *spref);
|
|
|
|
struct spell *spellref_get(struct spellref *spref);
|
2018-05-05 07:38:11 +02:00
|
|
|
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);
|
2017-01-28 19:42:20 +01:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
int sp_antimagiczone(struct castorder *co);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2017-05-01 17:04:28 +02:00
|
|
|
struct spell * create_spell(const char * name);
|
2015-10-13 22:02:58 +02:00
|
|
|
struct spell * find_spell(const char *name);
|
2017-01-26 17:41:21 +01:00
|
|
|
void add_spell(struct selist **slistp, spell * sp);
|
2015-10-13 22:02:58 +02:00
|
|
|
void free_spells(void);
|
2010-08-08 10:06:34 +02:00
|
|
|
|
2015-01-30 20:37:14 +01:00
|
|
|
/** globals **/
|
|
|
|
extern struct attrib_type at_unitdissolve;
|
|
|
|
extern struct attrib_type at_wdwpyramid;
|
2017-01-26 17:41:21 +01:00
|
|
|
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
|
2019-02-07 20:33:20 +01:00
|
|
|
* b : Gebaeude- oder Burgnummer
|
2010-08-08 10:06:34 +02:00
|
|
|
* s : Schiffsnummer
|
2019-02-07 20:33:20 +01:00
|
|
|
* c : String, wird ohne Weiterverarbeitung uebergeben
|
|
|
|
* i : Zahl (int), wird ohne Weiterverarbeitung uebergeben
|
2010-08-08 10:06:34 +02:00
|
|
|
* k : Keywort - dieser String gibt den Paramter an, der folgt. Der
|
|
|
|
* Parameter wird mit findparam() identifiziert.
|
2019-02-07 20:33:20 +01:00
|
|
|
* k muss immer von einem c als Platzhalter fuer das Objekt gefolgt
|
2010-08-08 10:06:34 +02:00
|
|
|
* werden.
|
2019-02-07 20:33:20 +01:00
|
|
|
* Ein gutes Beispiel sind hierfuer die Sprueche 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.
|
|
|
|
*
|
2019-02-07 20:33:20 +01:00
|
|
|
* Flags fuer 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
|
2019-02-07 20:33:20 +01:00
|
|
|
* Magieresistenz ueberprueft
|
2010-08-08 10:06:34 +02:00
|
|
|
* TESTCANSEE : jedes Objekt vom Typ Einheit wird auf seine
|
2019-02-07 20:33:20 +01:00
|
|
|
* Sichtbarkeit ueberprueft
|
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
|
2019-02-07 20:33:20 +01:00
|
|
|
* die Magieresistenz der Region ueberprueft
|
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
|
2019-02-07 20:33:20 +01:00
|
|
|
* ausgefuehrt.
|
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
|
|
|
*//* ------------------------------------------------------------- */
|