From c53aa275979ba74308854a592d9f275d356cacc6 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sat, 23 May 2020 10:18:18 +0200 Subject: [PATCH] bug 2661: desertierende einheiten, spoils MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Kampfstatus und Tarnung setzen. Spoils-Texte für mehr Rassen. --- res/translations/strings.de.po | 43 +++++++++++++++++++++++++++++++++- src/chaos.c | 8 +++---- src/economy.c | 8 +++---- src/monsters.c | 43 ++++++++++++++++++++++++---------- src/monsters.h | 1 + 5 files changed, 82 insertions(+), 21 deletions(-) diff --git a/res/translations/strings.de.po b/res/translations/strings.de.po index 0e9776a40..ba16c31e9 100644 --- a/res/translations/strings.de.po +++ b/res/translations/strings.de.po @@ -3890,7 +3890,7 @@ msgstr "Ent" msgctxt "iteminfo" msgid "dwarfspoil" -msgstr "Beim Barte des Proheten! Ach nein, Zwergen. Irgendetwas riecht hier ranzig." +msgstr "Beim Barte des Propheten! Ach nein, Zwergen. Irgendetwas riecht hier ranzig." msgctxt "race" msgid "clone" @@ -6320,3 +6320,44 @@ msgctxt "race" msgid "wolf" msgstr "Wolf" +msgctxt "iteminfo" +msgid "elfspoil" +msgstr "Die Ohren sind spitz und beinahe trapezförmig. Wie kann +damit hören?" + +msgctxt "iteminfo" +msgid "goblinspoil" +msgstr "Die Fratze des kleinen Kopfs wirkt beinahe etwas kindlich +zierlich, aber dennoch liegt etwas Listiges darin." + +msgctxt "iteminfo" +msgid "halflingspoil" +msgstr "Die Sohle des behaarten Fußes ist deutlich dicker, beinahe +wie ein Huf." + +msgctxt "iteminfo" +msgid "aquarianspoil" +msgstr "Die kleine, türkisfarbene Schuppe glänzt in der Sonne. Dennoch ist sie erstaunlich hart." + +msgctxt "iteminfo" +msgid "humanspoil" +msgstr "Ob blond oder braun, ob kurz oder lang, du hast ein Büschel Haare mit einem Stück Haut in der Hand." + +msgctxt "iteminfo" +msgid "catspoil" +msgstr "Wie ein kleines Seil aus weichem Fell." + +msgctxt "iteminfo" +msgid "insectspoil" +msgstr "Das am Kopf der meisten Gliederfüßer auftretende, +gegliederte Extremitätenpaar, das mit Sensillen (Tastsinn, Geruchssinn) +ausgestattet ist." + +msgctxt "iteminfo" +msgid "orcspoil" +msgstr "Große, spitze Zähne. Ob sie früher einem Ork oder doch einem Wildschwein gehörten ist nicht so leicht zu unterscheiden." + +msgctxt "iteminfo" +msgid "demonspoil" +msgstr "Eine giftige und grüne Flüssigkeit in einer kleinen Phiole, +keine humanoide Rasse außer Dämonen wagt damit in Kontakt zu kommen." diff --git a/src/chaos.c b/src/chaos.c index 2639592f0..8b474cb24 100644 --- a/src/chaos.c +++ b/src/chaos.c @@ -84,10 +84,10 @@ static void chaos(region * r) if (!(r->terrain->flags & SEA_REGION)) { unit *u = random_unit(r); if (u && playerrace(u_race(u))) { - ADDMSG(&u->faction->msgs, msg_message("chaos_disease", "unit", u)); - u_setfaction(u, get_monsters()); - u_freeorders(u); - u_setrace(u, get_race(RC_GHOUL)); + if (join_monsters(u)) { + ADDMSG(&u->faction->msgs, msg_message("chaos_disease", "unit", u)); + u_setrace(u, get_race(RC_GHOUL)); + } } } break; diff --git a/src/economy.c b/src/economy.c index 482b8d959..a16e9718d 100644 --- a/src/economy.c +++ b/src/economy.c @@ -290,10 +290,10 @@ static int forget_cmd(unit * u, order * ord) else { unit *ufam = get_familiar(u); if (ufam) { - a_removeall(&ufam->attribs, NULL); - u_setfaction(ufam, get_monsters()); - u_freeorders(ufam); - unit_convert_race(ufam, NULL, "ghost"); + if (join_monsters(ufam)) { + a_removeall(&ufam->attribs, NULL); + unit_convert_race(ufam, NULL, "ghost"); + } } a_removeall(&u->attribs, &at_mage); a_removeall(&u->attribs, &at_familiar); diff --git a/src/monsters.c b/src/monsters.c index cd6efc558..c10ad97e9 100644 --- a/src/monsters.c +++ b/src/monsters.c @@ -43,9 +43,10 @@ #include /* attributes includes */ -#include -#include #include +#include +#include +#include #include @@ -179,6 +180,23 @@ static order *monster_attack(unit * u, const unit * target) return create_order(K_ATTACK, u->faction->locale, "%i", target->no); } +bool join_monsters(unit *u) { + static faction *monsters = NULL; + if (monsters == NULL) { + monsters = get_monsters(); + if (monsters == NULL) { + return false; + } + } + u_setfaction(u, monsters); + u->status = ST_FIGHT; + a_removeall(&u->attribs, &at_otherfaction); + u->flags &= ~UFL_ANON_FACTION; + u_seteffstealth(u, -1); + u_freeorders(u); + return true; +} + void monsters_desert(struct faction *monsters) { region *r; @@ -193,10 +211,10 @@ void monsters_desert(struct faction *monsters) if (fval(u, UFL_ISNEW)) continue; if (rng_int() % 100 < 5) { - ADDMSG(&u->faction->msgs, msg_message("desertion", - "unit region", u, r)); - u_setfaction(u, monsters); - u_freeorders(u); + if (join_monsters(u)) { + ADDMSG(&u->faction->msgs, msg_message("desertion", + "unit region", u, r)); + } } } } @@ -1175,10 +1193,11 @@ void monster_kills_peasants(unit * u) void make_zombie(unit * u) { - u_setfaction(u, get_monsters()); - u_freeorders(u); - scale_number(u, 1); - u->hp = unit_max_hp(u) * u->number; - u_setrace(u, get_race(RC_ZOMBIE)); - u->irace = NULL; + if (join_monsters(u)) { + u_freeorders(u); + scale_number(u, 1); + u->hp = unit_max_hp(u) * u->number; + u_setrace(u, get_race(RC_ZOMBIE)); + u->irace = NULL; + } } diff --git a/src/monsters.h b/src/monsters.h index e799c68c4..9b2dd2720 100644 --- a/src/monsters.h +++ b/src/monsters.h @@ -23,6 +23,7 @@ extern "C" { void spawn_undead(void); void plan_monsters(struct faction *f); + bool join_monsters(struct unit *u); #ifdef __cplusplus }