Merge pull request #636 from ennorehling/develop

issue #633 & #477
This commit is contained in:
Enno Rehling 2017-01-23 11:42:31 +01:00 committed by GitHub
commit bce2afac12
6 changed files with 69 additions and 31 deletions

View file

@ -214,6 +214,27 @@ param_t findparam(const char *s, const struct locale * lang)
return result; return result;
} }
param_t findparam_block(const char *s, const struct locale *lang, bool any_locale)
{
param_t p;
if (!s || s[0] == '@') {
return NOPARAM;
}
p = findparam(s, lang);
if (any_locale && p==NOPARAM) {
const struct locale *loc;
for (loc=locales;loc;loc=nextlocale(loc)) {
if (loc!=lang) {
p = findparam(s, loc);
if (p==P_FACTION || p==P_GAMENAME) {
break;
}
}
}
}
return p;
}
param_t findparam_ex(const char *s, const struct locale * lang) param_t findparam_ex(const char *s, const struct locale * lang)
{ {
param_t result = findparam(s, lang); param_t result = findparam(s, lang);

View file

@ -45,6 +45,7 @@ extern "C" {
int findoption(const char *s, const struct locale *lang); int findoption(const char *s, const struct locale *lang);
param_t findparam(const char *s, const struct locale *lang); param_t findparam(const char *s, const struct locale *lang);
param_t findparam_block(const char *s, const struct locale *lang, bool any_locale);
param_t findparam_ex(const char *s, const struct locale * lang); param_t findparam_ex(const char *s, const struct locale * lang);
bool isparam(const char *s, const struct locale * lang, param_t param); bool isparam(const char *s, const struct locale * lang, param_t param);
param_t getparam(const struct locale *lang); param_t getparam(const struct locale *lang);

View file

@ -251,9 +251,33 @@ static void test_config_inifile(CuTest *tc) {
test_cleanup(); test_cleanup();
} }
static void test_findparam(CuTest *tc) {
struct locale *en, *de;
test_setup();
en = get_or_create_locale("en");
locale_setstring(en, parameters[P_FACTION], "FACTION");
CuAssertIntEquals(tc, NOPARAM, findparam("FACTION", en));
init_parameters(en);
CuAssertIntEquals(tc, P_FACTION, findparam("FACTION", en));
de = get_or_create_locale("de");
locale_setstring(de, parameters[P_FACTION], "PARTEI");
CuAssertIntEquals(tc, NOPARAM, findparam("PARTEI", de));
init_parameters(de);
CuAssertIntEquals(tc, P_FACTION, findparam("PARTEI", de));
CuAssertIntEquals(tc, NOPARAM, findparam("HODOR", de));
CuAssertIntEquals(tc, NOPARAM, findparam("PARTEI", en));
CuAssertIntEquals(tc, NOPARAM, findparam_block("HODOR", de, false));
CuAssertIntEquals(tc, P_FACTION, findparam_block("PARTEI", de, true));
CuAssertIntEquals(tc, NOPARAM, findparam_block("PARTEI", en, false));
CuAssertIntEquals(tc, P_FACTION, findparam_block("PARTEI", en, true));
test_cleanup();
}
CuSuite *get_config_suite(void) CuSuite *get_config_suite(void)
{ {
CuSuite *suite = CuSuiteNew(); CuSuite *suite = CuSuiteNew();
SUITE_ADD_TEST(suite, test_findparam);
SUITE_ADD_TEST(suite, test_config_inifile); SUITE_ADD_TEST(suite, test_config_inifile);
SUITE_ADD_TEST(suite, test_config_cache); SUITE_ADD_TEST(suite, test_config_cache);
SUITE_ADD_TEST(suite, test_get_set_param); SUITE_ADD_TEST(suite, test_get_set_param);

View file

@ -252,26 +252,6 @@ static faction *factionorders(void)
return f; return f;
} }
static param_t next_param(const char *s, const struct locale *lang) {
param_t p;
if (!s || s[0] == '@') {
return NOPARAM;
}
p = findparam(s, lang);
if (p==NOPARAM) {
const struct locale *loc;
for (loc=locales;loc;loc=nextlocale(loc)) {
if (loc!=lang) {
p = findparam(s, lang);
if (p==P_FACTION || p==P_GAMENAME) {
break;
}
}
}
}
return p;
}
int readorders(const char *filename) int readorders(const char *filename)
{ {
FILE *F = NULL; FILE *F = NULL;
@ -299,7 +279,7 @@ int readorders(const char *filename)
const char *s; const char *s;
init_tokens_str(b); init_tokens_str(b);
s = gettoken(token, sizeof(token)); s = gettoken(token, sizeof(token));
p = next_param(s, lang); p = findparam_block(s, lang, true);
switch (p) { switch (p) {
case P_GAMENAME: case P_GAMENAME:
case P_FACTION: case P_FACTION:

View file

@ -295,13 +295,14 @@ void init_translations(const struct locale *lang, int ut, const char * (*string_
// TODO: swap the name of s and key // TODO: swap the name of s and key
const char * s = string_cb(i); const char * s = string_cb(i);
if (s) { if (s) {
struct critbit_tree ** cb = (struct critbit_tree **)tokens;
const char * key = locale_string(lang, s, false); const char * key = locale_string(lang, s, false);
if (!key) key = s; if (key) {
struct critbit_tree ** cb = (struct critbit_tree **)tokens;
add_translation(cb, key, i); add_translation(cb, key, i);
} }
} }
} }
}
void *get_translation(const struct locale *lang, const char *str, int index) { void *get_translation(const struct locale *lang, const char *str, int index) {
void **tokens = get_translations(lang, index); void **tokens = get_translations(lang, index);

View file

@ -55,7 +55,7 @@ static int nb_armor(const unit * u, int index)
if (!(u_race(u)->battle_flags & BF_EQUIPMENT)) if (!(u_race(u)->battle_flags & BF_EQUIPMENT))
return 0; return 0;
/* Normale Rüstung */ /* Normale R<EFBFBD>stung */
for (itm = u->items; itm; itm = itm->next) { for (itm = u->items; itm; itm = itm->next) {
const armor_type *atype = itm->type->rtype->atype; const armor_type *atype = itm->type->rtype->atype;
@ -169,11 +169,11 @@ static region *rrandneighbour(region * r)
for (i = 0; i != MAXDIRECTIONS; i++) { for (i = 0; i != MAXDIRECTIONS; i++) {
c++; c++;
} }
/* Zufällig eine auswählen */ /* Zuf<EFBFBD>llig eine ausw<73>hlen */
rr = rng_int() % c; rr = rng_int() % c;
/* Durchzählen */ /* Durchz<EFBFBD>hlen */
c = -1; c = -1;
for (i = 0; i != MAXDIRECTIONS; i++) { for (i = 0; i != MAXDIRECTIONS; i++) {
@ -204,7 +204,7 @@ volcano_destruction(region * volcano, region * r, const char *damage)
else { else {
/* Produktion vierteln ... */ /* Produktion vierteln ... */
a->data.sa[0] = (short)percent; a->data.sa[0] = (short)percent;
/* Für 6-17 Runden */ /* F<EFBFBD>r 6-17 Runden */
a->data.sa[1] = (short)(a->data.sa[1] + time); a->data.sa[1] = (short)(a->data.sa[1] + time);
} }
@ -255,6 +255,14 @@ void volcano_outbreak(region * r, region *rn)
} }
} }
static bool stop_smoke_chance(void) {
return rng_int() % 100 < 12;
}
static bool outbreak_chance(void) {
return rng_int() % 100 < 8;
}
void volcano_update(void) void volcano_update(void)
{ {
region *r; region *r;
@ -270,13 +278,16 @@ void volcano_update(void)
r->terrain = t_volcano; r->terrain = t_volcano;
} }
else { else {
if (rng_int() % 100 < 12) { if (stop_smoke_chance()) {
ADDMSG(&r->msgs, msg_message("volcanostopsmoke", "region", r)); ADDMSG(&r->msgs, msg_message("volcanostopsmoke", "region", r));
r->terrain = t_volcano; r->terrain = t_volcano;
} }
else if (r->uid == 1246051340 || (r->age > 20 && rng_int() % 100 < 8)) { else if (r->uid == 1246051340 || outbreak_chance()) {
// HACK: a fixed E4-only region-uid in Code.
// FIXME: In E4 gibt es eine Ebene #1246051340, die Smalland heisst.
// da das kein aktiver Vulkan ist, ist dieser Test da nicht idiotisch?
// das sollte bestimmt rn betreffen?
region *rn; region *rn;
/* Zufällige Nachbarregion verwüsten */
rn = rrandneighbour(r); rn = rrandneighbour(r);
volcano_outbreak(r, rn); volcano_outbreak(r, rn);
r->terrain = t_volcano; r->terrain = t_volcano;