Removing old items created in code and replacing them with XML definitions.
This commit is contained in:
Enno Rehling 2005-01-30 14:30:31 +00:00
parent 812c41c220
commit a44951cf6f
23 changed files with 50 additions and 445 deletions

View file

@ -9,15 +9,10 @@ SubDirHdrs $(SUBDIR)/../.. ;
SOURCES = SOURCES =
artrewards.c artrewards.c
birthday_firework.c
catapultammo.c
demonseye.c demonseye.c
itemtypes.c itemtypes.c
questkeys.c
racespoils.c racespoils.c
seed.c seed.c
speedsail.c
studypotion.c
weapons.c weapons.c
xerewards.c xerewards.c
; ;

View file

@ -1,122 +0,0 @@
/* 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-pbem.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 <config.h>
#include <eressea.h>
#include "birthday_firework.h"
/* kernel includes */
#include <item.h>
#include <build.h>
#include <region.h>
#include <teleport.h>
#include <unit.h>
#include <message.h>
/* util includes */
#include <functions.h>
#include "../util/message.h"
/* libc includes */
#include <assert.h>
#include <string.h>
const int FIREWORK_RANGE=10;
static int
use_birthday_firework(struct unit * u, const struct item_type * itype, int amount, struct order * ord)
{
region_list *rlist = all_in_range(u->region, FIREWORK_RANGE, NULL);
region_list *rl;
message *m;
const char *name;
unused(amount);
name = getstrtoken();
/* "Zur Feier der Geburtstags von %name wird in %region ein großes
* Feuerwerk abgebrannt, welches noch hier zu bewundern ist. Kaskaden
* bunter Sterne, leuchtende Wasserfälle aus Licht und strahlende
* Feuerdrachen erhellen den Himmel." */
if(name && *name) {
m = new_message(u->faction, "birthday_firework%u:unit%r:region%s:name",
u, u->region, strdup(name));
add_message(&u->region->msgs, new_message(u->faction, "birthday_firework_local%u:unit%s:name",u, strdup(name)));
} else {
m = new_message(u->faction, "birthday_firework_noname%u:unit%r:region",
u, u->region);
add_message(&u->region->msgs, new_message(u->faction, "birthday_firework_noname_local%u:unit%s:name",u));
}
for(rl = rlist; rl; rl=rl->next) if(rl->data != u->region) {
add_message(&rl->data->msgs, m);
}
msg_release(m);
free_regionlist(rlist);
res_changeitem(u, itype->rtype, -1);
return 0;
}
resource_type rt_birthday_firework = {
{ "birthday_firework", "birthday_firework_p" },
{ "birthday_firework", "birthday_firework_p" },
RTF_ITEM,
&res_changeitem
};
item_type it_birthday_firework = {
&rt_birthday_firework, /* resourcetype */
0, 50, 0, /* flags, weight, capacity */
NULL, /* construction */
&use_birthday_firework, /* use */
NULL,
NULL /* give */
};
void
register_birthday_firework(void)
{
it_register(&it_birthday_firework);
it_birthday_firework.rtype->flags |= RTF_POOLED;
register_function((pf_generic)use_birthday_firework, "usefirework");
}
resource_type rt_lebkuchenherz = {
{ "lebkuchenherz", "lebkuchenherz_p" },
{ "lebkuchenherz", "lebkuchenherz_p" },
RTF_ITEM,
&res_changeitem
};
item_type it_lebkuchenherz = {
&rt_lebkuchenherz, /* resourcetype */
0, 0, 0, /* flags, weight, capacity */
NULL, /* construction */
NULL, /* use */
NULL /* give */
};
void
register_lebkuchenherz(void)
{
it_register(&it_lebkuchenherz);
it_lebkuchenherz.rtype->flags |= RTF_POOLED;
}

View file

@ -1,33 +0,0 @@
/* 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-pbem.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.
*/
#ifndef H_ITM_BIRTHDAY
#define H_ITM_BIRTHDAY
#ifdef __cplusplus
extern "C" {
#endif
extern struct item_type it_birthday_firework;
extern struct resource_type rt_birthday_firework;
extern void register_birthday_firework(void);
extern struct item_type it_lebkuchenherz;
extern struct resource_type rt_lebkuchenherz;
extern void register_lebkuchenherz(void);
#ifdef __cplusplus
}
#endif
#endif

View file

