forked from github/server
refactoring and tests for wormhole module.
This commit is contained in:
parent
139ff04108
commit
4527ffdda2
12 changed files with 119 additions and 46 deletions
|
@ -92,6 +92,7 @@ set (ERESSEA_SRC
|
||||||
study.c
|
study.c
|
||||||
summary.c
|
summary.c
|
||||||
monsters.c
|
monsters.c
|
||||||
|
wormhole.c
|
||||||
${SPELLS_SRC}
|
${SPELLS_SRC}
|
||||||
${RACES_SRC}
|
${RACES_SRC}
|
||||||
${ITEMS_SRC}
|
${ITEMS_SRC}
|
||||||
|
@ -153,6 +154,7 @@ target_link_libraries(eressea
|
||||||
)
|
)
|
||||||
|
|
||||||
set(TESTS_SRC
|
set(TESTS_SRC
|
||||||
|
wormhole.test.c
|
||||||
test_eressea.c
|
test_eressea.c
|
||||||
tests.c
|
tests.c
|
||||||
battle.test.c
|
battle.test.c
|
||||||
|
|
|
@ -16,7 +16,6 @@
|
||||||
#include <kernel/xmlreader.h>
|
#include <kernel/xmlreader.h>
|
||||||
#include <kernel/item.h>
|
#include <kernel/item.h>
|
||||||
#include <kernel/building.h>
|
#include <kernel/building.h>
|
||||||
#include <modules/wormhole.h>
|
|
||||||
#include <modules/gmcmd.h>
|
#include <modules/gmcmd.h>
|
||||||
#include <modules/xmas.h>
|
#include <modules/xmas.h>
|
||||||
#include <items/itemtypes.h>
|
#include <items/itemtypes.h>
|
||||||
|
@ -25,6 +24,7 @@
|
||||||
#include "items.h"
|
#include "items.h"
|
||||||
#include "creport.h"
|
#include "creport.h"
|
||||||
#include "names.h"
|
#include "names.h"
|
||||||
|
#include "wormhole.h"
|
||||||
|
|
||||||
void game_done(void)
|
void game_done(void)
|
||||||
{
|
{
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include "gmtool_structs.h"
|
#include "gmtool_structs.h"
|
||||||
#include "console.h"
|
#include "console.h"
|
||||||
#include "listbox.h"
|
#include "listbox.h"
|
||||||
|
#include "wormhole.h"
|
||||||
|
|
||||||
#include <modules/xmas.h>
|
#include <modules/xmas.h>
|
||||||
#include <modules/gmcmd.h>
|
#include <modules/gmcmd.h>
|
||||||
|
@ -26,7 +27,6 @@
|
||||||
#if ARENA_MODULE
|
#if ARENA_MODULE
|
||||||
#include <modules/arena.h>
|
#include <modules/arena.h>
|
||||||
#endif
|
#endif
|
||||||
#include <modules/wormhole.h>
|
|
||||||
#include <modules/autoseed.h>
|
#include <modules/autoseed.h>
|
||||||
#if DUNGEON_MODULE
|
#if DUNGEON_MODULE
|
||||||
#include <modules/dungeon.h>
|
#include <modules/dungeon.h>
|
||||||
|
|
12
src/laws.c
12
src/laws.c
|
@ -22,18 +22,18 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
#include "laws.h"
|
#include "laws.h"
|
||||||
|
|
||||||
#include <modules/gmcmd.h>
|
#include <modules/gmcmd.h>
|
||||||
#include <modules/wormhole.h>
|
|
||||||
|
|
||||||
|
#include "alchemy.h"
|
||||||
|
#include "battle.h"
|
||||||
#include "economy.h"
|
#include "economy.h"
|
||||||
|
#include "keyword.h"
|
||||||
|
#include "market.h"
|
||||||
#include "monster.h"
|
#include "monster.h"
|
||||||
|
#include "move.h"
|
||||||
#include "randenc.h"
|
#include "randenc.h"
|
||||||
#include "spy.h"
|
#include "spy.h"
|
||||||
#include "study.h"
|
#include "study.h"
|
||||||
#include "market.h"
|
#include "wormhole.h"
|
||||||
#include "keyword.h"
|
|
||||||
#include "move.h"
|
|
||||||
#include "battle.h"
|
|
||||||
#include "alchemy.h"
|
|
||||||
|
|
||||||
/* kernel includes */
|
/* kernel includes */
|
||||||
#include <kernel/alliance.h>
|
#include <kernel/alliance.h>
|
||||||
|
|
|
@ -7,7 +7,6 @@ gmcmd.c
|
||||||
museum.c
|
museum.c
|
||||||
score.c
|
score.c
|
||||||
weather.c
|
weather.c
|
||||||
wormhole.c
|
|
||||||
xmas.c
|
xmas.c
|
||||||
)
|
)
|
||||||
FOREACH(_FILE ${_FILES})
|
FOREACH(_FILE ${_FILES})
|
||||||
|
|
|
@ -60,6 +60,7 @@ int RunAllTests(void)
|
||||||
ADD_TESTS(suite, stealth);
|
ADD_TESTS(suite, stealth);
|
||||||
ADD_TESTS(suite, upkeep);
|
ADD_TESTS(suite, upkeep);
|
||||||
ADD_TESTS(suite, vortex);
|
ADD_TESTS(suite, vortex);
|
||||||
|
ADD_TESTS(suite, wormhole);
|
||||||
|
|
||||||
CuSuiteRun(suite);
|
CuSuiteRun(suite);
|
||||||
CuSuiteSummary(suite, output);
|
CuSuiteSummary(suite, output);
|
||||||
|
|
|
@ -115,7 +115,9 @@ building_type * test_create_buildingtype(const char * name)
|
||||||
btype->construction->materials[1].number = 0;
|
btype->construction->materials[1].number = 0;
|
||||||
btype->construction->materials[0].number = 1;
|
btype->construction->materials[0].number = 1;
|
||||||
btype->construction->materials[0].rtype = get_resourcetype(R_STONE);
|
btype->construction->materials[0].rtype = get_resourcetype(R_STONE);
|
||||||
locale_setstring(default_locale, name, name);
|
if (default_locale) {
|
||||||
|
locale_setstring(default_locale, name, name);
|
||||||
|
}
|
||||||
bt_register(btype);
|
bt_register(btype);
|
||||||
return btype;
|
return btype;
|
||||||
}
|
}
|
||||||
|
|
|
@ -116,22 +116,8 @@ void addtoken(void ** root, const char *str, variant id)
|
||||||
const char str[3];
|
const char str[3];
|
||||||
} replace[] = {
|
} replace[] = {
|
||||||
/* match lower-case (!) umlauts and others to transcriptions */
|
/* match lower-case (!) umlauts and others to transcriptions */
|
||||||
{
|
{ 228, "AE" }, { 246, "OE" }, { 252, "UE" }, { 223, "SS" },
|
||||||
228, "AE" }, /* auml */
|
{ 230, "AE" }, { 248, "OE" }, { 229, "AA" }, { 0, "" }
|
||||||
{
|
|
||||||
246, "OE" }, /* ouml */
|
|
||||||
{
|
|
||||||
252, "UE" }, /* uuml */
|
|
||||||
{
|
|
||||||
223, "SS" }, /* szlig */
|
|
||||||
{
|
|
||||||
230, "AE" }, /* norsk */
|
|
||||||
{
|
|
||||||
248, "OE" }, /* norsk */
|
|
||||||
{
|
|
||||||
229, "AA" }, /* norsk */
|
|
||||||
{
|
|
||||||
0, "" }
|
|
||||||
};
|
};
|
||||||
|
|
||||||
assert(root && str);
|
assert(root && str);
|
||||||
|
|
|
@ -35,13 +35,9 @@ static void test_move_to_vortex(CuTest *tc) {
|
||||||
CuAssertPtrEquals(tc, r2, r);
|
CuAssertPtrEquals(tc, r2, r);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void test_vortex(CuTest *tc) {
|
|
||||||
}
|
|
||||||
|
|
||||||
CuSuite *get_vortex_suite(void)
|
CuSuite *get_vortex_suite(void)
|
||||||
{
|
{
|
||||||
CuSuite *suite = CuSuiteNew();
|
CuSuite *suite = CuSuiteNew();
|
||||||
SUITE_ADD_TEST(suite, test_vortex);
|
|
||||||
SUITE_ADD_TEST(suite, test_move_to_vortex);
|
SUITE_ADD_TEST(suite, test_move_to_vortex);
|
||||||
return suite;
|
return suite;
|
||||||
}
|
}
|
||||||
|
|
|
@ -173,20 +173,13 @@ make_wormhole(const building_type * bt_wormhole, region * r1, region * r2)
|
||||||
ADDMSG(&r2->msgs, msg_message("wormhole_appear", "region", r2));
|
ADDMSG(&r2->msgs, msg_message("wormhole_appear", "region", r2));
|
||||||
}
|
}
|
||||||
|
|
||||||
void create_wormholes(void)
|
|
||||||
{
|
|
||||||
#define WORMHOLE_CHANCE 10000
|
#define WORMHOLE_CHANCE 10000
|
||||||
const building_type *bt_wormhole = bt_find("wormhole");
|
|
||||||
quicklist *ql, *rlist = 0;
|
|
||||||
region *r = regions;
|
|
||||||
int qi, i = 0, count = 0;
|
|
||||||
region **match;
|
|
||||||
|
|
||||||
if (bt_wormhole == NULL)
|
void select_wormhole_regions(quicklist **rlistp, int *countp) {
|
||||||
return;
|
quicklist *rlist = 0;
|
||||||
/*
|
region *r = regions;
|
||||||
* select a list of regions. we'll sort them by age later.
|
int count = 0;
|
||||||
*/
|
|
||||||
while (r != NULL) {
|
while (r != NULL) {
|
||||||
int next = rng_int() % (2 * WORMHOLE_CHANCE);
|
int next = rng_int() % (2 * WORMHOLE_CHANCE);
|
||||||
while (r != NULL && (next != 0 || !good_region(r))) {
|
while (r != NULL && (next != 0 || !good_region(r))) {
|
||||||
|
@ -202,21 +195,47 @@ void create_wormholes(void)
|
||||||
r = r->next;
|
r = r->next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (count < 2)
|
*countp = count;
|
||||||
return;
|
*rlistp = rlist;
|
||||||
|
}
|
||||||
|
|
||||||
match = (region **)malloc(sizeof(region *) * count);
|
void sort_wormhole_regions(quicklist *rlist, region **match, int count) {
|
||||||
|
quicklist *ql;
|
||||||
|
int qi, i = 0;
|
||||||
|
|
||||||
for (ql = rlist, qi = 0; i != count; ql_advance(&ql, &qi, 1)) {
|
for (ql = rlist, qi = 0; i != count; ql_advance(&ql, &qi, 1)) {
|
||||||
match[i++] = (region *)ql_get(ql, qi);
|
match[i++] = (region *)ql_get(ql, qi);
|
||||||
}
|
}
|
||||||
qsort(match, count, sizeof(region *), cmp_age);
|
qsort(match, count, sizeof(region *), cmp_age);
|
||||||
ql_free(rlist);
|
}
|
||||||
|
|
||||||
|
void make_wormholes(region **match, int count, const building_type *bt_wormhole) {
|
||||||
|
int i;
|
||||||
count /= 2;
|
count /= 2;
|
||||||
for (i = 0; i != count; ++i) {
|
for (i = 0; i != count; ++i) {
|
||||||
make_wormhole(bt_wormhole, match[i], match[i + count]);
|
make_wormhole(bt_wormhole, match[i], match[i + count]);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void create_wormholes(void)
|
||||||
|
{
|
||||||
|
const building_type *bt_wormhole = bt_find("wormhole");
|
||||||
|
quicklist *rlist = 0;
|
||||||
|
int count = 0;
|
||||||
|
region **match;
|
||||||
|
|
||||||
|
if (bt_wormhole == NULL) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
select_wormhole_regions(&rlist, &count);
|
||||||
|
if (count < 2) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
match = (region **)malloc(sizeof(region *) * count);
|
||||||
|
sort_wormhole_regions(rlist, match, count);
|
||||||
|
ql_free(rlist);
|
||||||
|
make_wormholes(match, count, bt_wormhole);
|
||||||
free(match);
|
free(match);
|
||||||
}
|
}
|
||||||
|
|
68
src/wormhole.test.c
Normal file
68
src/wormhole.test.c
Normal file
|
@ -0,0 +1,68 @@
|
||||||
|
#include <platform.h>
|
||||||
|
#include <kernel/types.h>
|
||||||
|
|
||||||
|
#include "wormhole.h"
|
||||||
|
#include "tests.h"
|
||||||
|
|
||||||
|
#include <kernel/building.h>
|
||||||
|
#include <kernel/region.h>
|
||||||
|
#include <kernel/terrain.h>
|
||||||
|
|
||||||
|
#include <util/attrib.h>
|
||||||
|
|
||||||
|
#include <quicklist.h>
|
||||||
|
|
||||||
|
#include <CuTest.h>
|
||||||
|
|
||||||
|
void sort_wormhole_regions(quicklist *rlist, region **match, int count);
|
||||||
|
void make_wormholes(region **match, int count, const building_type *bt_wormhole);
|
||||||
|
|
||||||
|
static void test_make_wormholes(CuTest *tc) {
|
||||||
|
region *r1, *r2, *match[2];
|
||||||
|
terrain_type *t_plain;
|
||||||
|
building_type *btype;
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
t_plain = test_create_terrain("plain", LAND_REGION);
|
||||||
|
btype = test_create_buildingtype("wormhole");
|
||||||
|
match[0] = r1 = test_create_region(0, 0, t_plain);
|
||||||
|
match[1] = r2 = test_create_region(1, 0, t_plain);
|
||||||
|
make_wormholes(match, 2, btype);
|
||||||
|
CuAssertPtrNotNull(tc, r1->buildings);
|
||||||
|
CuAssertPtrNotNull(tc, r1->buildings->attribs);
|
||||||
|
CuAssertPtrEquals(tc, (void *)r1->buildings->type, (void *)btype);
|
||||||
|
CuAssertPtrNotNull(tc, r2->buildings);
|
||||||
|
CuAssertPtrNotNull(tc, r2->buildings->attribs);
|
||||||
|
CuAssertPtrEquals(tc, (void *)r2->buildings->type, (void *)btype);
|
||||||
|
CuAssertPtrEquals(tc, (void *)r1->buildings->attribs->type, (void *)r2->buildings->attribs->type);
|
||||||
|
CuAssertStrEquals(tc, r1->buildings->attribs->type->name, "wormhole");
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
static void test_sort_wormhole_regions(CuTest *tc) {
|
||||||
|
region *r1, *r2, *match[2];
|
||||||
|
terrain_type *t_plain;
|
||||||
|
quicklist *rlist = 0;
|
||||||
|
|
||||||
|
test_cleanup();
|
||||||
|
t_plain = test_create_terrain("plain", LAND_REGION);
|
||||||
|
r1 = test_create_region(0, 0, t_plain);
|
||||||
|
r2 = test_create_region(1, 0, t_plain);
|
||||||
|
r1->age = 4;
|
||||||
|
r2->age = 2;
|
||||||
|
ql_push(&rlist, r1);
|
||||||
|
ql_push(&rlist, r2);
|
||||||
|
sort_wormhole_regions(rlist, match, 2);
|
||||||
|
CuAssertPtrEquals(tc, r2, match[0]);
|
||||||
|
CuAssertPtrEquals(tc, r1, match[1]);
|
||||||
|
ql_free(rlist);
|
||||||
|
test_cleanup();
|
||||||
|
}
|
||||||
|
|
||||||
|
CuSuite *get_wormhole_suite(void)
|
||||||
|
{
|
||||||
|
CuSuite *suite = CuSuiteNew();
|
||||||
|
SUITE_ADD_TEST(suite, test_sort_wormhole_regions);
|
||||||
|
SUITE_ADD_TEST(suite, test_make_wormholes);
|
||||||
|
return suite;
|
||||||
|
}
|
Loading…
Reference in a new issue