forked from github/server
in_safe_building needs a test and some changes to logic
github issue #393 fixed
This commit is contained in:
parent
e5a5f05410
commit
7fb5adc7af
4 changed files with 38 additions and 14 deletions
|
@ -662,3 +662,18 @@ void building_setregion(building * b, region * r)
|
|||
|
||||
b->region = r;
|
||||
}
|
||||
|
||||
bool in_safe_building(unit *u1, unit *u2) {
|
||||
if (u1->building) {
|
||||
building * b = inside_building(u1);
|
||||
if (b->type->flags & BTF_FORTIFICATION) {
|
||||
if (!u2->building) {
|
||||
return true;
|
||||
}
|
||||
if (u2->building != b || b != inside_building(u2)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
|
|
@ -89,6 +89,7 @@ extern "C" {
|
|||
int bt_effsize(const struct building_type *btype,
|
||||
const struct building *b, int bsize);
|
||||
|
||||
bool in_safe_building(struct unit *u1, struct unit *u2);
|
||||
/* buildingt => building_type
|
||||
* Name => locale_string(name)
|
||||
* MaxGroesse => levels
|
||||
|
|
|
@ -386,7 +386,7 @@ static void test_active_building(CuTest *tc) {
|
|||
building *b;
|
||||
|
||||
test_cleanup();
|
||||
b = test_create_building(test_create_region(0,0,0), 0);
|
||||
b = test_create_building(test_create_region(0, 0, 0), 0);
|
||||
CuAssertIntEquals(tc, false, building_is_active(b));
|
||||
b->flags |= BLD_WORKING;
|
||||
CuAssertIntEquals(tc, true, building_is_active(b));
|
||||
|
@ -395,6 +395,26 @@ static void test_active_building(CuTest *tc) {
|
|||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_safe_building(CuTest *tc) {
|
||||
building_type *btype;
|
||||
unit *u1, *u2;
|
||||
|
||||
test_cleanup();
|
||||
btype = test_create_buildingtype("castle");
|
||||
u1 = test_create_unit(test_create_faction(0), test_create_region(0, 0, 0));
|
||||
u2 = test_create_unit(test_create_faction(0), test_create_region(0, 0, 0));
|
||||
CuAssertIntEquals(tc, false, in_safe_building(u1, u2));
|
||||
u1->building = test_create_building(u1->region, btype);
|
||||
CuAssertIntEquals(tc, false, in_safe_building(u1, u2));
|
||||
btype->flags |= BTF_FORTIFICATION;
|
||||
CuAssertIntEquals(tc, true, in_safe_building(u1, u2));
|
||||
u2->building = u1->building;
|
||||
CuAssertIntEquals(tc, true, in_safe_building(u1, u2));
|
||||
u1->building->size = 2;
|
||||
CuAssertIntEquals(tc, false, in_safe_building(u1, u2));
|
||||
test_cleanup();
|
||||
}
|
||||
|
||||
CuSuite *get_building_suite(void)
|
||||
{
|
||||
CuSuite *suite = CuSuiteNew();
|
||||
|
@ -410,5 +430,6 @@ CuSuite *get_building_suite(void)
|
|||
SUITE_ADD_TEST(suite, test_buildingowner_goes_to_same_faction_after_leave);
|
||||
SUITE_ADD_TEST(suite, test_buildingowner_goes_to_empty_unit_after_leave);
|
||||
SUITE_ADD_TEST(suite, test_active_building);
|
||||
SUITE_ADD_TEST(suite, test_safe_building);
|
||||
return suite;
|
||||
}
|
||||
|
|
|
@ -157,19 +157,6 @@ static order *monster_attack(unit * u, const unit * target)
|
|||
return create_order(K_ATTACK, u->faction->locale, "%i", target->no);
|
||||
}
|
||||
|
||||
static bool in_safe_building(unit *u1, unit *u2) {
|
||||
if (u1->building && u2->building == u1->building) {
|
||||
building * b = inside_building(u1);
|
||||
if (u2->building) {
|
||||
if (b != inside_building(u2)) return true;
|
||||
}
|
||||
if (b->type->flags & BTF_FORTIFICATION) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
||||
static order *get_money_for_dragon(region * r, unit * u, int wanted)
|
||||
{
|
||||
int n;
|
||||
|
|
Loading…
Reference in a new issue