@ -1,57 +0,0 @@
/* vi: set ts=2:
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
| | Enno Rehling <enno@eressea-pbem.de>
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
+-------------------+ Stefan Reich <reich@halbling.de>
This program may not be used, modified or distributed
without prior permission by the authors of Eressea.
*/
#include <config.h>
#include <eressea.h>
#include "catapultammo.h"
#include <build.h>
#include <region.h>
/* kernel includes */
#include <item.h>
/* libc includes */
#include <assert.h>
static requirement mat_catapultammo[] = {
{I_STONE, 1},
{0, 0}
};
resource_type rt_catapultammo = {
{ "catapultammo", "catapultammo_p" },
{ "catapultammo", "catapultammo_p" },
RTF_ITEM|RTF_POOLED,
&res_changeitem
};
static construction con_catapultammo = {
SK_QUARRYING, 3, /* skill, minskill */
-1, 1, mat_catapultammo /* maxsize, reqsize [,materials] */
};
item_type it_catapultammo = {
&rt_catapultammo, /* resourcetype */
0, 1000, 0, /* flags, weight, capacity */
&con_catapultammo, /* construction */
NULL, /* use */
NULL /* give */
};
void
register_catapultammo(void)
{
it_register(&it_catapultammo);
}

View file

@ -1,18 +0,0 @@
/* 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-pbem.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.
*/
extern struct item_type it_catapultammo;
extern struct resource_type rt_catapultammo;
extern void register_catapultammo(void);

View file

@ -123,21 +123,12 @@
<File <File
RelativePath=".\artrewards.h"> RelativePath=".\artrewards.h">
</File> </File>
<File
RelativePath=".\birthday_firework.h">
</File>
<File
RelativePath=".\catapultammo.h">
</File>
<File <File
RelativePath=".\demonseye.h"> RelativePath=".\demonseye.h">
</File> </File>
<File <File
RelativePath=".\itemtypes.h"> RelativePath=".\itemtypes.h">
</File> </File>
<File
RelativePath=".\questkeys.h">
</File>
<File <File
RelativePath=".\racespoils.h"> RelativePath=".\racespoils.h">
</File> </File>
@ -154,21 +145,12 @@
<File <File
RelativePath=".\artrewards.c"> RelativePath=".\artrewards.c">
</File> </File>
<File
RelativePath=".\birthday_firework.c">
</File>
<File
RelativePath=".\catapultammo.c">
</File>
<File <File
RelativePath=".\demonseye.c"> RelativePath=".\demonseye.c">
</File> </File>
<File <File
RelativePath=".\itemtypes.c"> RelativePath=".\itemtypes.c">
</File> </File>
<File
RelativePath=".\questkeys.c">
</File>
<File <File
RelativePath=".\racespoils.c"> RelativePath=".\racespoils.c">
</File> </File>

View file

@ -14,7 +14,6 @@
#include <eressea.h> #include <eressea.h>
#include "itemtypes.h" #include "itemtypes.h"
#include "birthday_firework.h"
#include "demonseye.h" #include "demonseye.h"
#include "xerewards.h" #include "xerewards.h"
#include "artrewards.h" #include "artrewards.h"
@ -23,8 +22,6 @@
#if GROWING_TREES #if GROWING_TREES
# include "seed.h" # include "seed.h"
#endif #endif
#include "questkeys.h"
#include "catapultammo.h"
void void
register_itemtypes(void) register_itemtypes(void)
@ -36,10 +33,6 @@ register_itemtypes(void)
register_seed(); register_seed();
register_mallornseed(); register_mallornseed();
#endif #endif
register_birthday_firework();
register_lebkuchenherz();
register_questkeys();
register_catapultammo();
register_racespoils(); register_racespoils();
register_artrewards(); register_artrewards();
} }

View file

