forked from github/server
Merge pull request #696 from ennorehling/develop
BUG 2328: absolutely final changes for 3.12
This commit is contained in:
commit
4efe6f6a71
7 changed files with 69 additions and 52 deletions
|
@ -2,17 +2,18 @@
|
|||
"calendar" : {
|
||||
"months" : [
|
||||
{ "storm" : 60, "season" : 2 },
|
||||
{ "storm" : 10, "season" : 2 },
|
||||
|
||||
{ "storm" : 60, "season" : 3 },
|
||||
{ "storm" : 10, "season" : 3 },
|
||||
{ "storm" : 60, "season" : 3 },
|
||||
|
||||
{ "storm" : 10, "season" : 0 },
|
||||
{ "storm" : 60, "season" : 0 },
|
||||
{ "storm" : 80, "season" : 0 },
|
||||
|
||||
{ "storm" : 50, "season" : 1 },
|
||||
{ "storm" : 30, "season" : 1 },
|
||||
{ "storm" : 60, "season" : 1 }
|
||||
|
||||
{ "storm" : 60, "season" : 2 }
|
||||
],
|
||||
"weeks" : [
|
||||
"firstweek", "secondweek", "thirdweek"
|
||||
|
|
|
@ -404,3 +404,7 @@ function test_demonstealth()
|
|||
desc = u:show()
|
||||
assert_equal(nil, string.find(desc, "Drache"))
|
||||
end
|
||||
|
||||
function test_calendar_season_2328()
|
||||
assert_equal("fall", get_season(1026))
|
||||
end
|
||||
|
|
|
@ -75,15 +75,16 @@ static building_type *bt_find_i(const char *name)
|
|||
if (match) {
|
||||
cb_get_kv(match, &btype, sizeof(btype));
|
||||
}
|
||||
else {
|
||||
log_warning("st_find: could not find ship '%s'\n", name);
|
||||
}
|
||||
return btype;
|
||||
}
|
||||
|
||||
const building_type *bt_find(const char *name)
|
||||
{
|
||||
return bt_find_i(name);
|
||||
building_type *btype = bt_find_i(name);
|
||||
if (!btype) {
|
||||
log_warning("bt_find: could not find building '%s'\n", name);
|
||||
}
|
||||
return btype;
|
||||
}
|
||||
|
||||
static int bt_changes = 1;
|
||||
|
|
|
@ -97,14 +97,15 @@ static ship_type *st_find_i(const char *name)
|
|||
if (match) {
|
||||
cb_get_kv(match, &st, sizeof(st));
|
||||
}
|
||||
else {
|
||||
log_warning("st_find: could not find ship '%s'\n", name);
|
||||
}
|
||||
return st;
|
||||
}
|
||||
|
||||
const ship_type *st_find(const char *name) {
|
||||
return st_find_i(name);
|
||||
ship_type *st = st_find_i(name);
|
||||
if (!st) {
|
||||
log_warning("st_find: could not find ship '%s'\n", name);
|
||||
}
|
||||
return st;
|
||||
}
|
||||
|
||||
static void st_register(ship_type *stype) {
|
||||
|
|
10
src/laws.c
10
src/laws.c
|
@ -2390,6 +2390,7 @@ static void display_race(unit * u, const race * rc)
|
|||
|
||||
static void reshow_other(unit * u, struct order *ord, const char *s) {
|
||||
int err = 21;
|
||||
bool found = false;
|
||||
|
||||
if (s) {
|
||||
const spell *sp = 0;
|
||||
|
@ -2426,7 +2427,7 @@ static void reshow_other(unit * u, struct order *ord, const char *s) {
|
|||
else {
|
||||
display_item(u, itype);
|
||||
}
|
||||
return;
|
||||
found = true;
|
||||
}
|
||||
|
||||
if (sp) {
|
||||
|
@ -2437,15 +2438,16 @@ static void reshow_other(unit * u, struct order *ord, const char *s) {
|
|||
if (a != NULL) {
|
||||
a_remove(&u->faction->attribs, a);
|
||||
}
|
||||
return;
|
||||
found = true;
|
||||
}
|
||||
|
||||
if (rc && u_race(u) == rc) {
|
||||
display_race(u, rc);
|
||||
return;
|
||||
found = true;
|
||||
}
|
||||
}
|
||||
cmistake(u, ord, err, MSG_EVENT);
|
||||
if (!found)
|
||||
cmistake(u, ord, err, MSG_EVENT);
|
||||
}
|
||||
|
||||
static void reshow(unit * u, struct order *ord, const char *s, param_t p)
|
||||
|
|
|
@ -1363,42 +1363,6 @@ static void test_show_without_item(CuTest *tc)
|
|||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_show_elf(CuTest *tc) {
|
||||
order *ord;
|
||||
race * rc;
|
||||
unit *u;
|
||||
struct locale *loc;
|
||||
message * msg;
|
||||
|
||||
test_setup();
|
||||
|
||||
mt_register(mt_new_va("msg_event", "string:string", 0));
|
||||
rc = test_create_race("elf");
|
||||
test_create_itemtype("elvenhorse");
|
||||
|
||||
loc = test_create_locale();
|
||||
locale_setstring(loc, "elvenhorse", "Elfenpferd");
|
||||
locale_setstring(loc, "elvenhorse_p", "Elfenpferde");
|
||||
locale_setstring(loc, "race::elf_p", "Elfen");
|
||||
locale_setstring(loc, "race::elf", "Elf");
|
||||
init_locale(loc);
|
||||
|
||||
CuAssertPtrNotNull(tc, finditemtype("elf", loc));
|
||||
CuAssertPtrNotNull(tc, findrace("elf", loc));
|
||||
|
||||
u = test_create_unit(test_create_faction(rc), test_create_region(0, 0, 0));
|
||||
u->faction->locale = loc;
|
||||
ord = create_order(K_RESHOW, loc, "Elf");
|
||||
reshow_cmd(u, ord);
|
||||
CuAssertTrue(tc, test_find_messagetype(u->faction->msgs, "error36") == NULL);
|
||||
msg = test_find_messagetype(u->faction->msgs, "msg_event");
|
||||
CuAssertPtrNotNull(tc, msg);
|
||||
CuAssertTrue(tc, memcmp("Elf:", msg->parameters[0].v, 4) == 0);
|
||||
test_clear_messages(u->faction);
|
||||
free_order(ord);
|
||||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_show_race(CuTest *tc) {
|
||||
order *ord;
|
||||
race * rc;
|
||||
|
@ -1440,6 +1404,48 @@ static void test_show_race(CuTest *tc) {
|
|||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_show_both(CuTest *tc) {
|
||||
order *ord;
|
||||
race * rc;
|
||||
unit *u;
|
||||
struct locale *loc;
|
||||
message * msg;
|
||||
|
||||
test_cleanup();
|
||||
|
||||
mt_register(mt_new_va("msg_event", "string:string", 0));
|
||||
mt_register(mt_new_va("displayitem", "weight:int", "item:resource", "description:string", 0));
|
||||
rc = test_create_race("elf");
|
||||
test_create_itemtype("elvenhorse");
|
||||
|
||||
loc = get_or_create_locale("de");
|
||||
locale_setstring(loc, "elvenhorse", "Elfenpferd");
|
||||
locale_setstring(loc, "elvenhorse_p", "Elfenpferde");
|
||||
locale_setstring(loc, "iteminfo::elvenhorse", "Hiyaa!");
|
||||
locale_setstring(loc, "race::elf_p", "Elfen");
|
||||
locale_setstring(loc, "race::elf", "Elf");
|
||||
init_locale(loc);
|
||||
|
||||
CuAssertPtrNotNull(tc, finditemtype("elf", loc));
|
||||
CuAssertPtrNotNull(tc, findrace("elf", loc));
|
||||
|
||||
u = test_create_unit(test_create_faction(rc), test_create_region(0, 0, 0));
|
||||
u->faction->locale = loc;
|
||||
i_change(&u->items, finditemtype("elfenpferd", loc), 1);
|
||||
ord = create_order(K_RESHOW, loc, "Elf");
|
||||
reshow_cmd(u, ord);
|
||||
CuAssertTrue(tc, test_find_messagetype(u->faction->msgs, "error36") == NULL);
|
||||
msg = test_find_messagetype(u->faction->msgs, "msg_event");
|
||||
CuAssertPtrNotNull(tc, msg);
|
||||
CuAssertTrue(tc, memcmp("Elf:", msg->parameters[0].v, 4) == 0);
|
||||
msg = test_find_messagetype(u->faction->msgs, "displayitem");
|
||||
CuAssertPtrNotNull(tc, msg);
|
||||
CuAssertTrue(tc, memcmp("Hiyaa!", msg->parameters[2].v, 4) == 0);
|
||||
test_clear_messages(u->faction);
|
||||
free_order(ord);
|
||||
test_cleanup();
|
||||
}
|
||||
|
||||
static void test_immigration(CuTest * tc)
|
||||
{
|
||||
region *r;
|
||||
|
@ -1607,8 +1613,8 @@ CuSuite *get_laws_suite(void)
|
|||
SUITE_ADD_TEST(suite, test_name_building);
|
||||
SUITE_ADD_TEST(suite, test_name_ship);
|
||||
SUITE_ADD_TEST(suite, test_show_without_item);
|
||||
SUITE_ADD_TEST(suite, test_show_elf);
|
||||
SUITE_ADD_TEST(suite, test_show_race);
|
||||
SUITE_ADD_TEST(suite, test_show_both);
|
||||
SUITE_ADD_TEST(suite, test_immigration);
|
||||
SUITE_ADD_TEST(suite, test_demon_hunger);
|
||||
SUITE_ADD_TEST(suite, test_armedmen);
|
||||
|
|
|
@ -15,11 +15,13 @@
|
|||
#define NO_MKDIR
|
||||
#define _CRT_SECURE_NO_WARNINGS
|
||||
#define _USE_MATH_DEFINES
|
||||
#if _MSC_VER >= 1900
|
||||
#pragma warning(disable: 4710 4820)
|
||||
#pragma warning(disable: 4100) // unreferenced formal parameter
|
||||
#pragma warning(disable: 4456) // declaration hides previous
|
||||
#pragma warning(disable: 4457) // declaration hides function parameter
|
||||
#pragma warning(disable: 4459) // declaration hides global
|
||||
#endif
|
||||
#else /* assume gcc */
|
||||
#if !defined(__STDC_VERSION__) || __STDC_VERSION__ < 199901L
|
||||
# define va_copy(a,b) __va_copy(a,b)
|
||||
|
|
Loading…
Reference in a new issue