Spiking on findparam to use critbit as a findtoken replacement

This commit is contained in:
Enno Rehling 2012-05-16 09:18:25 -07:00
parent 53d35213b6
commit 0a6e18f34d
2 changed files with 26 additions and 8 deletions

View file

@ -54,6 +54,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/attrib.h> #include <util/attrib.h>
#include <util/base36.h> #include <util/base36.h>
#include <util/bsdstring.h> #include <util/bsdstring.h>
#include <util/critbit.h>
#include <util/crmessage.h> #include <util/crmessage.h>
#include <util/event.h> #include <util/event.h>
#include <util/functions.h> #include <util/functions.h>
@ -1494,17 +1495,22 @@ keyword_t findkeyword(const char *s, const struct locale * lang)
param_t findparam(const char *s, const struct locale * lang) param_t findparam(const char *s, const struct locale * lang)
{ {
void **tokens = get_translations(lang, UT_PARAMS); void **tokens = get_translations(lang, UT_PARAMS);
variant token; int i;
param_t result = NOPARAM;
void * match;
char buffer[64];
char * str = transliterate(buffer, sizeof(buffer)-sizeof(int), s);
critbit_tree *cb = (critbit_tree *)*tokens;
if (findtoken(*tokens, s, &token) == E_TOK_NOMATCH) { if (str && cb_find_prefix(cb, str, strlen(str), &match, 1, 0)) {
cb_get_kv(match, &i, sizeof(int));
result = (param_t)i;
} else {
const building_type *btype = findbuildingtype(s, lang); const building_type *btype = findbuildingtype(s, lang);
if (btype != NULL) if (btype != NULL)
return (param_t) P_GEBAEUDE; return (param_t) P_GEBAEUDE;
return NOPARAM;
} }
if (token.i == P_BUILDING) return (result == P_BUILDING) ? P_GEBAEUDE : result;
return P_GEBAEUDE;
return (param_t) token.i;
} }
param_t getparam(const struct locale * lang) param_t getparam(const struct locale * lang)
@ -2057,6 +2063,7 @@ static void init_locale(const struct locale *lang)
const struct race *rc; const struct race *rc;
void **tokens; void **tokens;
const terrain_type *terrain; const terrain_type *terrain;
char buffer[256];
#ifdef PTRIES #ifdef PTRIES
trie_node **ptrie; trie_node **ptrie;
#endif #endif
@ -2096,8 +2103,18 @@ static void init_locale(const struct locale *lang)
tokens = get_translations(lang, UT_PARAMS); tokens = get_translations(lang, UT_PARAMS);
for (i = 0; i != MAXPARAMS; ++i) { for (i = 0; i != MAXPARAMS; ++i) {
var.i = i; const char * key = LOC(lang, parameters[i]);
addtoken(tokens, LOC(lang, parameters[i]), var); char * str = transliterate(buffer, sizeof(buffer)-sizeof(int), key);
if (str) {
critbit_tree * cb = (critbit_tree *)*tokens;
if (!cb) {
*tokens = cb = (critbit_tree *)calloc(1, sizeof(critbit_tree *));
}
cb_new_kv(str, &i, sizeof(int), buffer);
cb_insert(cb, buffer, strlen(str)+1+sizeof(int));
} else {
log_error(("could not transliterate param '%s'\n", key));
}
} }
#ifdef PTRIES #ifdef PTRIES
ptrie = get_ptrie(lang, UT_SKILLS); ptrie = get_ptrie(lang, UT_SKILLS);

View file

@ -164,6 +164,7 @@ typedef struct stat stat_type;
/* MSVC has _access, not access */ /* MSVC has _access, not access */
#ifndef access #ifndef access
#include <io.h>
# define access(f, m) _access(f, m) # define access(f, m) _access(f, m)
#endif #endif
#define HAVE_ACCESS #define HAVE_ACCESS