@ -1,130 +0,0 @@
/* 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-pbem.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 <config.h>
#include <eressea.h>
#include "questkeys.h"
/* kernel includes */
#include <faction.h>
#include <item.h>
#include <message.h>
#include <plane.h>
#include <region.h>
#include <unit.h>
#include <border.h>
/* util includes */
#include <functions.h>
/* libc includes */
#include <assert.h>
#include <stdlib.h>
extern border *borders[];
static int
use_questkey(struct unit * u, const struct item_type * itype, int amount, struct order * ord)
{
border *bo;
region *r1, *r2;
int lock, k;
message *m;
unit *u2;
if(u->region->x != 43 || u->region->y != -39) {
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "use_questkey_wrongregion", ""));
return EUNUSABLE;
}
r1 = findregion(43,-39);
r2 = findregion(44,-39);
bo = get_borders(r1, r2);
while (bo!=NULL) {
if(bo->type == &bt_questportal) {
break;
}
bo = bo->next;
}
assert(bo != NULL);
lock = (int)bo->data;
if (itype == &it_questkey1) k = 1;
else k = 2;
if (lock & k) {
m = msg_message("questportal_unlock","region unit key", u->region, u, k);
lock = lock & ~k;
} else {
m = msg_message("questportal_lock","region unit key", u->region, u, k);
lock = lock | k;
}
bo->data = (void *)lock;
for(u2 = u->region->units; u2; u2=u2->next) {
freset(u2->faction, FL_DH);
}
for(u2 = u->region->units; u2; u2=u2->next) {
if(!fval(u2->faction, FL_DH)) {
add_message(&u2->faction->msgs, m);
fset(u2->faction, FL_DH);
}
}
return 0;
}
static resource_type rt_questkey1 = {
{ "questkey1", "questkey1_p" },
{ "questkey1", "questkey1_p" },
RTF_ITEM,
&res_changeitem
};
static resource_type rt_questkey2 = {
{ "questkey2", "questkey2_p" },
{ "questkey2", "questkey2_p" },
RTF_ITEM,
&res_changeitem
};
item_type it_questkey1 = {
&rt_questkey1, /* resourcetype */
ITF_NOTLOST, 1, 0, /* flags, weight, capacity */
NULL, /* construction */
&use_questkey,
NULL,
NULL
};
item_type it_questkey2 = {
&rt_questkey2, /* resourcetype */
ITF_NOTLOST, 1, 0, /* flags, weight, capacity */
NULL, /* construction */
&use_questkey,
NULL,
NULL
};
void
register_questkeys(void)
{
it_register(&it_questkey1);
it_register(&it_questkey2);
register_function((pf_generic)use_questkey, "usequestkey");
}

View file

@ -1,28 +0,0 @@
/* 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-pbem.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.
*/
#ifndef H_ITM_QUESTKEYS
#define H_ITM_QUESTKEYS
#ifdef __cplusplus
extern "C" {
#endif
extern struct item_type it_questkey1;
extern struct item_type it_questkey2;
extern void register_questkeys(void);
#ifdef __cplusplus
}
#endif
#endif

View file

