forked from github/server
WdW-Pyramiden
This commit is contained in:
parent
f6cc641d9c
commit
1c7ace7556
13 changed files with 224 additions and 101 deletions
|
@ -9,6 +9,7 @@ SubDirHdrs $(SUBDIR)/../.. ;
|
|||
|
||||
SOURCES =
|
||||
aggressive.c
|
||||
alliance.c
|
||||
at_movement.c
|
||||
attributes.c
|
||||
fleechance.c
|
||||
|
|
|
@ -39,6 +39,9 @@
|
|||
#endif
|
||||
#include "moved.h"
|
||||
#include "variable.h"
|
||||
#ifdef WDW_PYRAMID
|
||||
#include "alliance.h"
|
||||
#endif
|
||||
|
||||
/* util includes */
|
||||
#include <attrib.h>
|
||||
|
|
|
@ -24,6 +24,7 @@
|
|||
#include <attributes/overrideroads.h>
|
||||
#include <attributes/viewrange.h>
|
||||
#include <attributes/otherfaction.h>
|
||||
#include <attributes/alliance.h>
|
||||
#ifdef AT_OPTION
|
||||
# include <attributes/option.h>
|
||||
#endif
|
||||
|
@ -61,6 +62,7 @@
|
|||
#include <kernel/skill.h>
|
||||
#include <kernel/teleport.h>
|
||||
#include <kernel/unit.h>
|
||||
#include <kernel/alliance.h>
|
||||
#ifdef USE_UGROUPS
|
||||
# include <ugroup.h>
|
||||
#endif
|
||||
|
@ -1870,20 +1872,59 @@ report_building(FILE *F, const region * r, const building * b, const faction * f
|
|||
scat(b->display);
|
||||
i = b->display[strlen(b->display) - 1];
|
||||
}
|
||||
|
||||
#ifdef WDW_PYRAMID
|
||||
|
||||
if (i != '!' && i != '?' && i != '.')
|
||||
scat(", ");
|
||||
|
||||
if(b->type == bt_find("pyramid")) {
|
||||
unit * owner = buildingowner(r, b);
|
||||
scat("Größenstufe ");
|
||||
icat(wdw_pyramid_level(b));
|
||||
scat(".");
|
||||
|
||||
if (owner && owner->faction==f) {
|
||||
const construction *ctype = b->type->construction;
|
||||
int completed = b->size;
|
||||
int c;
|
||||
|
||||
scat(" Baukosten pro Größenpunkt: ");
|
||||
|
||||
while(ctype->improvement != NULL &&
|
||||
ctype->improvement != ctype &&
|
||||
ctype->maxsize > 0 &&
|
||||
ctype->maxsize <= completed)
|
||||
{
|
||||
completed -= ctype->maxsize;
|
||||
ctype = ctype->improvement;
|
||||
}
|
||||
|
||||
assert(ctype->materials != NULL);
|
||||
|
||||
for (c=0;ctype->materials[c].number;c++) {
|
||||
resource_t rtype = ctype->materials[c].type;
|
||||
int number = ctype->materials[c].number;
|
||||
|
||||
if(c > 0) {
|
||||
scat(", ");
|
||||
}
|
||||
icat(number);
|
||||
scat(" ");
|
||||
scat(locale_string(lang,
|
||||
resourcename(oldresourcetype[rtype],
|
||||
number!=1?GR_PLURAL:0)));
|
||||
}
|
||||
|
||||
scat(".");
|
||||
}
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
if (i != '!' && i != '?' && i != '.')
|
||||
scat(".");
|
||||
|
||||
#if WDW_PYRAMID
|
||||
if(b->type == bt_find("wdw_pyramid")) {
|
||||
attrib *a = a_find(b->attribs, &at_alliance));
|
||||
if(f->alliance && f->alliance->id == a->data.i) {
|
||||
scat("Die Größenstufe dieser Pyramide ist ");
|
||||
icat(wdw_pyramid_level(b));
|
||||
scat(". Die nächste Größenstufe wird mit ");
|
||||
icat(wdw_pyramid_size_for_next_level(b));
|
||||
scat(" Größenpunkten erreicht. Baukosten pro Größenpunkt: ");
|
||||
}
|
||||
}
|
||||
#endif
|
||||
|
||||
rparagraph(F, buf, 2, 0);
|
||||
|
|
|
@ -40,6 +40,7 @@
|
|||
#include "ship.h"
|
||||
#include "skill.h"
|
||||
#include "unit.h"
|
||||
#include "alliance.h"
|
||||
|
||||
/* from libutil */
|
||||
#include <attrib.h>
|
||||
|
@ -59,6 +60,7 @@
|
|||
|
||||
/* attributes inclues */
|
||||
#include <attributes/matmod.h>
|
||||
#include <attributes/alliance.h>
|
||||
|
||||
#define STONERECYCLE 50
|
||||
/* Name, MaxGroesse, MinBauTalent, Kapazitaet, {Eisen, Holz, Stein, BauSilber,
|
||||
|
@ -627,16 +629,19 @@ build(unit * u, const construction * ctype, int completed, int want)
|
|||
|
||||
effsk = basesk;
|
||||
if (inside_building(u)) {
|
||||
effsk = skillmod(u->building->type->attribs, u, u->region, type->skill, effsk, SMF_PRODUCTION);
|
||||
effsk = skillmod(u->building->type->attribs, u, u->region, type->skill,
|
||||
effsk, SMF_PRODUCTION);
|
||||
}
|
||||
effsk = skillmod(type->attribs, u, u->region, type->skill, effsk, SMF_PRODUCTION);
|
||||
effsk = skillmod(type->attribs, u, u->region, type->skill,
|
||||
effsk, SMF_PRODUCTION);
|
||||
if (effsk<0) return effsk; /* pass errors to caller */
|
||||
if (effsk==0) return ENEEDSKILL;
|
||||
|
||||
skills = effsk * u->number;
|
||||
|
||||
/* technically, nimblefinge and domore should be in a global set of "game"-attributes,
|
||||
* (as at_skillmod) but for a while, we're leaving them in here. */
|
||||
/* technically, nimblefinge and domore should be in a global set of
|
||||
* "game"-attributes, (as at_skillmod) but for a while, we're leaving
|
||||
* them in here. */
|
||||
|
||||
if (dm != 0) {
|
||||
/* Auswirkung Schaffenstrunk */
|
||||
|
@ -649,9 +654,9 @@ build(unit * u, const construction * ctype, int completed, int want)
|
|||
|
||||
/* skip over everything that's already been done:
|
||||
* type->improvement==NULL means no more improvements, but no size limits
|
||||
* type->improvement==type means build another object of the same time while material lasts
|
||||
* type->improvement==x means build x when type is finished
|
||||
*/
|
||||
* type->improvement==type means build another object of the same time
|
||||
* while material lasts type->improvement==x means build x when type
|
||||
* is finished */
|
||||
while (type->improvement!=NULL &&
|
||||
type->improvement!=type &&
|
||||
type->maxsize>0 &&
|
||||
|
@ -852,6 +857,13 @@ build_building(unit * u, const building_type * btype, int want, order * ord)
|
|||
cmistake(u, ord, 221, MSG_PRODUCE);
|
||||
return;
|
||||
}
|
||||
if (btype->flags & BTF_ONEPERTURN) {
|
||||
if(b && fval(b, BLD_EXPANDED)) {
|
||||
cmistake(u, ord, 318, MSG_PRODUCE);
|
||||
return;
|
||||
}
|
||||
want = 1;
|
||||
}
|
||||
|
||||
if (b) built = b->size;
|
||||
if (want<=0 || want == INT_MAX) {
|
||||
|
@ -913,8 +925,8 @@ build_building(unit * u, const building_type * btype, int want, order * ord)
|
|||
u->building = b;
|
||||
fset(u, UFL_OWNER);
|
||||
|
||||
#if WDW_PYRAMID
|
||||
if(b->type == bt_find("wdw_pyramid") && u->faction->alliance != NULL) {
|
||||
#ifdef WDW_PYRAMID
|
||||
if(b->type == bt_find("pyramid") && u->faction->alliance != NULL) {
|
||||
attrib * a = a_add(&b->attribs, a_new(&at_alliance));
|
||||
a->data.i = u->faction->alliance->id;
|
||||
}
|
||||
|
@ -949,6 +961,8 @@ build_building(unit * u, const building_type * btype, int want, order * ord)
|
|||
}
|
||||
|
||||
b->size += built;
|
||||
fset(b, BLD_EXPANDED);
|
||||
|
||||
update_lighthouse(b);
|
||||
|
||||
|
||||
|
|
|
@ -37,6 +37,7 @@
|
|||
#include <assert.h>
|
||||
#include <stdlib.h>
|
||||
#include <string.h>
|
||||
#include <limits.h>
|
||||
|
||||
/* attributes includes */
|
||||
#include <attributes/matmod.h>
|
||||
|
@ -298,81 +299,51 @@ castle_name(int bsize)
|
|||
return fname[i];
|
||||
}
|
||||
|
||||
#if WDW_PYRAMID
|
||||
static requirement wdw_pyramid_req[][] = {
|
||||
{{R_STONE, 100, 0}, {R_WOOD, 100, 0}, {R_IRON, 100, 0}, {NORESOURCE, 0, 0.0 }},
|
||||
{{R_STONE, 1, 0}, {R_WOOD, 1, 0}, {R_IRON, 1, 0}, {NORESOURCE, 0, 0.0 }},
|
||||
{{R_STONE, 1, 0}, {R_WOOD, 1, 0}, {R_IRON, 1, 0},
|
||||
{R_MALLORN, 1, 0}, {NORESOURCE, 0, 0.0 }},
|
||||
{{R_STONE, 1, 0}, {R_WOOD, 1, 0}, {R_IRON, 1, 0},
|
||||
{R_LAEN, 1, 0}, {NORESOURCE, 0, 0.0 }},
|
||||
{{R_STONE, 1, 0}, {R_WOOD, 1, 0}, {R_IRON, 1, 0},
|
||||
{R_TOADSLIME, 1, 0}, {NORESOURCE, 0, 0.0 }},
|
||||
{{R_STONE, 1, 0}, {R_WOOD, 1, 0}, {R_IRON, 1, 0},
|
||||
{R_BALM, 1, 0.0 }, {R_SPICES, 1, 0.0 }, {R_JEWELERY, 1, 0.0 },
|
||||
{R_MYRRH, 1, 0.0 }, {R_OIL, 1, 0.0 }, {R_SILK, 1, 0.0 },
|
||||
{R_INCENSE, 1, 0.0 }, {NORESOURCE, 0, 0.0 }}
|
||||
}
|
||||
#ifdef WDW_PYRAMID
|
||||
|
||||
static const char *
|
||||
pyramid_name(int bsize)
|
||||
{
|
||||
static const struct building_type * bt_pyramid;
|
||||
static char p_name_buf[32];
|
||||
int level=0;
|
||||
const construction * ctype;
|
||||
|
||||
static construction wdw_pyramid_bld[] = {
|
||||
{ SK_BUILDING, 10, 1, 1, pyramid_req[0], wdw_pyramid_bld[0] }, /* 0 -> 1 */
|
||||
{ SK_BUILDING, 3, 6, 1, pyramid_req[1], wdw_pyramid_bld[1] }, /* -> 7 */
|
||||
{ SK_BUILDING, 4, 1, 1, pyramid_req[2], wdw_pyramid_bld[2] }, /* -> 8 */
|
||||
{ SK_BUILDING, 5, 13, 1, pyramid_req[1], wdw_pyramid_bld[3] }, /* -> 21 */
|
||||
{ SK_BUILDING, 6, 1, 1, pyramid_req[3], wdw_pyramid_bld[4] }, /* -> 22 */
|
||||
{ SK_BUILDING, 7, 41, 1, pyramid_req[1], wdw_pyramid_bld[5] }, /* -> 63 */
|
||||
{ SK_BUILDING, 8, 1, 1, pyramid_req[4], wdw_pyramid_bld[6] }, /* -> 64 */
|
||||
{ SK_BUILDING, 9, 125, 1, pyramid_req[1], wdw_pyramid_bld[7] }, /* -> 189 */
|
||||
{ SK_BUILDING, 10, 1, 1, pyramid_req[5], wdw_pyramid_bld[8] }, /* -> 190 */
|
||||
{ SK_BUILDING, 100, 100000, 1, pyramid_req[0], NULL } /* should never be seen */
|
||||
if(!bt_pyramid) bt_pyramid = bt_find("pyramid");
|
||||
assert(bt_pyramid);
|
||||
|
||||
ctype = bt_pyramid->construction;
|
||||
|
||||
while (ctype && ctype->maxsize != -1 && ctype->maxsize<=bsize) {
|
||||
bsize-=ctype->maxsize;
|
||||
ctype=ctype->improvement;
|
||||
++level;
|
||||
}
|
||||
|
||||
sprintf(p_name_buf, "pyramid%d", level);
|
||||
|
||||
return p_name_buf;
|
||||
}
|
||||
|
||||
int
|
||||
wdw_pyramid_level(const struct building *b)
|
||||
{
|
||||
int size = 0;
|
||||
int level;
|
||||
const construction *ctype = b->type->construction;
|
||||
int completed = b->size;
|
||||
int level = 0;
|
||||
|
||||
for(level=0; wdw_pyramid_bld[level].improvement != NULL; level++) {
|
||||
size += wdw_pyramid_bld[level].maxsize;
|
||||
if(size > b->size) break;
|
||||
while(ctype->improvement != NULL &&
|
||||
ctype->improvement != ctype &&
|
||||
ctype->maxsize > 0 &&
|
||||
ctype->maxsize <= completed)
|
||||
{
|
||||
++level;
|
||||
completed-=ctype->maxsize;
|
||||
ctype = ctype->improvement;
|
||||
}
|
||||
|
||||
return level;
|
||||
}
|
||||
|
||||
int
|
||||
wdw_pyramid_size_for_next_level(const struct building *b)
|
||||
{
|
||||
int size = 0;
|
||||
int level;
|
||||
|
||||
for(level=0; wdw_pyramid_bld[level].improvement != NULL; level++) {
|
||||
size += wdw_pyramid_bld[level].maxsize;
|
||||
if(size > b->size) {
|
||||
return size - b->size;
|
||||
}
|
||||
}
|
||||
|
||||
return INT_MAX;
|
||||
}
|
||||
|
||||
static const char *
|
||||
wdw_pyramid_name(int bsize)
|
||||
{
|
||||
return "wdw_pyramid";
|
||||
}
|
||||
|
||||
building_type bt_wdw_pyramid = {
|
||||
"wdw_pyramid",
|
||||
BTF_INDESTRUCTIBLE,
|
||||
1, 4, -1,
|
||||
0, 0, 0, 1.0,
|
||||
NULL,
|
||||
&wdw_pyramid_bld[0],
|
||||
wdw_pyramid_name
|
||||
};
|
||||
#endif
|
||||
|
||||
/* for finding out what was meant by a particular building string */
|
||||
|
@ -412,10 +383,8 @@ register_buildings(void)
|
|||
{
|
||||
register_function((pf_generic)init_smithy, "init_smithy");
|
||||
register_function((pf_generic)castle_name, "castle_name");
|
||||
|
||||
#if WDW_PYRAMID
|
||||
register_function((pf_generic)wdw_pyramid_name, "wdw_pyramid_name");
|
||||
bt_register(&bt_wdw_pyramid);
|
||||
#ifdef WDW_PYRAMID
|
||||
register_function((pf_generic)pyramid_name, "pyramid_name");
|
||||
#endif
|
||||
}
|
||||
|
||||
|
|
|
@ -39,6 +39,7 @@ typedef struct maintenance {
|
|||
#define BTF_DYNAMIC 0x10 /* dynamic type, needs bt_write */
|
||||
#define BTF_PROTECTION 0x20 /* protection in combat */
|
||||
#define BTF_MAGIC 0x40 /* magical effect */
|
||||
#define BTF_ONEPERTURN 0x80 /* one one sizepoint can be added per turn */
|
||||
|
||||
typedef struct building_type {
|
||||
const char * _name;
|
||||
|
@ -82,6 +83,7 @@ extern struct building_typelist *buildingtypes;
|
|||
#define BLD_MAINTAINED 0x01 /* vital maintenance paid for */
|
||||
#define BLD_WORKING 0x02 /* full maintenance paid, it works */
|
||||
#define BLD_UNGUARDED 0x04 /* you can enter this building anytime */
|
||||
#define BLD_EXPANDED 0x08 /* has been expanded this turn */
|
||||
|
||||
#define BLD_SAVEMASK 0x00 /* mask for persistent flags */
|
||||
|
||||
|
@ -143,9 +145,8 @@ extern struct unit * buildingowner(const struct region * r, const struct buildin
|
|||
extern attrib_type at_nodestroy;
|
||||
extern attrib_type at_building_action;
|
||||
|
||||
#if WDW_PYRAMID
|
||||
extern int wdw_pyramid_size(const struct building *b);
|
||||
extern int wdw_pyramid_size_for_next_level(const struct building *b);
|
||||
#ifdef WDW_PYRAMID
|
||||
extern int wdw_pyramid_level(const struct building *b);
|
||||
#endif
|
||||
|
||||
typedef struct building_action {
|
||||
|
|
|
@ -267,6 +267,7 @@ parse_buildings(xmlDocPtr doc)
|
|||
bt->auraregen = xml_fvalue(node, "auraregen", 1.0);
|
||||
|
||||
if (xml_bvalue(node, "nodestroy", false)) bt->flags |= BTF_INDESTRUCTIBLE;
|
||||
if (xml_bvalue(node, "oneperturn", false)) bt->flags |= BTF_ONEPERTURN;
|
||||
if (xml_bvalue(node, "nobuild", false)) bt->flags |= BTF_NOBUILD;
|
||||
if (xml_bvalue(node, "unique", false)) bt->flags |= BTF_UNIQUE;
|
||||
if (xml_bvalue(node, "decay", false)) bt->flags |= BTF_DECAY;
|
||||
|
|
|
@ -53,4 +53,4 @@
|
|||
#undef XECMD_MODULE
|
||||
#define WDW_PHOENIX
|
||||
#define WDW_PYRAMIDSPELL
|
||||
/* #define WDW_PYRAMID 1 */
|
||||
#define WDW_PYRAMID
|
||||
|
|
|
@ -166,14 +166,6 @@
|
|||
</construction>
|
||||
</building>
|
||||
|
||||
<building name="pyramid" capacity="1" maxcapacity="10000" nodestroy="yes">
|
||||
<construction skill="sk_building" minskill="10" reqsize="1">
|
||||
<requirement type="iron" quantity="100"/>
|
||||
<requirement type="log" quantity="100"/>
|
||||
<requirement type="stone" quantity="100"/>
|
||||
</construction>
|
||||
</building>
|
||||
|
||||
<building name="castle" capacity="1" maxcapacity="4">
|
||||
<function name="name" value="castle_name"/>
|
||||
<construction skill="sk_building" minskill="1" maxsize="2" reqsize="1">
|
||||
|
|
|
@ -2750,6 +2750,17 @@
|
|||
<text locale="fr">"$unit($unit) drowns when $ship($ship) in $region($region) sinks."</text>
|
||||
<text locale="en">"$unit($unit) drowns when $ship($ship) in $region($region) sinks."</text>
|
||||
</message>
|
||||
|
||||
<message name="error318" section="events">
|
||||
<type>
|
||||
<arg name="unit" type="unit"/>
|
||||
<arg name="region" type="region"/>
|
||||
<arg name="command" type="order"/>
|
||||
</type>
|
||||
<text locale="de">"$unit($unit) in $region($region): '$order($command)' - Das Gebäude kann nur einmal pro Runde erweitert werden."</text>
|
||||
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - Thhe building can be expanded only once per turn."</text>
|
||||
</message>
|
||||
|
||||
<message name="error317" section="events">
|
||||
<type>
|
||||
<arg name="unit" type="unit"/>
|
||||
|
|
|
@ -46,6 +46,7 @@
|
|||
<xi:include href="vinyambar/wdw-strings.xml"/>
|
||||
<xi:include href="vinyambar/wdw-resources.xml" />
|
||||
<xi:include href="vinyambar/wdw-races.xml"/>
|
||||
<xi:include href="vinyambar/wdw-buildings.xml"/>
|
||||
|
||||
<strings>
|
||||
<string name="mailto">
|
||||
|
|
47
src/res/vinyambar/wdw-buildings.xml
Normal file
47
src/res/vinyambar/wdw-buildings.xml
Normal file
|
@ -0,0 +1,47 @@
|
|||
<?xml version="1.0"?>
|
||||
<buildings>
|
||||
<building name="pyramid" capacity="1" maxcapacity="10000" nodestroy="yes" oneperturn="yes">
|
||||
<function name="name" value="pyramid_name"/>
|
||||
<construction skill="sk_building" minskill="10" maxsize="1" reqsize="1">
|
||||
<requirement type="iron" quantity="100"/>
|
||||
<requirement type="log" quantity="100"/>
|
||||
<requirement type="stone" quantity="100"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="10" maxsize="4" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="log" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="8" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="12" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="16" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="20" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="24" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
<construction skill="sk_building" minskill="11" maxsize="28" reqsize="1">
|
||||
<requirement type="iron" quantity="10"/>
|
||||
<requirement type="mallorn" quantity="10"/>
|
||||
<requirement type="stone" quantity="10"/>
|
||||
</construction>
|
||||
</building>
|
||||
</buildings>
|
||||
|
|
@ -90,6 +90,48 @@
|
|||
<text locale="de">Smaragde</text>
|
||||
<text locale="en">emeralds</text>
|
||||
</string>
|
||||
|
||||
|
||||
<string name="pyramid0">
|
||||
<text locale="de">Pyramide des Hapi</text>
|
||||
<text locale="en">pyramid of Hapi</text>
|
||||
</string>
|
||||
<string name="pyramid1">
|
||||
<text locale="de">Pyramide der Tayet</text>
|
||||
<text locale="en">pyramid of Tayet</text>
|
||||
</string>
|
||||
<string name="pyramid2">
|
||||
<text locale="de">Pyramide der Tefnut</text>
|
||||
<text locale="en">pyramid of Tefnut</text>
|
||||
</string>
|
||||
<string name="pyramid3">
|
||||
<text locale="de">Pyramide des Shu</text>
|
||||
<text locale="en">pyramid of Shu</text>
|
||||
</string>
|
||||
<string name="pyramid4">
|
||||
<text locale="de">Pyramide der Nuit</text>
|
||||
<text locale="en">pyramid of Nuit</text>
|
||||
</string>
|
||||
<string name="pyramid5">
|
||||
<text locale="de">Pyramide der Bastet</text>
|
||||
<text locale="en">pyramid of Bastet</text>
|
||||
</string>
|
||||
<string name="pyramid6">
|
||||
<text locale="de">Pyramide des Horus</text>
|
||||
<text locale="en">pyramid of Horus </text>
|
||||
</string>
|
||||
<string name="pyramid7">
|
||||
<text locale="de">Pyramide der Maat</text>
|
||||
<text locale="en">pyramid of Maat</text>
|
||||
</string>
|
||||
<string name="pyramid8">
|
||||
<text locale="de">Pyramide des Osiris</text>
|
||||
<text locale="en">pyramid of Osiris</text>
|
||||
</string>
|
||||
<string name="pyramid9">
|
||||
<text locale="de">Pyramide des Set</text>
|
||||
<text locale="en">pyramid of Set</text>
|
||||
</string>
|
||||
<string name="pyramid10">
|
||||
<text locale="de">Pyramide des Thoth</text>
|
||||
<text locale="en">pyramid of Thoth</text>
|
||||
</string>
|
||||
</strings>
|
||||
|
|
Loading…
Reference in a new issue