WdW-Pyramiden

This commit is contained in:
Christian Schlittchen 2005-10-23 11:27:55 +00:00
parent f6cc641d9c
commit 1c7ace7556
13 changed files with 224 additions and 101 deletions

View file

@ -9,6 +9,7 @@ SubDirHdrs $(SUBDIR)/../.. ;
SOURCES =
aggressive.c
alliance.c
at_movement.c
attributes.c
fleechance.c

View file

@ -39,6 +39,9 @@
#endif
#include "moved.h"
#include "variable.h"
#ifdef WDW_PYRAMID
#include "alliance.h"
#endif
/* util includes */
#include <attrib.h>

View file

@ -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);

View file

@ -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);

View file

@ -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
}

View file

@ -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 {

View file

@ -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;

View file

@ -53,4 +53,4 @@
#undef XECMD_MODULE
#define WDW_PHOENIX
#define WDW_PYRAMIDSPELL
/* #define WDW_PYRAMID 1 */
#define WDW_PYRAMID

View file

@ -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">

View file

@ -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"/>

View file

@ -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">

View 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>

View file

@ -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>