From 183981f3c7952f9208d337d86c00315e048c6370 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sat, 4 Jul 2020 11:48:24 +0200 Subject: [PATCH] bug 2678: fix trade_needs_castle The logic for "insects do not need castles in deserts or swamps" was broken. --- src/economy.c | 5 ++++- src/economy.test.c | 13 +++++++++++-- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/src/economy.c b/src/economy.c index 4d2c30d90..f0e655b99 100644 --- a/src/economy.c +++ b/src/economy.c @@ -1175,11 +1175,14 @@ bool trade_needs_castle(const terrain_type *terrain, const race *rc) if (rc_changed(&rc_change)) { rc_insect = get_race(RC_INSECT); } + if (rc != rc_insect) { + return true; + } if (terrain_changed(&terrain_change)) { t_swamp = newterrain(T_SWAMP); t_desert = newterrain(T_DESERT); } - return rc != rc_insect && (terrain == t_swamp || terrain == t_desert); + return (terrain != t_swamp && terrain != t_desert); } static building * first_building(region *r, const struct building_type *btype, int minsize) { diff --git a/src/economy.test.c b/src/economy.test.c index 034a6cf44..4cda069d0 100644 --- a/src/economy.test.c +++ b/src/economy.test.c @@ -269,7 +269,7 @@ static void test_trade_needs_castle(CuTest *tc) { region *r; unit *u; building *b; - const terrain_type *t_swamp; + const terrain_type *t_swamp, *t_desert, *t_plain; const item_type *it_luxury; test_setup(); @@ -278,11 +278,15 @@ static void test_trade_needs_castle(CuTest *tc) { setup_terrains(tc); init_terrains(); t_swamp = get_terrain("swamp"); - r = setup_trade_region(tc, t_swamp); + t_desert = get_terrain("desert"); + t_plain = get_terrain("plain"); + r = setup_trade_region(tc, t_plain); it_luxury = r_luxury(r); rc = test_create_race(NULL); CuAssertTrue(tc, trade_needs_castle(t_swamp, rc)); + CuAssertTrue(tc, trade_needs_castle(t_desert, rc)); + CuAssertTrue(tc, trade_needs_castle(t_plain, rc)); u = test_create_unit(test_create_faction(rc), r); unit_addorder(u, create_order(K_BUY, u->faction->locale, "1 %s", @@ -305,6 +309,11 @@ static void test_trade_needs_castle(CuTest *tc) { test_clear_messages(u->faction); produce(r); CuAssertIntEquals(tc, 0, test_count_messagetype(u->faction->msgs, "error119")); + + rc = test_create_race("insect"); + CuAssertTrue(tc, !trade_needs_castle(t_swamp, rc)); + CuAssertTrue(tc, !trade_needs_castle(t_desert, rc)); + CuAssertTrue(tc, trade_needs_castle(t_plain, rc)); test_teardown(); }