forked from github/server
fixing something. findresourcetype, I think?
This commit is contained in:
parent
2872dfa772
commit
56083b1fcf
|
@ -57,6 +57,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
|
||||||
static critbit_tree inames[MAXLOCALES];
|
static critbit_tree inames[MAXLOCALES];
|
||||||
|
static critbit_tree rnames[MAXLOCALES];
|
||||||
static critbit_tree cb_resources;
|
static critbit_tree cb_resources;
|
||||||
static critbit_tree cb_items;
|
static critbit_tree cb_items;
|
||||||
luxury_type *luxurytypes;
|
luxury_type *luxurytypes;
|
||||||
|
@ -1055,46 +1056,49 @@ int change_money(unit * u, int v)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static local_names *rnames;
|
static int add_resourcename_cb(const void * match, const void * key, size_t keylen, void *data)
|
||||||
#define CB_BATCHSIZE 16
|
|
||||||
const resource_type *findresourcetype(const char *name,
|
|
||||||
const struct locale *lang)
|
|
||||||
{
|
{
|
||||||
const void * matches[CB_BATCHSIZE];
|
struct locale * lang = (struct locale *)data;
|
||||||
local_names *rn = rnames;
|
int i = locale_index(lang);
|
||||||
variant token;
|
critbit_tree * cb = rnames+i;
|
||||||
|
resource_type *rtype;
|
||||||
|
|
||||||
while (rn) {
|
cb_get_kv(match, &rtype, sizeof(rtype));
|
||||||
if (rn->lang == lang)
|
for (i = 0; i!=2;++i) {
|
||||||
break;
|
char buffer[128];
|
||||||
rn = rn->next;
|
const char * name = locale_string(lang, rtype->_name[i]);
|
||||||
}
|
|
||||||
if (!rn) {
|
|
||||||
int m, offset = 0;
|
|
||||||
rn = (local_names *)calloc(1, sizeof(local_names));
|
|
||||||
rn->next = rnames;
|
|
||||||
rn->lang = lang;
|
|
||||||
do {
|
|
||||||
m = cb_find_prefix(&cb_resources, "", 1, matches, CB_BATCHSIZE, offset);
|
|
||||||
if (m) {
|
|
||||||
int i;
|
|
||||||
offset += m;
|
|
||||||
for (i=0;i!=m;++i) {
|
|
||||||
resource_type *rtype;
|
|
||||||
cb_get_kv(matches[i], &rtype, sizeof(rtype));
|
|
||||||
token.v = (void *)rtype;
|
|
||||||
addtoken(&rn->names, locale_string(lang, rtype->_name[0]), token);
|
|
||||||
addtoken(&rn->names, locale_string(lang, rtype->_name[1]), token);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} while (m==CB_BATCHSIZE);
|
|
||||||
rnames = rn;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (findtoken(rn->names, name, &token) == E_TOK_NOMATCH) {
|
if (name && transliterate(buffer, sizeof(buffer), name)) {
|
||||||
return 0;
|
size_t len = strlen(buffer);
|
||||||
|
assert(len+sizeof(rtype)<sizeof(buffer));
|
||||||
|
cb_new_kv(buffer, &rtype, sizeof(rtype), buffer);
|
||||||
|
cb_insert(cb, buffer, len+1+sizeof(rtype));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return (const resource_type *)token.v;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
const resource_type *findresourcetype(const char *name, const struct locale *lang)
|
||||||
|
{
|
||||||
|
int i = locale_index(lang);
|
||||||
|
critbit_tree * cb = rnames+i;
|
||||||
|
char buffer[128];
|
||||||
|
|
||||||
|
if (transliterate(buffer, sizeof(buffer), name)) {
|
||||||
|
const void * match;
|
||||||
|
if (!cb->root) {
|
||||||
|
/* first-time initialization of resource names for this locale */
|
||||||
|
cb_foreach(&cb_resources, "", 0, add_resourcename_cb, (void *)lang);
|
||||||
|
}
|
||||||
|
if (cb_find_prefix(cb, buffer, strlen(buffer), &match, 1, 0)) {
|
||||||
|
const resource_type * rtype = 0;
|
||||||
|
cb_get_kv(match, (void*)&rtype, sizeof(rtype));
|
||||||
|
return rtype;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
log_debug("findresourcetype: transliterate failed for '%s'\n", name);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
attrib_type at_showitem = {
|
attrib_type at_showitem = {
|
||||||
|
|
|
@ -55,10 +55,14 @@ void test_findresourcetype(CuTest * tc)
|
||||||
|
|
||||||
lang = find_locale("de");
|
lang = find_locale("de");
|
||||||
locale_setstring(lang, "horse", "Pferd");
|
locale_setstring(lang, "horse", "Pferd");
|
||||||
|
locale_setstring(lang, "peasant", "Bauer");
|
||||||
|
|
||||||
rtype = rt_find("horse");
|
rtype = rt_find("horse");
|
||||||
rresult = findresourcetype("Pferd", lang);
|
rresult = findresourcetype("Pferd", lang);
|
||||||
CuAssertPtrNotNull(tc, rresult);
|
CuAssertPtrNotNull(tc, rresult);
|
||||||
CuAssertPtrEquals(tc, (void*)rtype, (void*)rresult);
|
CuAssertPtrEquals(tc, (void*)rtype, (void*)rresult);
|
||||||
|
|
||||||
|
CuAssertPtrNotNull(tc, findresourcetype("Bauer", lang));
|
||||||
}
|
}
|
||||||
|
|
||||||
CuSuite *get_item_suite(void)
|
CuSuite *get_item_suite(void)
|
||||||
|
|
|
@ -271,6 +271,7 @@ int reserve_cmd(unit * u, struct order *ord)
|
||||||
if (use) {
|
if (use) {
|
||||||
new_set_resvalue(u, rtype, use);
|
new_set_resvalue(u, rtype, use);
|
||||||
change_resource(u, rtype, use);
|
change_resource(u, rtype, use);
|
||||||
|
return use;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
#include <util/language.h>
|
||||||
#include <kernel/item.h>
|
#include <kernel/item.h>
|
||||||
#include <kernel/region.h>
|
#include <kernel/region.h>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue