forked from github/server
* Schiffe werden in XML-Datei gespeichert.
This commit is contained in:
parent
0d76ceabb9
commit
8df7894084
14 changed files with 235 additions and 26 deletions
|
@ -113,7 +113,7 @@ typedef struct construction {
|
|||
int reqsize; /* size of object using up 1 set of requirement. */
|
||||
requirement * materials; /* material req'd to build one object */
|
||||
|
||||
const struct construction * improvement;
|
||||
struct construction * improvement;
|
||||
/* next level, if upgradable. if more than one of these items
|
||||
* can be built (weapons, armour) per turn, must not be NULL,
|
||||
* but point to the same type again:
|
||||
|
|
|
@ -222,7 +222,7 @@ static requirement castle_req[] = {
|
|||
};
|
||||
|
||||
#if LARGE_CASTLES
|
||||
static const construction castle_bld[MAXBUILDINGS] = {
|
||||
static construction castle_bld[MAXBUILDINGS] = {
|
||||
{ SK_BUILDING, 1, 2, 1, castle_req, &castle_bld[1] },
|
||||
{ SK_BUILDING, 1, 8, 1, castle_req, &castle_bld[2] },
|
||||
{ SK_BUILDING, 2, 40, 1, castle_req, &castle_bld[3] },
|
||||
|
@ -232,7 +232,7 @@ static const construction castle_bld[MAXBUILDINGS] = {
|
|||
{ SK_BUILDING, 6, -1, 1, castle_req, NULL }
|
||||
};
|
||||
#else
|
||||
static const construction castle_bld[MAXBUILDINGS] = {
|
||||
static construction castle_bld[MAXBUILDINGS] = {
|
||||
{ SK_BUILDING, 1, 2, 1, castle_req, &castle_bld[1] },
|
||||
{ SK_BUILDING, 2, 8, 1, castle_req, &castle_bld[2] },
|
||||
{ SK_BUILDING, 3, 40, 1, castle_req, &castle_bld[3] },
|
||||
|
|
|
@ -2233,6 +2233,7 @@ attrib_init(void)
|
|||
bt_register(&bt_generic);
|
||||
bt_register(&bt_caldera);
|
||||
|
||||
#ifdef NOXMLBOATS
|
||||
/* Schiffstypen registrieren: */
|
||||
st_register(&st_boat);
|
||||
st_register(&st_balloon);
|
||||
|
@ -2240,6 +2241,7 @@ attrib_init(void)
|
|||
st_register(&st_dragonship);
|
||||
st_register(&st_caravelle);
|
||||
st_register(&st_trireme);
|
||||
#endif
|
||||
|
||||
/* disable: st_register(&st_transport); */
|
||||
|
||||
|
|
|
@ -259,7 +259,7 @@ give_starting_equipment(struct region *r, struct unit *u)
|
|||
break;
|
||||
case RC_AQUARIAN:
|
||||
{
|
||||
ship *sh = new_ship(&st_boat, r);
|
||||
ship *sh = new_ship(st_find("boat"), r);
|
||||
sh->size = sh->type->construction->maxsize;
|
||||
addlist(&r->ships, sh);
|
||||
u->ship = sh;
|
||||
|
|
|
@ -1299,9 +1299,13 @@ readgame(boolean backup)
|
|||
rds(F, &sh->display);
|
||||
|
||||
if (global.data_version < SHIPTYPE_VERSION) {
|
||||
#ifdef NOXMLBOATS
|
||||
const ship_type * oldship[] = { &st_boat, &st_balloon, &st_longboat, &st_dragonship, &st_caravelle, &st_trireme };
|
||||
int i = ri(F);
|
||||
sh->type = oldship[i];
|
||||
#else
|
||||
assert(!"cannot read old datafile with xml ship support");
|
||||
#endif
|
||||
}
|
||||
else {
|
||||
rs(F, buf);
|
||||
|
|
|
@ -20,10 +20,12 @@
|
|||
#include "unit.h"
|
||||
#include "item.h"
|
||||
#include "region.h"
|
||||
#include "skill.h"
|
||||
|
||||
/* util includes */
|
||||
#include <base36.h>
|
||||
#include <event.h>
|
||||
#include <xml.h>
|
||||
#include <language.h>
|
||||
|
||||
/* libc includes */
|
||||
|
@ -66,9 +68,9 @@ st_find(const char* name)
|
|||
{
|
||||
const struct ship_typelist * stl = shiptypes;
|
||||
while (stl && strcasecmp(stl->type->name[0], name)) stl = stl->next;
|
||||
if (!stl) {
|
||||
if (!stl) { /* compatibility for old datafiles */
|
||||
stl = shiptypes;
|
||||
while (stl && strncasecmp(stl->type->name[0], name, strlen(name))) stl = stl->next;
|
||||
while (stl && strcasecmp(locale_string(default_locale, stl->type->name[0]), name)) stl = stl->next;
|
||||
}
|
||||
return stl?stl->type:NULL;
|
||||
}
|
||||
|
@ -81,16 +83,6 @@ st_register(const ship_type * type) {
|
|||
shiptypes = stl;
|
||||
}
|
||||
|
||||
static const terrain_t coast_large[] = {
|
||||
T_OCEAN, T_PLAIN, NOTERRAIN
|
||||
};
|
||||
|
||||
static const terrain_t coast_small[] = {
|
||||
T_OCEAN, T_PLAIN, T_SWAMP, T_DESERT, T_HIGHLAND, T_MOUNTAIN, T_GLACIER,
|
||||
T_GRASSLAND, T_VOLCANO, T_VOLCANO_SMOKING, T_ICEBERG_SLEEP, T_ICEBERG,
|
||||
NOTERRAIN
|
||||
};
|
||||
|
||||
#define SMAXHASH 8191
|
||||
ship *shiphash[SMAXHASH];
|
||||
void
|
||||
|
@ -155,6 +147,17 @@ captain(ship *sh, region *r)
|
|||
|
||||
/* Alte Schiffstypen: */
|
||||
|
||||
#ifdef NOXMLBOATS
|
||||
static const terrain_t coast_large[] = {
|
||||
T_OCEAN, T_PLAIN, NOTERRAIN
|
||||
};
|
||||
|
||||
static terrain_t coast_small[] = {
|
||||
T_OCEAN, T_PLAIN, T_SWAMP, T_DESERT, T_HIGHLAND, T_MOUNTAIN, T_GLACIER,
|
||||
T_GRASSLAND, T_VOLCANO, T_VOLCANO_SMOKING, T_ICEBERG_SLEEP, T_ICEBERG,
|
||||
NOTERRAIN
|
||||
};
|
||||
|
||||
static requirement boat_req[] = {
|
||||
{I_WOOD, 1},
|
||||
{0, 0}
|
||||
|
@ -263,6 +266,7 @@ const ship_type st_trireme = {
|
|||
4, 1, 120, coast_large,
|
||||
&trireme_bld
|
||||
};
|
||||
#endif
|
||||
|
||||
ship *
|
||||
new_ship(const ship_type * stype, region * r)
|
||||
|
@ -343,3 +347,149 @@ shipowner(const region * r, const ship * sh)
|
|||
fset(first, FL_OWNER);
|
||||
return first;
|
||||
}
|
||||
|
||||
#ifdef NOXMLBOATS
|
||||
void
|
||||
xml_writeships(void)
|
||||
{
|
||||
FILE * F = fopen("ships.xml", "w");
|
||||
ship_typelist *stl= shiptypes;
|
||||
while (stl) {
|
||||
int i;
|
||||
const ship_type * st = stl->type;
|
||||
fprintf(F, "<ship name=\"%s\" range=\"%u\" storm=\"%.2f\" damage=\"%.2f\" cabins=\"%u\" cargo=\"%u\" cptskill=\"%u\" minskill=\"%u\" sumskill=\"%u\"",
|
||||
locale_string(find_locale("en"), st->name[0]), st->range, st->storm, st->damage, st->cabins, st->cargo,
|
||||
st->cptskill, st->minskill, st->sumskill);
|
||||
if (st->flags & SFL_OPENSEA) fputs(" opensea", F);
|
||||
if (st->flags & SFL_FLY) fputs(" fly", F);
|
||||
fputs(">\n", F);
|
||||
for (i=0;st->coast[i]!=NOTERRAIN;++i) {
|
||||
fprintf(F, "\t<coast terrain=\"%s\"></coast>\n", terrain[st->coast[i]].name);
|
||||
}
|
||||
fprintf(F, "\t<construction skill=\"%s\" minskill=\"%u\" maxsize=\"%u\" reqsize=\"%u\">\n",
|
||||
skillname(st->construction->skill, NULL), st->construction->minskill,
|
||||
st->construction->maxsize, st->construction->reqsize);
|
||||
for (i=0;st->construction->materials[i].number!=0;++i) {
|
||||
fprintf(F, "\t\t<requirement type=\"%s\" quantity=\"%d\"></requirement>\n",
|
||||
oldresourcetype[st->construction->materials[i].type]->_name[0],
|
||||
st->construction->materials[i].number);
|
||||
}
|
||||
fputs("\t</construction>\n", F);
|
||||
fputs("</ship>\n\n", F);
|
||||
stl=stl->next;
|
||||
}
|
||||
fclose(F);
|
||||
}
|
||||
#endif
|
||||
|
||||
static int
|
||||
tagend(struct xml_stack * stack)
|
||||
{
|
||||
const xml_tag * tag = stack->tag;
|
||||
if (strcmp(tag->name, "ship")==0) {
|
||||
st_register((ship_type*)stack->state);
|
||||
stack->state = 0;
|
||||
}
|
||||
return XML_OK;
|
||||
}
|
||||
|
||||
static int
|
||||
tagbegin(struct xml_stack * stack)
|
||||
{
|
||||
ship_type * st = (ship_type *)stack->state;
|
||||
const xml_tag * tag = stack->tag;
|
||||
if (strcmp(tag->name, "ship")==0) {
|
||||
const char * name = xml_value(tag, "name");
|
||||
if (name!=NULL) {
|
||||
st = stack->state = calloc(sizeof(ship_type), 1);
|
||||
st->name[0] = strdup(name);
|
||||
st->name[1] = strcat(strcpy(malloc(strlen(name)+3), name),"_a");
|
||||
st->cabins = xml_ivalue(tag, "cabins");
|
||||
st->cargo = xml_ivalue(tag, "cargo");
|
||||
st->combat = xml_ivalue(tag, "combat");
|
||||
st->cptskill = xml_ivalue(tag, "cptskill");
|
||||
st->damage = xml_fvalue(tag, "damage");
|
||||
if (xml_bvalue(tag, "fly")) st->flags |= SFL_FLY;
|
||||
if (xml_bvalue(tag, "opensea")) st->flags |= SFL_OPENSEA;
|
||||
st->minskill = xml_ivalue(tag, "minskill");
|
||||
st->range = xml_ivalue(tag, "range");
|
||||
st->storm = xml_fvalue(tag, "storm");
|
||||
st->sumskill = xml_ivalue(tag, "sumskill");
|
||||
}
|
||||
} else if (st!=NULL) {
|
||||
if (strcmp(tag->name, "coast")==0) {
|
||||
int size=0;
|
||||
terrain_t t;
|
||||
terrain_t * add;
|
||||
const char * tname = xml_value(tag, "terrain");
|
||||
if (tname!=NULL) {
|
||||
if (st->coast) {
|
||||
terrain_t * tnew;
|
||||
for (;st->coast[size++];);
|
||||
tnew = malloc(sizeof(terrain_t) * (size+2));
|
||||
memcpy(tnew, st->coast, size*sizeof(terrain_t));
|
||||
free(st->coast);
|
||||
st->coast = tnew;
|
||||
add = st->coast+size;
|
||||
} else {
|
||||
st->coast = malloc(sizeof(terrain_t) * 2);
|
||||
add = st->coast;
|
||||
}
|
||||
add[0] = NOTERRAIN;
|
||||
for (t=0;t!=MAXTERRAINS;++t) if (strcmp(tname, terrain[t].name)==0) {
|
||||
add[0] = t;
|
||||
break;
|
||||
}
|
||||
add[1] = NOTERRAIN;
|
||||
}
|
||||
} else if (strcmp(tag->name, "construction")==0) {
|
||||
construction * con = st->construction = calloc(sizeof(construction), 1);
|
||||
con->maxsize = xml_ivalue(tag, "maxsize");
|
||||
con->minskill = xml_ivalue(tag, "minskill");
|
||||
con->reqsize = xml_ivalue(tag, "reqsize");
|
||||
con->skill = sk_find(xml_value(tag, "skill"));
|
||||
} else if (strcmp(tag->name, "requirement")==0) {
|
||||
construction * con = st->construction;
|
||||
if (con!=NULL) {
|
||||
const resource_type * rtype;
|
||||
resource_t type = NORESOURCE;
|
||||
requirement * radd = con->materials;
|
||||
if (radd) {
|
||||
requirement * rnew;
|
||||
int size;
|
||||
for (size=0;radd[size++].number;);
|
||||
rnew = malloc(sizeof(requirement) * (size+2));
|
||||
memcpy(rnew, radd, size*sizeof(requirement));
|
||||
free(radd);
|
||||
con->materials = rnew;
|
||||
radd = rnew+size;
|
||||
} else {
|
||||
radd = con->materials = calloc(sizeof(requirement), 2);
|
||||
}
|
||||
radd[0].number = xml_ivalue(tag, "quantity");
|
||||
rtype = rt_find(xml_value(tag, "type"));
|
||||
for (type=0;type!=MAX_RESOURCES;++type) {
|
||||
if (oldresourcetype[type]==rtype) {
|
||||
radd[0].type = type;
|
||||
break;
|
||||
}
|
||||
}
|
||||
radd[1].number = 0;
|
||||
radd[1].type = 0;
|
||||
}
|
||||
}
|
||||
}
|
||||
return XML_OK;
|
||||
}
|
||||
|
||||
static xml_callbacks xml_ships = {
|
||||
tagbegin, tagend, NULL
|
||||
};
|
||||
|
||||
void
|
||||
register_ships(void)
|
||||
{
|
||||
#ifndef NOXMLBOATS
|
||||
xml_register(&xml_ships, "eressea ship", 0);
|
||||
#endif
|
||||
}
|
|
@ -40,9 +40,9 @@ typedef struct ship_type {
|
|||
int minskill; /* min. skill to sail this (crew) */
|
||||
int sumskill; /* min. sum of crew+captain */
|
||||
|
||||
const terrain_t * coast; /* coast that this ship can land on */
|
||||
terrain_t * coast; /* coast that this ship can land on */
|
||||
|
||||
const construction * construction; /* how to build a ship */
|
||||
construction * construction; /* how to build a ship */
|
||||
} ship_type;
|
||||
|
||||
typedef struct ship_typelist {
|
||||
|
@ -53,15 +53,15 @@ typedef struct ship_typelist {
|
|||
extern ship_typelist *shiptypes;
|
||||
|
||||
/* Alte Schiffstypen: */
|
||||
|
||||
#ifdef NOXMLBOATS
|
||||
extern const ship_type st_boat;
|
||||
extern const ship_type st_balloon;
|
||||
extern const ship_type st_longboat;
|
||||
extern const ship_type st_dragonship;
|
||||
extern const ship_type st_caravelle;
|
||||
extern const ship_type st_trireme;
|
||||
|
||||
extern const ship_type st_transport;
|
||||
#endif
|
||||
|
||||
extern const ship_type * st_find(const char* name);
|
||||
extern void st_register(const ship_type * type);
|
||||
|
@ -95,4 +95,5 @@ extern ship *findship(int n);
|
|||
|
||||
extern const struct ship_type * findshiptype(const char *s, const struct locale * lang);
|
||||
|
||||
extern void register_ships(void);
|
||||
#endif
|
||||
|
|
|
@ -164,6 +164,7 @@ game_init(void)
|
|||
debug_language("locales.log");
|
||||
register_races();
|
||||
register_resources();
|
||||
register_ships();
|
||||
register_items();
|
||||
register_spells();
|
||||
register_dungeon();
|
||||
|
@ -582,7 +583,8 @@ main(int argc, char *argv[])
|
|||
kernel_init();
|
||||
game_init();
|
||||
#if defined(BETA_CODE) && 0
|
||||
xml_writeitems("items.xml");
|
||||
xml_writeships();
|
||||
/* xml_writeitems("items.xml"); */
|
||||
return 0;
|
||||
#endif
|
||||
|
||||
|
|
|
@ -1467,6 +1467,7 @@ main(int argc, char *argv[])
|
|||
|
||||
register_races();
|
||||
register_resources();
|
||||
register_ships();
|
||||
register_items();
|
||||
register_spells();
|
||||
/* register_dungeon(); */
|
||||
|
|
|
@ -2,6 +2,7 @@
|
|||
_d: dativ (wir erklären allen /Trollen/ den Krieg)
|
||||
_p: plural (13 /Trolle/)
|
||||
_x: preposition (15 /Troll/schwerter)
|
||||
_a: including article (ein Troll, a troll)
|
||||
</comment>
|
||||
|
||||
<strings>
|
||||
|
@ -194,19 +195,41 @@
|
|||
</string>
|
||||
|
||||
<comment>Schiffstypen</comment>
|
||||
<string name="Karavelle">
|
||||
<string name="balloon_a">
|
||||
<text locale="de">ein Ballon</text>
|
||||
</string>
|
||||
<string name="caravel_a">
|
||||
<text locale="de">eine Karavelle</text>
|
||||
</string>
|
||||
<string name="boat_a">
|
||||
<text locale="de">ein Boot</text>
|
||||
</string>
|
||||
<string name="longboat_a">
|
||||
<text locale="de">ein Langboot</text>
|
||||
</string>
|
||||
<string name="dragonship_a">
|
||||
<text locale="de">ein Drachenschiff</text>
|
||||
</string>
|
||||
<string name="Trireme_a">
|
||||
<text locale="de">eine Trireme</text>
|
||||
</string>
|
||||
|
||||
<string name="balloon">
|
||||
<text locale="de">Ballon</text>
|
||||
</string>
|
||||
<string name="caravel">
|
||||
<text locale="de">Karavelle</text>
|
||||
</string>
|
||||
<string name="Boot">
|
||||
<string name="boat">
|
||||
<text locale="de">Boot</text>
|
||||
</string>
|
||||
<string name="Langboot">
|
||||
<string name="longboat">
|
||||
<text locale="de">Langboot</text>
|
||||
</string>
|
||||
<string name="Drachenschiff">
|
||||
<string name="dragonship">
|
||||
<text locale="de">Drachenschiff</text>
|
||||
</string>
|
||||
<string name="Trireme">
|
||||
<string name="trireme">
|
||||
<text locale="de">Trireme</text>
|
||||
</string>
|
||||
|
||||
|
|
|
@ -62,6 +62,29 @@
|
|||
<string name="Trireme">
|
||||
<text locale="en">trireme</text>
|
||||
</string>
|
||||
<string name="balloon">
|
||||
<text locale="en">balloon</text>
|
||||
</string>
|
||||
|
||||
<comment>Schiffstypen</comment>
|
||||
<string name="caravel_a">
|
||||
<text locale="en">a caravel</text>
|
||||
</string>
|
||||
<string name="boat_a">
|
||||
<text locale="en">a boat</text>
|
||||
</string>
|
||||
<string name="longboat_a">
|
||||
<text locale="en">a longboat</text>
|
||||
</string>
|
||||
<string name="balloon_a">
|
||||
<text locale="en">a balloon</text>
|
||||
</string>
|
||||
<string name="dragonship_a">
|
||||
<text locale="en">a dragonship</text>
|
||||
</string>
|
||||
<string name="trireme_a">
|
||||
<text locale="en">a trireme</text>
|
||||
</string>
|
||||
|
||||
<comment> Terraintypen</comment>
|
||||
<string name="activevolcano">
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
<include file="races.xml"></include>
|
||||
<include file="resources.xml"></include>
|
||||
<include file="ships.xml"></include>
|
||||
|
||||
<game name="Eressea" welcome="eressea">
|
||||
<comment>Game specific</comment>
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
<include file="races.xml"></include>
|
||||
<include file="resources.xml"></include>
|
||||
<include file="ships.xml"></include>
|
||||
|
||||
<game name="Vinyambar I" units="250" welcome="vinyambar">
|
||||
<comment>Game specific</comment>
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
<include file="races.xml"></include>
|
||||
<include file="resources.xml"></include>
|
||||
<include file="ships.xml"></include>
|
||||
|
||||
<game name="Vinyambar II" units="250" welcome="vinyambar">
|
||||
<comment>Game specific</comment>
|
||||
|
|
Loading…
Reference in a new issue