|
@@ -276,17 +276,16 @@ static byte MakeFinnishTownName(char *bu
|
|
|
//null terminates the string for strcat
|
|
|
strcpy(buf, "");
|
|
|
|
|
|
// Select randomly if town name should consists of one or two parts.
|
|
|
if (SeedChance(0, 15, seed) >= 10) {
|
|
|
strcat(buf, name_finnish_real[SeedChance( 2, lengthof(name_finnish_real), seed)]);
|
|
|
}
|
|
|
// A two-part name by combining one of name_finnish_1 + "la"/"lä"
|
|
|
// The reason for not having the contents of name_finnish_{1,2} in the same table is
|
|
|
// that the ones in name_finnish_2 are not good for this purpose.
|
|
|
else if (SeedChance(0, 15, seed) >= 5) {
|
|
|
} else if (SeedChance(0, 15, seed) >= 5) {
|
|
|
// A two-part name by combining one of name_finnish_1 + "la"/"lä"
|
|
|
// The reason for not having the contents of name_finnish_{1,2} in the same table is
|
|
|
// that the ones in name_finnish_2 are not good for this purpose.
|
|
|
uint sel = SeedChance( 0, lengthof(name_finnish_1), seed);
|
|
|
char *last;
|
|
|
strcat(buf, name_finnish_1[sel]);
|
|
|
last = &buf[strlen(buf)-1];
|
|
|
if (*last == 'i')
|
|
|
*last = 'e';
|
|
@@ -294,16 +293,15 @@ static byte MakeFinnishTownName(char *bu
|
|
|
strstr(buf, "A") || strstr(buf, "O") || strstr(buf, "U"))
|
|
|
{
|
|
|
strcat(buf, "la");
|
|
|
} else {
|
|
|
strcat(buf, "lä");
|
|
|
}
|
|
|
}
|
|
|
// A two-part name by combining one of name_finnish_{1,2} + name_finnish_3.
|
|
|
// Why aren't name_finnish_{1,2} just one table? See above.
|
|
|
else {
|
|
|
} else {
|
|
|
// A two-part name by combining one of name_finnish_{1,2} + name_finnish_3.
|
|
|
// Why aren't name_finnish_{1,2} just one table? See above.
|
|
|
uint sel = SeedChance(2,
|
|
|
lengthof(name_finnish_1) + lengthof(name_finnish_2), seed);
|
|
|
if (sel >= lengthof(name_finnish_1)) {
|
|
|
strcat(buf, name_finnish_2[sel-lengthof(name_finnish_1)]);
|
|
|
} else {
|
|
|
strcat(buf, name_finnish_1[sel]);
|
|
@@ -421,16 +419,17 @@ static byte MakeCzechTownName(char *buf,
|
|
|
postfix %= lengthof(name_czech_subst_postfix);
|
|
|
}
|
|
|
if (choose & CZC_NOPOSTFIX) {
|
|
|
// Always drop a postfix.
|
|
|
postfix += lengthof(name_czech_subst_postfix);
|
|
|
}
|
|
|
if (postfix < lengthof(name_czech_subst_postfix))
|
|
|
if (postfix < lengthof(name_czech_subst_postfix)) {
|
|
|
choose |= CZC_POSTFIX;
|
|
|
else
|
|
|
} else {
|
|
|
choose |= CZC_NOPOSTFIX;
|
|
|
}
|
|
|
|
|
|
// Localize the array segment containing a good gender
|
|
|
for (ending = 0; ending < (int) lengthof(name_czech_subst_ending); ending++) {
|
|
|
const CzechNameSubst *e = &name_czech_subst_ending[ending];
|
|
|
|
|
|
if (gender == CZG_FREE ||
|