Unicode WIP:

- sinking ships i18n
This commit is contained in:
Enno Rehling 2007-07-23 19:36:43 +00:00
parent e63c3dc4a1
commit 376172adcd
2 changed files with 154 additions and 65 deletions

View file

@ -184,11 +184,12 @@ spy_message(int spy, const unit *u, const unit *target)
/* spion ist gleich gut wie Wahrnehmung Opfer */ /* spion ist gleich gut wie Wahrnehmung Opfer */
/* spion ist schlechter als Wahrnehmung Opfer */ /* spion ist schlechter als Wahrnehmung Opfer */
{ /* immer */ { /* immer */
const xmlChar * str;
scat("Kampfstatus: "); scat("Kampfstatus: ");
scat(report_kampfstatus(target, u->faction->locale)); scat(report_kampfstatus(target, u->faction->locale));
c = locale_string(u->faction->locale, hp_status(target)); str = locale_string(u->faction->locale, hp_status(target));
if (c && strlen(c)) if (str && str[0])
sprintf(buf, "%s (%s)", buf, c); sprintf(buf, "%s (%s)", buf, str);
scat("."); scat(".");
} }
@ -297,7 +298,7 @@ setwere_cmd(unit *u, struct order * ord)
int int
setstealth_cmd(unit * u, struct order * ord) setstealth_cmd(unit * u, struct order * ord)
{ {
const char *s; const xmlChar *s;
char level; char level;
const race * trace; const race * trace;
@ -359,11 +360,11 @@ setstealth_cmd(unit * u, struct order * ord)
} else if (findparam(s, u->faction->locale) == P_NOT) { } else if (findparam(s, u->faction->locale) == P_NOT) {
freset(u, UFL_PARTEITARNUNG); freset(u, UFL_PARTEITARNUNG);
} else if (findkeyword(s, u->faction->locale) == K_NUMBER) { } else if (findkeyword(s, u->faction->locale) == K_NUMBER) {
const char *s2 = getstrtoken(); const xmlChar *s2 = getstrtoken();
int nr = -1; int nr = -1;
if(s2) nr = atoi36(s2); if (s2) nr = atoi36(s2);
if(!s2 || *s2 == 0 || nr == u->faction->no) { if (!s2 || *s2 == 0 || nr == u->faction->no) {
a_removeall(&u->attribs, &at_otherfaction); a_removeall(&u->attribs, &at_otherfaction);
} else { } else {
struct faction * f = findfaction(nr); struct faction * f = findfaction(nr);
@ -450,8 +451,7 @@ setstealth_cmd(unit * u, struct order * ord)
/* Tarnungslevel setzen */ /* Tarnungslevel setzen */
level = (char) atoip(s); level = (char) atoip(s);
if (level > effskill(u, SK_STEALTH)) { if (level > effskill(u, SK_STEALTH)) {
sprintf(buf, "%s kann sich nicht so gut tarnen.", unitname(u)); ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "error_lowstealth", ""));
mistake(u, ord, buf, MSG_EVENT);
return 0; return 0;
} }
u_seteffstealth(u, level); u_seteffstealth(u, level);
@ -493,42 +493,36 @@ crew_skill(region * r, faction * f, ship * sh, skill_t sk)
} }
static int static int
try_destruction(unit * u, unit * u2, const char *name, int skilldiff) try_destruction(unit * u, unit * u2, const ship *sh, int skilldiff)
{ {
const char *destruction_success_msg = "%s wurde von %s zerstoert."; const char *destruction_success_msg = "destroy_ship_0";
const char *destruction_failed_msg = "%s konnte %s nicht zerstoeren."; const char *destruction_failed_msg = "destroy_ship_1";
const char *destruction_detected_msg = "%s wurde beim Versuch, %s zu zerstoeren, entdeckt."; const char *destruction_detected_msg = "destroy_ship_2";
const char *detect_failure_msg = "Es wurde versucht, %s zu zerstoeren."; const char *detect_failure_msg = "destroy_ship_3";
const char *object_destroyed_msg = "%s wurde zerstoert."; const char *object_destroyed_msg = "destroy_ship_4";
if (skilldiff == 0) { if (skilldiff == 0) {
/* tell the unit that the attempt failed: */ /* tell the unit that the attempt failed: */
sprintf(buf, destruction_failed_msg, unitname(u), name); ADDMSG(&u->faction->msgs, msg_message(destruction_failed_msg, "ship unit", sh, u));
addmessage(0, u->faction, buf, MSG_EVENT, ML_WARN);
/* tell the enemy about the attempt: */ /* tell the enemy about the attempt: */
if (u2) { if (u2) {
sprintf(buf, detect_failure_msg, name); ADDMSG(&u2->faction->msgs, msg_message(detect_failure_msg, "ship", sh));
addmessage(0, u2->faction, buf, MSG_EVENT, ML_IMPORTANT);
} }
return 0; return 0;
} } else if (skilldiff < 0) {
if (skilldiff < 0) {
/* tell the unit that the attempt was detected: */ /* tell the unit that the attempt was detected: */
sprintf(buf, destruction_detected_msg, unitname(u), name); ADDMSG(&u2->faction->msgs, msg_message(destruction_detected_msg, "ship unit", sh, u));
addmessage(0, u->faction, buf, MSG_EVENT, ML_WARN);
/* tell the enemy whodunit: */ /* tell the enemy whodunit: */
if (u2) { if (u2) {
sprintf(buf, detect_failure_msg, unitname(u2), unitname(u), name); ADDMSG(&u2->faction->msgs, msg_message(detect_failure_msg, "ship unit", sh, u));
addmessage(0, u2->faction, buf, MSG_EVENT, ML_IMPORTANT);
} }
return 0; return 0;
} } else {
/* tell the unit that the attempt succeeded */ /* tell the unit that the attempt succeeded */
sprintf(buf, destruction_success_msg, name, unitname(u)); ADDMSG(&u->faction->msgs, msg_message(destruction_success_msg, "ship unit", sh, u));
addmessage(0, u->faction, buf, MSG_EVENT, ML_INFO);
if (u2) { if (u2) {
sprintf(buf, object_destroyed_msg, name); ADDMSG(&u2->faction->msgs, msg_message(object_destroyed_msg, "ship", sh));
addmessage(0, u2->faction, buf, MSG_EVENT, ML_IMPORTANT); }
} }
return 1; /* success */ return 1; /* success */
} }
@ -536,23 +530,16 @@ try_destruction(unit * u, unit * u2, const char *name, int skilldiff)
static void static void
sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur) sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur)
{ {
const char *person_lost_msg = "- %d Person von %s ertrinkt; %s.";
const char *persons_lost_msg = "- %d Personen von %s ertrinken; %s.";
const char *unit_dies_msg = "Die Einheit wird ausgeloescht";
const char *unit_lives_msg = "Die Einheit rettet sich nach ";
const char *unit_intact_msg = "%s ueberlebt unbeschadet und rettet sich nach %s.";
const char *ship_sinks_msg = "%s versinkt im Ozean.";
const char *enemy_discovers_spy_msg = "%s wurde beim versenken von %s entdeckt.";
const char *spy_discovered_msg = "%s entdeckte %s beim versenken von %s.";
unit **ui; unit **ui;
region *safety = r; region *safety = r;
int i; int i;
direction_t d; direction_t d;
unsigned int index; unsigned int index;
double probability = 0.0; double probability = 0.0;
char buffer[DISPLAYSIZE + 1];
vset informed; vset informed;
vset survivors; vset survivors;
message * sink_msg = NULL;
message * enemy_discovers_spy_msg = NULL;
vset_init(&informed); vset_init(&informed);
vset_init(&survivors); vset_init(&survivors);
@ -577,6 +564,7 @@ sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur)
vset_add(&informed, u->faction); vset_add(&informed, u->faction);
if (u->ship == sh) { if (u->ship == sh) {
int dead = 0; int dead = 0;
message * msg;
/* if this fails, I misunderstood something: */ /* if this fails, I misunderstood something: */
for (i = 0; i != u->number; ++i) for (i = 0; i != u->number; ++i)
@ -588,22 +576,24 @@ sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur)
{ {
vset_add(&survivors, u); vset_add(&survivors, u);
if (dead > 0) { if (dead > 0) {
strcat(strcpy(buffer, unit_lives_msg), regionname(safety, u->faction)); msg = msg_message("sink_lost_msg", "dead region unit", dead, safety, u);
sprintf(buf, (dead == 1) ? person_lost_msg : persons_lost_msg, } else {
dead, unitname(u), buffer); msg = msg_message("sink_saved_msg", "region unit", safety, u);
} else }
sprintf(buf, unit_intact_msg, unitname(u), regionname(safety, u->faction));
addmessage(0, u->faction, buf, MSG_EVENT, ML_WARN);
set_leftship(u, u->ship); set_leftship(u, u->ship);
u->ship = 0; u->ship = 0;
if (r != safety) if (r != safety) {
setguard(u, GUARD_NONE); setguard(u, GUARD_NONE);
while (u->items) i_remove(&u->items, u->items); }
while (u->items) {
i_remove(&u->items, u->items);
}
move_unit(u, safety, NULL); move_unit(u, safety, NULL);
} else { } else {
sprintf(buf, (dead == 1) ? person_lost_msg : persons_lost_msg, msg = msg_message("sink_lost_msg", "dead region unit", dead, NULL, u);
dead, unitname(u), unit_dies_msg);
} }
add_message(&u->faction->msgs, msg);
msg_release(msg);
if (dead == u->number) { if (dead == u->number) {
/* the poor creature, she dies */ /* the poor creature, she dies */
*ui = u->next; *ui = u->next;
@ -644,18 +634,22 @@ sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur)
} }
} }
/* finally, report to this faction that the ship sank: */ /* finally, report to this faction that the ship sank: */
sprintf(buf, ship_sinks_msg, name); if (sink_msg==NULL) {
addmessage(0, f, buf, MSG_EVENT, ML_WARN); sink_msg = msg_message("sink_msg", "ship region", sh, r);
}
add_message(&f->msgs, sink_msg);
vset_erase(&informed, f); vset_erase(&informed, f);
if (spy == 1 && f != saboteur->faction && if (spy == 1 && f != saboteur->faction && faction_skill(r, f, SK_OBSERVATION) - eff_skill(saboteur, SK_STEALTH, r) > 0) {
faction_skill(r, f, SK_OBSERVATION) - eff_skill(saboteur, SK_STEALTH, r) > 0) {
/* the unit is discovered */ /* the unit is discovered */
sprintf(buf, spy_discovered_msg, lastunit, unitname(saboteur), name); ADDMSG(&f->msgs, msg_message("spy_discovered_msg", "unit saboteur ship", lastunit, saboteur, sh));
addmessage(0, f, buf, MSG_EVENT, ML_IMPORTANT); if (enemy_discovers_spy_msg==NULL) {
sprintf(buf, enemy_discovers_spy_msg, unitname(saboteur), name); enemy_discovers_spy_msg = msg_message("enemy_discovers_spy_msg", "unit ship", saboteur, sh);
addmessage(0, saboteur->faction, buf, MSG_EVENT, ML_MISTAKE); }
add_message(&saboteur->faction->msgs, sink_msg);
} }
} }
if (enemy_discovers_spy_msg) msg_release(enemy_discovers_spy_msg);
if (sink_msg) msg_release(sink_msg);
/* finally, get rid of the ship */ /* finally, get rid of the ship */
destroy_ship(sh); destroy_ship(sh);
vset_destroy(&informed); vset_destroy(&informed);
@ -665,12 +659,13 @@ sink_ship(region * r, ship * sh, const char *name, char spy, unit * saboteur)
int int
sabotage_cmd(unit * u, struct order * ord) sabotage_cmd(unit * u, struct order * ord)
{ {
const char *s; const xmlChar *s;
int i; int i;
ship *sh; ship *sh;
unit *u2; unit *u2;
char buffer[DISPLAYSIZE]; char buffer[DISPLAYSIZE];
region * r = u->region; region * r = u->region;
int skdiff;
init_tokens(ord); init_tokens(ord);
skip_token(); skip_token();
@ -686,9 +681,8 @@ sabotage_cmd(unit * u, struct order * ord)
return 0; return 0;
} }
u2 = shipowner(sh); u2 = shipowner(sh);
strcat(strcpy(buffer, shipname(sh)), sh->type->name[0]); skdiff = eff_skill(u, SK_SPY, r)-crew_skill(r, u2->faction, sh, SK_OBSERVATION);
if (try_destruction(u, u2, buffer, eff_skill(u, SK_SPY, r) if (try_destruction(u, u2, sh, skdiff)) {
- crew_skill(r, u2->faction, sh, SK_OBSERVATION))) {
sink_ship(r, sh, buffer, 1, u); sink_ship(r, sh, buffer, 1, u);
} }
break; break;

