From 96d6abdc5a802e335fadd15e2a06c991249be4d0 Mon Sep 17 00:00:00 2001 From: Enno Rehling Date: Mon, 19 Sep 2016 06:55:32 +0200 Subject: [PATCH] add caching API for rc_find --- src/kernel/race.c | 14 ++++++++++++-- src/kernel/race.h | 1 + src/kernel/race.test.c | 9 ++++++++- 3 files changed, 21 insertions(+), 3 deletions(-) diff --git a/src/kernel/race.c b/src/kernel/race.c index bb91898db..1088681d2 100644 --- a/src/kernel/race.c +++ b/src/kernel/race.c @@ -59,7 +59,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. /** external variables **/ race *races; int num_races = 0; -static int cache_breaker; +static int rc_changes = 1; static const char *racenames[MAXRACES] = { "dwarf", "elf", NULL, "goblin", "human", "troll", "demon", "insect", @@ -132,6 +132,7 @@ void free_races(void) { races = rc; } num_races = 0; + ++rc_changes; } static race *rc_find_i(const char *name) @@ -153,6 +154,15 @@ const race * rc_find(const char *name) { return rc_find_i(name); } +bool rc_changed(int *cache) { + assert(cache); + if (*cache != rc_changes) { + *cache = rc_changes; + return true; + } + return false; +} + race *rc_get_or_create(const char *zName) { race *rc; @@ -180,7 +190,7 @@ race *rc_get_or_create(const char *zName) for (i = 1; i < RACE_ATTACKS; ++i) rc->attack[i].type = AT_NONE; rc->index = num_races++; - ++cache_breaker; + ++rc_changes; rc->next = races; return races = rc; } diff --git a/src/kernel/race.h b/src/kernel/race.h index b1632f62d..6e8e4bd36 100644 --- a/src/kernel/race.h +++ b/src/kernel/race.h @@ -180,6 +180,7 @@ extern "C" { race_t old_race(const struct race *); race *rc_get_or_create(const char *name); + bool rc_changed(int *cache); const race *rc_find(const char *); void free_races(void); diff --git a/src/kernel/race.test.c b/src/kernel/race.test.c index 25bd3e912..0a14c3ca6 100644 --- a/src/kernel/race.test.c +++ b/src/kernel/race.test.c @@ -50,11 +50,18 @@ static void test_rc_find(CuTest *tc) { } static void test_race_get(CuTest *tc) { + int cache; race *rc; test_setup(); + CuAssertTrue(tc, rc_changed(&cache)); + CuAssertTrue(tc, !rc_changed(&cache)); rc = get_race(RC_ELF); - CuAssertPtrEquals(tc, rc, (void *)rc_find("elf")); CuAssertPtrEquals(tc, rc, (void *)rc_get_or_create("elf")); + CuAssertTrue(tc, rc_changed(&cache)); + CuAssertTrue(tc, !rc_changed(&cache)); + CuAssertPtrEquals(tc, rc, (void *)rc_find("elf")); + free_races(); + CuAssertTrue(tc, rc_changed(&cache)); test_cleanup(); }