forked from github/server
Unicode QA:
- irritating comma in HELP status- - localized roads in NR - new function for trails - lua fix get_resource(horse)
This commit is contained in:
parent
9d8edd01bf
commit
c3283925b6
8 changed files with 86 additions and 23 deletions
|
@ -1331,7 +1331,6 @@ show_allies(FILE * F, const faction * f, const ally * allies, char * buf, size_t
|
||||||
break;
|
break;
|
||||||
case HELP_MONEY:
|
case HELP_MONEY:
|
||||||
p = P_MONEY;
|
p = P_MONEY;
|
||||||
hh = 1;
|
|
||||||
break;
|
break;
|
||||||
case HELP_FIGHT:
|
case HELP_FIGHT:
|
||||||
p = P_FIGHT;
|
p = P_FIGHT;
|
||||||
|
|
|
@ -427,25 +427,25 @@ b_nameroad(const border * b, const region * r, const struct faction * f, int gfl
|
||||||
|
|
||||||
unused(f);
|
unused(f);
|
||||||
if (gflags & GF_ARTICLE) {
|
if (gflags & GF_ARTICLE) {
|
||||||
if (!(gflags & GF_DETAILED)) strcpy(buffer, "eine Straße");
|
if (!(gflags & GF_DETAILED)) return LOC(f->locale, "nr_a_road");
|
||||||
else if (r->terrain->max_road<=local) {
|
else if (r->terrain->max_road<=local) {
|
||||||
int remote = (r2==b->from)?b->data.sa[0]:b->data.sa[1];
|
int remote = (r2==b->from)?b->data.sa[0]:b->data.sa[1];
|
||||||
if (r2->terrain->max_road<=remote) {
|
if (r2->terrain->max_road<=remote) {
|
||||||
strcpy(buffer, "eine Straße");
|
return LOC(f->locale, "nr_a_road");
|
||||||
} else {
|
} else {
|
||||||
strcpy(buffer, "eine unvollständige Straße");
|
return LOC(f->locale, "nr_an_incomplete_road");
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
int percent = max(1, 100*local/r->terrain->max_road);
|
int percent = max(1, 100*local/r->terrain->max_road);
|
||||||
if (local) {
|
if (local) {
|
||||||
sprintf(buffer, "eine zu %d%% vollendete Straße", percent);
|
sprintf(buffer, LOC(f->locale, "nr_road_percent"), percent);
|
||||||
} else {
|
} else {
|
||||||
strcpy(buffer, "ein Straßenanschluß");
|
return LOC(f->locale, "nr_a_road_connection");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if (gflags & GF_PLURAL) return "Straßen";
|
else if (gflags & GF_PLURAL) return LOC(f->locale, "nr_roads");
|
||||||
else return "Straße";
|
else return LOC(f->locale, "nr_road");
|
||||||
return buffer;
|
return buffer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1504,7 +1504,7 @@ travel_route(unit * u, region_list * route_begin, region_list * route_end, order
|
||||||
|
|
||||||
if (mode!=TRAVEL_TRANSPORTED) {
|
if (mode!=TRAVEL_TRANSPORTED) {
|
||||||
ADDMSG(&u->faction->msgs, msg_message("travel",
|
ADDMSG(&u->faction->msgs, msg_message("travel",
|
||||||
"unit mode start end regions", u, walkmode, r, current, route_begin));
|
"unit mode start end regions", u, walkmode, r, current, route_begin->next?route_begin:NULL));
|
||||||
}
|
}
|
||||||
|
|
||||||
mark_travelthru(u, r, route_begin, iroute);
|
mark_travelthru(u, r, route_begin, iroute);
|
||||||
|
|
|
@ -1616,7 +1616,7 @@ eval_localize(struct opstack ** stack, const void * userdata) /* (string, locale
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
eval_trail(struct opstack ** stack, const void * userdata) /* (int, int) -> int */
|
eval_trailto(struct opstack ** stack, const void * userdata) /* (int, int) -> int */
|
||||||
{
|
{
|
||||||
const struct faction * f = (const struct faction *)userdata;
|
const struct faction * f = (const struct faction *)userdata;
|
||||||
const struct locale * lang = f?f->locale:default_locale;
|
const struct locale * lang = f?f->locale:default_locale;
|
||||||
|
@ -1930,6 +1930,36 @@ eval_regions(struct opstack ** stack, const void * userdata) /* order -> string
|
||||||
opush(stack, var);
|
opush(stack, var);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
eval_trail(struct opstack ** stack, const void * userdata) /* order -> string */
|
||||||
|
{
|
||||||
|
const faction * report = (const faction*)userdata;
|
||||||
|
int i, end = 0, begin = 0;
|
||||||
|
const arg_regions * regions = (const arg_regions *)opop(stack).v;
|
||||||
|
static char buf[256];
|
||||||
|
variant var;
|
||||||
|
char * edit = buf;
|
||||||
|
|
||||||
|
if (regions!=NULL) {
|
||||||
|
end = regions->nregions-1;
|
||||||
|
for (i=begin;i<end;++i) {
|
||||||
|
region * r = regions->regions[i];
|
||||||
|
const char * trail = trailinto(r, report->locale);
|
||||||
|
const char * rn = f_regionid_s(r, report);
|
||||||
|
|
||||||
|
edit += snprintf(edit, sizeof(buf)-(edit-buf), trail, rn);
|
||||||
|
if (i+2<end) {
|
||||||
|
edit += strlcpy(edit, ", ", sizeof(buf)-(edit-buf));
|
||||||
|
} else if (i+1<end) {
|
||||||
|
edit += strlcpy(edit, LOC(report->locale, "list_and"), sizeof(buf)-(edit-buf));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
buf[sizeof(buf)-1] = 0;
|
||||||
|
var.v = strcpy(balloc(edit-buf+1), buf);
|
||||||
|
opush(stack, var);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
eval_direction(struct opstack ** stack, const void * userdata)
|
eval_direction(struct opstack ** stack, const void * userdata)
|
||||||
{
|
{
|
||||||
|
@ -2012,12 +2042,13 @@ reports_init(void)
|
||||||
add_function("order", &eval_order);
|
add_function("order", &eval_order);
|
||||||
add_function("direction", &eval_direction);
|
add_function("direction", &eval_direction);
|
||||||
add_function("int36", &eval_int36);
|
add_function("int36", &eval_int36);
|
||||||
add_function("trail", &eval_trail);
|
add_function("trailto", &eval_trailto);
|
||||||
add_function("localize", &eval_localize);
|
add_function("localize", &eval_localize);
|
||||||
add_function("spell", &eval_spell);
|
add_function("spell", &eval_spell);
|
||||||
add_function("curse", &eval_curse);
|
add_function("curse", &eval_curse);
|
||||||
add_function("resources", &eval_resources);
|
add_function("resources", &eval_resources);
|
||||||
add_function("regions", &eval_regions);
|
add_function("regions", &eval_regions);
|
||||||
|
add_function("trail", &eval_trail);
|
||||||
|
|
||||||
/* register alternative visibility functions */
|
/* register alternative visibility functions */
|
||||||
register_function((pf_generic)view_neighbours, "view_neighbours");
|
register_function((pf_generic)view_neighbours, "view_neighbours");
|
||||||
|
|
|
@ -1341,9 +1341,10 @@ create_unit(region * r, faction * f, int number, const struct race *urace, int i
|
||||||
/* erbt Gebäude/Schiff*/
|
/* erbt Gebäude/Schiff*/
|
||||||
if (creator->region==r) {
|
if (creator->region==r) {
|
||||||
u->building = creator->building;
|
u->building = creator->building;
|
||||||
assert(creator->ship==NULL || fval(u->race, RCF_CANSAIL));
|
if (creator->ship!=NULL && fval(u->race, RCF_CANSAIL)) {
|
||||||
u->ship = creator->ship;
|
u->ship = creator->ship;
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/* Tarnlimit wird vererbt */
|
/* Tarnlimit wird vererbt */
|
||||||
if (fval(creator, UFL_STEALTH)) {
|
if (fval(creator, UFL_STEALTH)) {
|
||||||
|
|
|
@ -148,6 +148,7 @@ region_getresource(const region& r, const char * type)
|
||||||
const resource_type * rtype = rt_find(type);
|
const resource_type * rtype = rt_find(type);
|
||||||
if (rtype!=NULL) {
|
if (rtype!=NULL) {
|
||||||
if (rtype==rt_find("money")) return rmoney(&r);
|
if (rtype==rt_find("money")) return rmoney(&r);
|
||||||
|
if (rtype==rt_find("horse")) return rhorses(&r);
|
||||||
if (rtype==rt_find("peasant")) return rpeasants(&r);
|
if (rtype==rt_find("peasant")) return rpeasants(&r);
|
||||||
} else {
|
} else {
|
||||||
if (strcmp(type, "seed")==0) return rtrees(&r, 0);
|
if (strcmp(type, "seed")==0) return rtrees(&r, 0);
|
||||||
|
@ -165,7 +166,8 @@ region_setresource(region& r, const char * type, int value)
|
||||||
const resource_type * rtype = rt_find(type);
|
const resource_type * rtype = rt_find(type);
|
||||||
if (rtype!=NULL) {
|
if (rtype!=NULL) {
|
||||||
if (rtype==rt_find("money")) rsetmoney(&r, value);
|
if (rtype==rt_find("money")) rsetmoney(&r, value);
|
||||||
if (rtype==rt_find("peasant")) return rsetpeasants(&r, value);
|
else if (rtype==rt_find("peasant")) rsetpeasants(&r, value);
|
||||||
|
else if (rtype==rt_find("horse")) rsethorses(&r, value);
|
||||||
} else {
|
} else {
|
||||||
if (strcmp(type, "seed")==0) {
|
if (strcmp(type, "seed")==0) {
|
||||||
rsettrees(&r, 0, value);
|
rsettrees(&r, 0, value);
|
||||||
|
|
|
@ -7432,4 +7432,34 @@
|
||||||
<text locale="en">Owner</text>
|
<text locale="en">Owner</text>
|
||||||
</string>
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_a_road">
|
||||||
|
<text locale="de">eine Straße</text>
|
||||||
|
<text locale="en">a road</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_roads">
|
||||||
|
<text locale="de">Straßen</text>
|
||||||
|
<text locale="en">roads</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_road">
|
||||||
|
<text locale="de">Straße</text>
|
||||||
|
<text locale="en">road</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_road_percent">
|
||||||
|
<text locale="de">eine zu %d%% vollendete Straße</text>
|
||||||
|
<text locale="en">a road that is %d%% complete</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_a_road_connection">
|
||||||
|
<text locale="de">ein Straßenanschluß</text>
|
||||||
|
<text locale="en">a connection to another road</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
|
<string name="nr_an_incomplete_road">
|
||||||
|
<text locale="de">eine unvollständige Straße</text>
|
||||||
|
<text locale="en">an incomplete road</text>
|
||||||
|
</string>
|
||||||
|
|
||||||
</strings>
|
</strings>
|
||||||
|
|
|
@ -714,8 +714,8 @@
|
||||||
<type>
|
<type>
|
||||||
<arg name="region" type="region"/>
|
<arg name="region" type="region"/>
|
||||||
</type>
|
</type>
|
||||||
<text locale="de">$trail($region)</text>
|
<text locale="de">$trailto($region)</text>
|
||||||
<text locale="en">$trail($region)</text>
|
<text locale="en">$trailto($region)</text>
|
||||||
</message>
|
</message>
|
||||||
<message name="nr_migrants" section="nr">
|
<message name="nr_migrants" section="nr">
|
||||||
<type>
|
<type>
|
||||||
|
@ -813,8 +813,8 @@
|
||||||
<arg name="dir" type="int"/>
|
<arg name="dir" type="int"/>
|
||||||
<arg name="region" type="region"/>
|
<arg name="region" type="region"/>
|
||||||
</type>
|
</type>
|
||||||
<text locale="de">"Im $direction($dir) der Region liegt $trail($region)"</text>
|
<text locale="de">"Im $direction($dir) der Region liegt $trailto($region)"</text>
|
||||||
<text locale="en">"To the $direction($dir) lies $trail($region)"</text>
|
<text locale="en">"To the $direction($dir) lies $trailto($region)"</text>
|
||||||
</message>
|
</message>
|
||||||
<message name="nr_market_price" section="nr">
|
<message name="nr_market_price" section="nr">
|
||||||
<type>
|
<type>
|
||||||
|
@ -2819,9 +2819,9 @@
|
||||||
<arg name="end" type="region"/>
|
<arg name="end" type="region"/>
|
||||||
<arg name="regions" type="regions"/>
|
<arg name="regions" type="regions"/>
|
||||||
</type>
|
</type>
|
||||||
<text locale="de">"$unit($unit) $if($eq($mode,1),"reitet", "wandert") von $region($start) nach $region($end).$if($isnull($regions),""," Dabei wurde $regions($regions,1,-2) durchquert.")"</text>
|
<text locale="de">"$unit($unit) $if($eq($mode,1),"reitet", "wandert") von $region($start) nach $region($end).$if($isnull($regions),""," Dabei wurde $trail($regions) durchquert.")"</text>
|
||||||
<text locale="fr">"$unit($unit) $if($eq($mode,1),"chevauche", "marche") de $region($start) vers $region($end) trans $regions($regions,1,-2)"</text>
|
<text locale="fr">"$unit($unit) $if($eq($mode,1),"chevauche", "marche") de $region($start) vers $region($end) trans $trail($regions)"</text>
|
||||||
<text locale="en">"$unit($unit) $if($eq($mode,1),"rides", "walks") from $region($start) to $region($end)$if($isnull($regions),""," by way of $regions($regions,1,-2)")."</text>
|
<text locale="en">"$unit($unit) $if($eq($mode,1),"rides", "walks") from $region($start) to $region($end)$if($isnull($regions),""," by way of $trail($regions)")."</text>
|
||||||
</message>
|
</message>
|
||||||
<message name="detectoceandir" section="movement">
|
<message name="detectoceandir" section="movement">
|
||||||
<type>
|
<type>
|
||||||
|
@ -7476,7 +7476,7 @@
|
||||||
<arg name="mage" type="unit"/>
|
<arg name="mage" type="unit"/>
|
||||||
<arg name="building" type="building"/>
|
<arg name="building" type="building"/>
|
||||||
</type>
|
</type>
|
||||||
<text locale="de">"Mit einem Ritual bindet $unit($unit) die magischen Kräfte der Erde in die Mauern von $building($building)."</text>
|
<text locale="de">"Mit einem Ritual bindet $unit($mage) die magischen Kräfte der Erde in die Mauern von $building($building)."</text>
|
||||||
</message>
|
</message>
|
||||||
|
|
||||||
<message name="blessedstonecircle_effect" section="magic">
|
<message name="blessedstonecircle_effect" section="magic">
|
||||||
|
|
Loading…
Reference in a new issue