View file

@ -1014,16 +1014,111 @@
<text locale="en">"$unit($unit) in $region($region): '$order($command)' - You cannot recruit in this plane."</text> <text locale="en">"$unit($unit) in $region($region): '$order($command)' - You cannot recruit in this plane."</text>
</message> </message>
<message name="error_lowstealth" section="errors">
<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)' - Die einheit kann sich nicht so gut tarnen."</text>
<text locale="en">"$unit($unit) in $region($region): '$order($command)' -The unit cannot hide that well."</text>
</message>
<message name="destroy_ship_0" section="events">
<type>
<arg name="unit" type="unit"/>
<arg name="ship" type="ship"/>
</type>
<text locale="en">"$ship($ship) was destroyed by $unit($unit)."</text>
<text locale="de">"$ship($ship) wurde von $unit($unit) zerstört."</text>
</message>
<message name="destroy_ship_1" section="events">
<type>
<arg name="unit" type="unit"/>
<arg name="ship" type="ship"/>
</type>
<text locale="en">"$unit($unit) could not destroy $ship($ship)."</text>
<text locale="de">"$unit($unit) konnte $ship($ship) nicht zerstören."</text>
</message>
<message name="destroy_ship_2" section="events">
<type>
<arg name="unit" type="unit"/>
<arg name="ship" type="ship"/>
</type>
<text locale="en">"$unit($unit) was detected while trying to destroy $ship($ship)."</text>
<text locale="de">"$unit($unit) wurde beim Versuch $ship($ship) zu zerstören entdeckt."</text>
</message>
<message name="destroy_ship_3" section="events">
<type>
<arg name="ship" type="ship"/>
</type>
<text locale="en">"Somebody attempted to destroy $ship($ship)."</text>
<text locale="de">"Es wurde versucht, $ship($ship) zu zerstören."</text>
</message>
<message name="destroy_ship_4" section="events">
<type>
<arg name="ship" type="ship"/>
</type>
<text locale="en">"$ship($ship) was destroyed."</text>
<text locale="de">"$ship($ship) wurde zerstört."</text>
</message>
<message name="sink_lost_msg" section="events">
<type>
<arg name="dead" type="int"/>
<arg name="region" type="region"/>
<arg name="unit" type="unit"/>
</type>
<text locale="de">"$int($amount) Personen von $unit($unit) ertrinken.$if($isnull($region),""," Die Einheit rettet sich nach $region($region).")"</text>
</message>
<message name="sink_saved_msg" section="events">
<type>
<arg name="region" type="region"/>
<arg name="unit" type="unit"/>
</type>
<text locale="de">"$unit($unit) ueberlebt unbeschadet und rettet sich nach $region($region)."</text>
</message>
<message name="sink_msg" section="events">
<type>
<arg name="ship" type="ship"/>
<arg name="region" type="region"/>
</type>
<text locale="de">"$ship($ship) versinkt in den Fluten von $region($region)."</text>
</message>
<message name="enemy_discovers_spy_msg" section="events">
<type>
<arg name="ship" type="ship"/>
<arg name="unit" type="unit"/>
</type>
<text locale="de">"$unit($unit) wurde beim versenken von $ship($ship) entdeckt."</text>
</message>
<message name="spy_discovered_msg" section="events">
<type>
<arg name="ship" type="ship"/>
<arg name="unit" type="unit"/>
<arg name="saboteur" type="unit"/>
</type>
<text locale="de">"$unit($unit) entdeckte $unit($saboteur) beim versenken von $ship($ship)."</text>
</message>
<message name="drown" section="events"> <message name="drown" section="events">
<type> <type>
<arg name="unit" type="unit"/> <arg name="unit" type="unit"/>
<arg name="region" type="region"/> <arg name="region" type="region"/>
</type> </type>
<text locale="de">"$unit($unit) ertrinkt in $region($region)."</text> <text locale="de">"$unit($unit) ertrinkt in $region($region)."</text>
<text locale="fr">"$unit($unit) drowns in in $region($region)."</text>
<text locale="en">"$unit($unit) drowns in in $region($region)."</text> <text locale="en">"$unit($unit) drowns in in $region($region)."</text>
</message> </message>
<message name="drown_amphibian_dead" section="events">
<message name="drown_amphibian_dead" section="events">
<type> <type>
<arg name="amount" type="int"/> <arg name="amount" type="int"/>
<arg name="unit" type="unit"/> <arg name="unit" type="unit"/>