forked from github/server
french fixes
conquest rules
This commit is contained in:
parent
167d80957c
commit
d85506b680
10 changed files with 124 additions and 70 deletions
|
@ -1913,57 +1913,6 @@ use_birthdayamulet(region * r, unit * magician, strlist * cmdstrings)
|
||||||
addmessage(r, 0, "Miiauuuuuu...", MSG_MESSAGE, ML_IMPORTANT);
|
addmessage(r, 0, "Miiauuuuuu...", MSG_MESSAGE, ML_IMPORTANT);
|
||||||
}
|
}
|
||||||
|
|
||||||
typedef struct t_umlaut {
|
|
||||||
const char *txt;
|
|
||||||
int id;
|
|
||||||
int typ;
|
|
||||||
} t_umlaut;
|
|
||||||
|
|
||||||
/* Hier sind zum einen Umlaut-Versionen von Schlüsselworten, aber auch
|
|
||||||
* oftmals Umlaut-umschriebene Worte, weil im "normalen" Source die
|
|
||||||
* Umlaut-Version steht, damit die im Report erscheint.
|
|
||||||
* WICHTIG: "setenv LANG en_US" sonst ist ä != Ä
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if 0
|
|
||||||
static const t_umlaut umlaut[] = {
|
|
||||||
/* Parameter */
|
|
||||||
{ "Straßen", P_ROAD, UT_PARAM },
|
|
||||||
/* Gegenstände - alternative Namen */
|
|
||||||
{ "Eisenbarren", I_IRON, UT_ITEM },
|
|
||||||
{ "Holzstamm", I_WOOD, UT_ITEM },
|
|
||||||
{ "Holzstämme", I_WOOD, UT_ITEM },
|
|
||||||
{ "Stämme", I_WOOD, UT_ITEM },
|
|
||||||
{ "Stamm", I_WOOD, UT_ITEM },
|
|
||||||
{ "Quader", I_STONE, UT_ITEM },
|
|
||||||
{ "Steinquader", I_STONE, UT_ITEM },
|
|
||||||
{ "Langbogen", I_LONGBOW, UT_ITEM },
|
|
||||||
{ "Langbögen", I_LONGBOW, UT_ITEM },
|
|
||||||
{ "Hemden", I_CHAIN_MAIL, UT_ITEM },
|
|
||||||
{ "Panzer", I_PLATE_ARMOR, UT_ITEM },
|
|
||||||
{ "Gewürze", I_SPICES, UT_ITEM },
|
|
||||||
{ "Öle", I_OIL, UT_ITEM },
|
|
||||||
{ "Sehens", I_AMULET_OF_TRUE_SEEING, UT_ITEM },
|
|
||||||
{ "Heilung", I_AMULET_OF_HEALING, UT_ITEM },
|
|
||||||
{ "Unsichtbarkeit", I_RING_OF_INVISIBILITY, UT_ITEM },
|
|
||||||
{ "Macht", I_RING_OF_POWER, UT_ITEM },
|
|
||||||
#ifdef COMPATIBILITY
|
|
||||||
{ "Einhornaugen", I_EYE_OF_HORAX, UT_ITEM },
|
|
||||||
{ "Reisekristall", I_TELEPORTCRYSTAL, UT_ITEM },
|
|
||||||
{ "Dunkelheit", I_AMULET_OF_DARKNESS, UT_ITEM },
|
|
||||||
#endif
|
|
||||||
{ "Kopf", I_DRAGONHEAD, UT_ITEM },
|
|
||||||
{ "Köpfe", I_DRAGONHEAD, UT_ITEM },
|
|
||||||
{ "Keuschheitsamulett", I_CHASTITY_BELT, UT_ITEM },
|
|
||||||
{ "Zweihänder", I_GREATSWORD, UT_ITEM },
|
|
||||||
{ "Axt", I_AXE, UT_ITEM },
|
|
||||||
{ "Äxte", I_AXE, UT_ITEM },
|
|
||||||
{ "Treffens", I_AMULETT_DES_TREFFENS, UT_ITEM },
|
|
||||||
{ "Flinkfingerring", I_RING_OF_NIMBLEFINGER, UT_ITEM },
|
|
||||||
{ NULL, 0, 0 }
|
|
||||||
};
|
|
||||||
#endif
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
init_directions(tnode * root, const struct locale * lang)
|
init_directions(tnode * root, const struct locale * lang)
|
||||||
{
|
{
|
||||||
|
|
|
@ -1382,6 +1382,7 @@ static translate_t translation[] = {
|
||||||
{ "Balsam", "balm", "balm_p", "balm", "balm_p" },
|
{ "Balsam", "balm", "balm_p", "balm", "balm_p" },
|
||||||
{ "Gewürz", "spice", "spice_p", "spice", "spice_p" },
|
{ "Gewürz", "spice", "spice_p", "spice", "spice_p" },
|
||||||
{ "Myrrhe", "myrrh", "myrrh_p", "myrrh", "myrrh_p" },
|
{ "Myrrhe", "myrrh", "myrrh_p", "myrrh", "myrrh_p" },
|
||||||
|
{ "Stein", "stone", "stone_p", "stone", "stone_p" },
|
||||||
{ "Öl", "oil", "oil_p", "oil", "oil_p" },
|
{ "Öl", "oil", "oil_p", "oil", "oil_p" },
|
||||||
{ "Seide", "silk", "silk_p", "silk", "silk_p" },
|
{ "Seide", "silk", "silk_p", "silk", "silk_p" },
|
||||||
{ "Weihrauch", "incense", "incense_p", "incense", "incense_p" },
|
{ "Weihrauch", "incense", "incense_p", "incense", "incense_p" },
|
||||||
|
|
|
@ -195,8 +195,11 @@ set_show_item(faction *f, item_t i)
|
||||||
|
|
||||||
void
|
void
|
||||||
give_starting_equipment(struct region *r, struct unit *u)
|
give_starting_equipment(struct region *r, struct unit *u)
|
||||||
|
|
||||||
{
|
{
|
||||||
|
const item_type * token = it_find("conquesttoken");
|
||||||
|
if (token!=NULL) {
|
||||||
|
i_add(&u->items, i_new(token, 1));
|
||||||
|
}
|
||||||
set_item(u, I_WOOD, 30);
|
set_item(u, I_WOOD, 30);
|
||||||
set_item(u, I_STONE, 30);
|
set_item(u, I_STONE, 30);
|
||||||
|
|
||||||
|
|
|
@ -274,6 +274,7 @@ score(void)
|
||||||
#ifdef ALLIANCES
|
#ifdef ALLIANCES
|
||||||
{
|
{
|
||||||
alliance *a;
|
alliance *a;
|
||||||
|
const item_type * token = it_find("conquesttoken");
|
||||||
|
|
||||||
sprintf(buf, "%s/score.alliances", basepath());
|
sprintf(buf, "%s/score.alliances", basepath());
|
||||||
scoreFP = fopen(buf, "w");
|
scoreFP = fopen(buf, "w");
|
||||||
|
@ -281,6 +282,7 @@ score(void)
|
||||||
|
|
||||||
for (a = alliances; a; a = a->next) {
|
for (a = alliances; a; a = a->next) {
|
||||||
int alliance_score = 0, alliance_number = 0, alliance_factions = 0;
|
int alliance_score = 0, alliance_number = 0, alliance_factions = 0;
|
||||||
|
int grails = 0;
|
||||||
|
|
||||||
for (f = factions; f; f = f->next) {
|
for (f = factions; f; f = f->next) {
|
||||||
if(f->alliance && f->alliance->id == a->id) {
|
if(f->alliance && f->alliance->id == a->id) {
|
||||||
|
@ -288,9 +290,21 @@ score(void)
|
||||||
alliance_score += f->score;
|
alliance_score += f->score;
|
||||||
alliance_number += f->number;
|
alliance_number += f->number;
|
||||||
}
|
}
|
||||||
|
if (token!=NULL) {
|
||||||
|
unit * u = f->units;
|
||||||
|
while (u!=NULL) {
|
||||||
|
const item ** iitem = i_find(&u->items, token);
|
||||||
|
if (iitem!=NULL && *iitem!=NULL) {
|
||||||
|
grails += (*iitem)->number;
|
||||||
|
}
|
||||||
|
u=u->nextF;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
fprintf(scoreFP, "%d:%d:%d:%d\n", a->id, alliance_factions, alliance_number, alliance_score);
|
fprintf(scoreFP, "%d:%d:%d:%d", a->id, alliance_factions, alliance_number, alliance_score);
|
||||||
|
if (token!=NULL) fprintf(scoreFP, ":%d", grails);
|
||||||
|
fputc('\n', scoreFP);
|
||||||
}
|
}
|
||||||
fclose(scoreFP);
|
fclose(scoreFP);
|
||||||
}
|
}
|
||||||
|
|
54
src/common/settings-conquest.h
Normal file
54
src/common/settings-conquest.h
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
/* 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 - 2002 | 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.
|
||||||
|
*/
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Contains defines for the "conquest" vinyambar game (Speedgame).
|
||||||
|
* Include this file from settings.h to make eressea work.
|
||||||
|
*/
|
||||||
|
#define CATAPULT_AMMUNITION 1 /* Gebaut werden kann sie auch mit 0! */
|
||||||
|
#define CHANGED_CROSSBOWS 1
|
||||||
|
#define COMBAT_TURNS 5
|
||||||
|
#define ENTERTAINBASE 15
|
||||||
|
#define ENTERTAINPERLEVEL 5
|
||||||
|
#define ENTERTAINFRACTION 20
|
||||||
|
#define GAME_ID 3
|
||||||
|
#define GROWING_TREES 1
|
||||||
|
#define GUARD_DISABLES_PRODUCTION 1
|
||||||
|
#define GUARD_DISABLES_RECRUIT 1
|
||||||
|
#define HUNGER_DISABLES_LONGORDERS 1
|
||||||
|
#define IMMUN_GEGEN_ANGRIFF 8
|
||||||
|
#define LARGE_CASTLES 1
|
||||||
|
#define NEW_MIGRATION 1
|
||||||
|
#define NEW_RESOURCEGROWTH 1
|
||||||
|
#define NMRTIMEOUT 5
|
||||||
|
#define PEASANTS_DO_NOT_STARVE 0
|
||||||
|
#define PEASANT_ADJUSTMENT 1
|
||||||
|
#define RACE_ADJUSTMENTS 1
|
||||||
|
#define RECRUITFRACTION 40 /* 100/RECRUITFRACTION% */
|
||||||
|
#define REDUCED_PEASANTGROWTH 1
|
||||||
|
#define REMOVENMRNEWBIE 0
|
||||||
|
#define RESOURCE_CONVERSION 1
|
||||||
|
#define RESOURCE_QUANTITY 0.5
|
||||||
|
#define TEACHDIFFERENCE 2
|
||||||
|
#define GIVERESTRICTION 0
|
||||||
|
#define NEWATSROI 0
|
||||||
|
#if NEWATSROI == 1
|
||||||
|
#define ATSBONUS 2
|
||||||
|
#define ROIBONUS 4
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#define ENHANCED_QUIT
|
||||||
|
#define ALLIANCES
|
||||||
|
#undef ALLIANCEJOIN
|
||||||
|
#define AUTOALLIANCE (HELP_FIGHT)
|
||||||
|
|
||||||
|
#define MAILITPATH "/usr/sbin:$HOME/bin:/bin:/usr/bin:/usr/local/bin"
|
|
@ -157,6 +157,7 @@ reverse_lookup(const locale * lang, const char * str)
|
||||||
{
|
{
|
||||||
int i;
|
int i;
|
||||||
assert(lang);
|
assert(lang);
|
||||||
|
if (strlen(str)) {
|
||||||
if (lang!=NULL) {
|
if (lang!=NULL) {
|
||||||
for (i=0;i!=SMAXHASH;++i) {
|
for (i=0;i!=SMAXHASH;++i) {
|
||||||
struct locale_string * ls;
|
struct locale_string * ls;
|
||||||
|
@ -166,6 +167,8 @@ reverse_lookup(const locale * lang, const char * str)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
log_warning(("could not do a reverse_lookup for \"%s\" in locale %s\n", str, lang->name));
|
||||||
|
}
|
||||||
return str;
|
return str;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@
|
||||||
|
|
||||||
#include <config.h>
|
#include <config.h>
|
||||||
#include "nrmessage.h"
|
#include "nrmessage.h"
|
||||||
|
#include "nrmessage_struct.h"
|
||||||
|
|
||||||
/* util includes */
|
/* util includes */
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
@ -25,18 +26,12 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <stdlib.h>
|
#include <stdlib.h>
|
||||||
|
|
||||||
typedef struct nrmessage_type {
|
|
||||||
const struct message_type * mtype;
|
|
||||||
const struct locale * lang;
|
|
||||||
const char * string;
|
|
||||||
const char * vars;
|
|
||||||
struct nrmessage_type * next;
|
|
||||||
int level;
|
|
||||||
const char * section;
|
|
||||||
} nrmessage_type;
|
|
||||||
|
|
||||||
static nrmessage_type * messagetypes;
|
static nrmessage_type * messagetypes;
|
||||||
|
|
||||||
|
nrmessage_type * get_nrmessagetypes(void) {
|
||||||
|
return messagetypes;
|
||||||
|
}
|
||||||
|
|
||||||
const char *
|
const char *
|
||||||
nrt_string(const struct nrmessage_type *type)
|
nrt_string(const struct nrmessage_type *type)
|
||||||
{
|
{
|
||||||
|
|
|
@ -2840,7 +2840,7 @@ korrektur(void)
|
||||||
do_once("fsee", fix_seeds());
|
do_once("fsee", fix_seeds());
|
||||||
do_once("orc2", orc_conversion2());
|
do_once("orc2", orc_conversion2());
|
||||||
do_once("witm", warn_items());
|
do_once("witm", warn_items());
|
||||||
do_once("guac", guard_conversion());
|
do_once("guaf", guard_conversion());
|
||||||
do_once("qpoi", questportal_init());
|
do_once("qpoi", questportal_init());
|
||||||
do_once("xini", xe_init());
|
do_once("xini", xe_init());
|
||||||
do_once("rest", fix_restart_flag());
|
do_once("rest", fix_restart_flag());
|
||||||
|
|
21
src/res/conquest.xml
Normal file
21
src/res/conquest.xml
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
<eressea>
|
||||||
|
<include file="messages.xml"></include>
|
||||||
|
|
||||||
|
<comment>Localization</comment>
|
||||||
|
<include file="de/strings.xml"></include>
|
||||||
|
<include file="en/strings.xml"></include>
|
||||||
|
|
||||||
|
<include file="races.xml"></include>
|
||||||
|
<include file="resources.xml"></include>
|
||||||
|
<include file="ships.xml"></include>
|
||||||
|
<include file="buildings.xml"></include>
|
||||||
|
|
||||||
|
<game name="Kreis der Macht" units="250" welcome="vinyambar">
|
||||||
|
<comment>Game specific</comment>
|
||||||
|
<order name="ARBEITEN" disable></order>
|
||||||
|
<order name="MEINUNG" disable></order>
|
||||||
|
<order name="MAGIEGEBIET" disable></order>
|
||||||
|
</game>
|
||||||
|
<include file="vinyambar/de/strings.xml"></include>
|
||||||
|
<include file="vinyambar/conquest.xml"></include>
|
||||||
|
</eressea>
|
14
src/res/vinyambar/conquest.xml
Normal file
14
src/res/vinyambar/conquest.xml
Normal file
|
@ -0,0 +1,14 @@
|
||||||
|
<resource name="conquesttoken">
|
||||||
|
<item cursed notlost weight="0">
|
||||||
|
</item>
|
||||||
|
</resource>
|
||||||
|
<strings>
|
||||||
|
<string name="conquesttoken">
|
||||||
|
<text locale="de">Gral</text>
|
||||||
|
<text locale="en">grail</text>
|
||||||
|
</string>
|
||||||
|
<string name="conquesttoken_p">
|
||||||
|
<text locale="de">Grale</text>
|
||||||
|
<text locale="en">grails</text>
|
||||||
|
</string>
|
||||||
|
</strings>
|
Loading…
Reference in a new issue