@ -16,8 +16,6 @@
#include <eressea.h> #include <eressea.h>
#include "weapons.h" #include "weapons.h"
#include "catapultammo.h"
#include <unit.h> #include <unit.h>
#include <build.h> #include <build.h>
#include <race.h> #include <race.h>
@ -205,6 +203,10 @@ attack_catapult(const troop * at, int * casualties, int row)
int d = 0, n; int d = 0, n;
int minrow, maxrow; int minrow, maxrow;
weapon * wp = af->person[at->index].missile; weapon * wp = af->person[at->index].missile;
static item_type * it_catapultammo = NULL;
if (it_catapultammo==NULL) {
it_catapultammo = it_find("catapultammo");
}
assert(row>=FIGHT_ROW); assert(row>=FIGHT_ROW);
if (row>BEHIND_ROW) { if (row>BEHIND_ROW) {
@ -214,12 +216,12 @@ attack_catapult(const troop * at, int * casualties, int row)
assert(wp->type->itype==olditemtype[I_CATAPULT]); assert(wp->type->itype==olditemtype[I_CATAPULT]);
assert(af->person[at->index].reload==0); assert(af->person[at->index].reload==0);
#if CATAPULT_AMMUNITION if (it_catapultammo!=NULL) {
if(new_get_pooled(au, &rt_catapultammo, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK) <= 0) { if (new_get_pooled(au, it_catapultammo->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK) <= 0) {
/* No ammo. Use other weapon if available. */ /* No ammo. Use other weapon if available. */
return true; return true;
} }
#endif }
if (af->catmsg == -1) { if (af->catmsg == -1) {
int i, k=0; int i, k=0;
@ -235,9 +237,9 @@ attack_catapult(const troop * at, int * casualties, int row)
n = min(CATAPULT_ATTACKS, count_enemies(b, af->side, minrow, maxrow, true)); n = min(CATAPULT_ATTACKS, count_enemies(b, af->side, minrow, maxrow, true));
#if CATAPULT_AMMUNITION if (it_catapultammo!=NULL) {
new_use_pooled(au, &rt_catapultammo, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, 1); new_use_pooled(au, it_catapultammo->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, 1);
#endif }
while (--n >= 0) { while (--n >= 0) {
/* Select defender */ /* Select defender */

View file

@ -60,8 +60,6 @@
/* attributes inclues */ /* attributes inclues */
#include <attributes/matmod.h> #include <attributes/matmod.h>
#include <items/catapultammo.h>
#define STONERECYCLE 50 #define STONERECYCLE 50
/* Name, MaxGroesse, MinBauTalent, Kapazitaet, {Eisen, Holz, Stein, BauSilber, /* Name, MaxGroesse, MinBauTalent, Kapazitaet, {Eisen, Holz, Stein, BauSilber,
* Laen, Mallorn}, UnterSilber, UnterSpezialTyp, UnterSpezial */ * Laen, Mallorn}, UnterSilber, UnterSpezialTyp, UnterSpezial */
@ -198,7 +196,12 @@ siege_cmd(unit * u, order * ord)
int bewaffnete, katapultiere = 0; int bewaffnete, katapultiere = 0;
static boolean init = false; static boolean init = false;
static const curse_type * magicwalls_ct; static const curse_type * magicwalls_ct;
if (!init) { init = true; magicwalls_ct = ct_find("magicwalls"); } static item_type * it_catapultammo = NULL;
if (!init) {
init = true;
magicwalls_ct = ct_find("magicwalls");
it_catapultammo = it_find("catapultammo");
}
/* gibt es ueberhaupt Burgen? */ /* gibt es ueberhaupt Burgen? */
init_tokens(ord); init_tokens(ord);
@ -218,7 +221,7 @@ siege_cmd(unit * u, order * ord)
/* schaden durch katapulte */ /* schaden durch katapulte */
d = min(u->number, d = min(u->number,
min(new_get_pooled(u, &rt_catapultammo, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK), get_item(u, I_CATAPULT))); min(new_get_pooled(u, it_catapultammo->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK), get_item(u, I_CATAPULT)));
if (eff_skill(u, SK_CATAPULT, r) >= 1) { if (eff_skill(u, SK_CATAPULT, r) >= 1) {
katapultiere = d; katapultiere = d;
d *= eff_skill(u, SK_CATAPULT, r); d *= eff_skill(u, SK_CATAPULT, r);
@ -252,7 +255,7 @@ siege_cmd(unit * u, order * ord)
/* meldung, schaden anrichten */ /* meldung, schaden anrichten */
if (d && !curse_active(get_curse(b->attribs, magicwalls_ct))) { if (d && !curse_active(get_curse(b->attribs, magicwalls_ct))) {
b->size -= d; b->size -= d;
new_use_pooled(u, &rt_catapultammo, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, d); new_use_pooled(u, it_catapultammo->rtype, GET_SLACK|GET_RESERVE|GET_POOLED_SLACK, d);
d = 100 * d / b->size; d = 100 * d / b->size;
} else d = 0; } else d = 0;

View file

@ -28,7 +28,6 @@
#define GUARD_DISABLES_PRODUCTION 1 #define GUARD_DISABLES_PRODUCTION 1
#define RESOURCE_QUANTITY 0.5 #define RESOURCE_QUANTITY 0.5
#define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */ #define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */
#define CATAPULT_AMMUNITION 1 /* Gebaut werden kann sie auch mit 0! */
#define CHANGED_CROSSBOWS 1 #define CHANGED_CROSSBOWS 1
#define COMBAT_TURNS 5 #define COMBAT_TURNS 5
#define PEASANTS_DO_NOT_STARVE 0 #define PEASANTS_DO_NOT_STARVE 0

View file

@ -28,7 +28,6 @@
#define GUARD_DISABLES_PRODUCTION 1 #define GUARD_DISABLES_PRODUCTION 1
#define RESOURCE_QUANTITY 0.5 #define RESOURCE_QUANTITY 0.5
#define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */ #define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */
#define CATAPULT_AMMUNITION 1 /* Gebaut werden kann sie auch mit 0! */
#define CHANGED_CROSSBOWS 1 #define CHANGED_CROSSBOWS 1
#define NEWATSROI 0 #define NEWATSROI 0
#define COMBAT_TURNS 5 #define COMBAT_TURNS 5

View file

@ -28,7 +28,6 @@
#define GUARD_DISABLES_PRODUCTION 1 #define GUARD_DISABLES_PRODUCTION 1
#define RESOURCE_QUANTITY 0.5 #define RESOURCE_QUANTITY 0.5
#define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */ #define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */
#define CATAPULT_AMMUNITION 1 /* Gebaut werden kann sie auch mit 0! */
#define CHANGED_CROSSBOWS 1 #define CHANGED_CROSSBOWS 1
#define NEWATSROI 0 #define NEWATSROI 0
#define COMBAT_TURNS 5 #define COMBAT_TURNS 5

View file

@ -28,7 +28,6 @@
#define GUARD_DISABLES_PRODUCTION 1 #define GUARD_DISABLES_PRODUCTION 1
#define RESOURCE_QUANTITY 0.5 #define RESOURCE_QUANTITY 0.5
#define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */ #define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */
#define CATAPULT_AMMUNITION 1 /* Gebaut werden kann sie auch mit 0! */
#define CHANGED_CROSSBOWS 1 #define CHANGED_CROSSBOWS 1
#define COMBAT_TURNS 5 #define COMBAT_TURNS 5
#define PEASANTS_DO_NOT_STARVE 0 #define PEASANTS_DO_NOT_STARVE 0

View file

@ -23,8 +23,6 @@
/* misc includes */ /* misc includes */
#include <attributes/key.h> #include <attributes/key.h>
#include <items/questkeys.h>
#include <items/catapultammo.h>
#include <modules/xecmd.h> #include <modules/xecmd.h>
/* gamecode includes */ /* gamecode includes */

View file

@ -11,7 +11,6 @@
* prior permission by the authors of Eressea. * prior permission by the authors of Eressea.
*/ */
#define BOOL_DEFINED
/* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */ /* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */
/* wenn curses.h nicht vor mapper included wird, kennt es die structs nicht. TODO: curses-teil separieren (map_tools.h) */ /* wenn curses.h nicht vor mapper included wird, kennt es die structs nicht. TODO: curses-teil separieren (map_tools.h) */
#include <config.h> #include <config.h>

View file

@ -11,7 +11,6 @@
* prior permission by the authors of Eressea. * prior permission by the authors of Eressea.
*/ */
#define BOOL_DEFINED
#include <config.h> #include <config.h>
#include <curses.h> #include <curses.h>
#include <eressea.h> #include <eressea.h>

View file

@ -12,7 +12,6 @@
* prior permission by the authors of Eressea. * prior permission by the authors of Eressea.
*/ */
#define BOOL_DEFINED
/* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */ /* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */
#include <config.h> #include <config.h>

View file

@ -14,8 +14,6 @@
#define VERSION "3.3.0" #define VERSION "3.3.0"
#define ISLANDSIZE 20 #define ISLANDSIZE 20
#define MAIN_C
#define BOOL_DEFINED
/* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */ /* wenn config.h nicht vor curses included wird, kompiliert es unter windows nicht */
#include <config.h> #include <config.h>
#include <curses.h> #include <curses.h>

View file

@ -1299,6 +1299,14 @@
<text locale="de">Lebkuchenherzen mit der Aufschrift 'Erz und <text locale="de">Lebkuchenherzen mit der Aufschrift 'Erz und
Stein, das ist fein'</text> Stein, das ist fein'</text>
</string> </string>
<string name="key">
<text locale="de">Schlüssel</text>
<text locale="en">key</text>
</string>
<string name="key_p">
<text locale="de">Schlüssel</text>
<text locale="en">keys</text>
</string>
<string name="questkey1"> <string name="questkey1">
<text locale="de">Achatener Schlüssel</text> <text locale="de">Achatener Schlüssel</text>
<text locale="en">agate key</text> <text locale="en">agate key</text>

View file

@ -1,5 +1,18 @@
<?xml version="1.0"?> <?xml version="1.0"?>
<resources> <resources>
<resource name="questkey1" appearance="key">
<!-- Key for an old quest. placeholder item -->
<function name="change" value="changeitem"/>
<item notlost="yes" weight="1" />
</resource>
<resource name="questkey2" appearance="key">
<!-- Key for an old quest. placeholder item -->
<function name="change" value="changeitem"/>
<item notlost="yes" weight="1" />
</resource>
<resource name="jadee_ring" appearance="ring"> <resource name="jadee_ring" appearance="ring">
<!-- Wedding ring for Jadee --> <!-- Wedding ring for Jadee -->
<function name="change" value="changeitem"/> <function name="change" value="changeitem"/>

View file

@ -91,4 +91,12 @@
</item> </item>
</resource> </resource>
<resource name="catapultammo">
<item weight="1000">
<construction skill="sk_quarrying" minskill="3" reqsize="1">
<requirement type="stone" quantity="1"/>
</construction>
</item>
</resource>
</resources> </resources>