From 4c58127ce17a10f7cb6a8fc408dd12e4ab549c89 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Sun, 25 Nov 2018 09:21:37 +0100 Subject: [PATCH] fix renumber parser crash --- src/renumber.c | 2 +- src/renumber.test.c | 9 +++++++-- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/src/renumber.c b/src/renumber.c index a4653e1a0..e562a0285 100644 --- a/src/renumber.c +++ b/src/renumber.c @@ -167,7 +167,7 @@ int renumber_cmd(unit * u, order * ord) break; } s = gettoken(token, sizeof(token)); - if (*s == 0) { + if (s == NULL || *s == 0) { i = newcontainerid(); } else { diff --git a/src/renumber.test.c b/src/renumber.test.c index e5f9c5c33..f65011cf7 100644 --- a/src/renumber.test.c +++ b/src/renumber.test.c @@ -101,7 +101,12 @@ static void test_renumber_building(CuTest *tc) { no = u->building->no; uno = (no > 1) ? no - 1 : no + 1; lang = u->faction->locale; - u->thisorder = create_order(K_NUMBER, lang, "%s %s", LOC(lang, parameters[P_BUILDING]), itoa36(uno)); + u->thisorder = create_order(K_NUMBER, lang, LOC(lang, parameters[P_BUILDING])); + renumber_cmd(u, u->thisorder); + CuAssertTrue(tc, no != u->building->no); + free_order(u->thisorder); + + u->thisorder = create_order(K_NUMBER, lang, "%s %i", LOC(lang, parameters[P_BUILDING]), uno); renumber_cmd(u, u->thisorder); CuAssertIntEquals(tc, uno, u->building->no); test_teardown(); @@ -120,7 +125,7 @@ static void test_renumber_building_duplicate(CuTest *tc) { u->building = test_create_building(u->region, NULL); no = u->building->no; lang = f->locale; - u->thisorder = create_order(K_NUMBER, lang, "%s %s", LOC(lang, parameters[P_BUILDING]), itoa36(uno)); + u->thisorder = create_order(K_NUMBER, lang, "%s %i", LOC(lang, parameters[P_BUILDING]), uno); renumber_cmd(u, u->thisorder); CuAssertPtrNotNull(tc, test_find_messagetype(f->msgs, "error115")); CuAssertIntEquals(tc, no, u->building->no);