forked from github/server
remove string parsing from XML. E3 tests failing!
This commit is contained in:
parent
0d6abd3811
commit
4d09f00f03
2 changed files with 7 additions and 103 deletions
|
@ -2,13 +2,8 @@
|
||||||
"include": [
|
"include": [
|
||||||
"config://res/translations/strings.de.po",
|
"config://res/translations/strings.de.po",
|
||||||
"config://res/translations/strings.en.po",
|
"config://res/translations/strings.en.po",
|
||||||
"config://res/core/messages.xml",
|
"config://res/translations/messages.de.po",
|
||||||
"config://res/eressea/strings.xml",
|
"config://res/translations/messages.en.po",
|
||||||
"config://res/eressea/spellinfo.xml",
|
"config://res/core/messages.xml"
|
||||||
"config://res/names-undead.xml",
|
|
||||||
"config://res/names-skeletons.xml",
|
|
||||||
"config://res/names-zombies.xml",
|
|
||||||
"config://res/names-ghouls.xml",
|
|
||||||
"config://res/names-dragons.xml"
|
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|
|
@ -1365,33 +1365,15 @@ static int parse_messages(xmlDocPtr doc)
|
||||||
}
|
}
|
||||||
|
|
||||||
propSection = xmlGetProp(node, BAD_CAST "section");
|
propSection = xmlGetProp(node, BAD_CAST "section");
|
||||||
if (propSection == NULL)
|
if (propSection == NULL) {
|
||||||
propSection = BAD_CAST default_section;
|
propSection = BAD_CAST default_section;
|
||||||
|
}
|
||||||
nrt_register(mtype, (const char *)propSection);
|
nrt_register(mtype, (const char *)propSection);
|
||||||
|
|
||||||
/* strings */
|
if (propSection != BAD_CAST default_section) {
|
||||||
xpath->node = node;
|
|
||||||
result = xmlXPathEvalExpression(BAD_CAST "text", xpath);
|
|
||||||
assert(result->nodesetval->nodeNr>0);
|
|
||||||
for (k = 0; k != result->nodesetval->nodeNr; ++k) {
|
|
||||||
xmlNodePtr node = result->nodesetval->nodeTab[k];
|
|
||||||
struct locale *lang;
|
|
||||||
xmlChar *propText;
|
|
||||||
|
|
||||||
xml_readtext(node, &lang, &propText);
|
|
||||||
if (lang) {
|
|
||||||
xml_cleanup_string(propText);
|
|
||||||
locale_setstring(lang, mtype->name, (const char *)propText);
|
|
||||||
}
|
|
||||||
xmlFree(propText);
|
|
||||||
|
|
||||||
}
|
|
||||||
xmlXPathFreeObject(result);
|
|
||||||
|
|
||||||
if (propSection != BAD_CAST default_section)
|
|
||||||
xmlFree(propSection);
|
xmlFree(propSection);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
xmlXPathFreeObject(messages);
|
xmlXPathFreeObject(messages);
|
||||||
|
|
||||||
|
@ -1399,78 +1381,6 @@ static int parse_messages(xmlDocPtr doc)
|
||||||
return results;
|
return results;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
xml_readstrings(xmlXPathContextPtr xpath, xmlNodePtr * nodeTab, int nodeNr,
|
|
||||||
bool names)
|
|
||||||
{
|
|
||||||
int i;
|
|
||||||
|
|
||||||
for (i = 0; i != nodeNr; ++i) {
|
|
||||||
xmlNodePtr stringNode = nodeTab[i];
|
|
||||||
xmlChar *propName = xmlGetProp(stringNode, BAD_CAST "name");
|
|
||||||
xmlChar *propNamespace = NULL;
|
|
||||||
xmlXPathObjectPtr result;
|
|
||||||
int k;
|
|
||||||
char zName[128];
|
|
||||||
|
|
||||||
assert(propName != NULL);
|
|
||||||
if (names)
|
|
||||||
propNamespace = xmlGetProp(stringNode->parent, BAD_CAST "name");
|
|
||||||
mkname_buf((const char *)propNamespace, (const char *)propName, zName);
|
|
||||||
if (propNamespace != NULL)
|
|
||||||
xmlFree(propNamespace);
|
|
||||||
xmlFree(propName);
|
|
||||||
|
|
||||||
/* strings */
|
|
||||||
xpath->node = stringNode;
|
|
||||||
result = xmlXPathEvalExpression(BAD_CAST "text", xpath);
|
|
||||||
for (k = 0; k != result->nodesetval->nodeNr; ++k) {
|
|
||||||
xmlNodePtr textNode = result->nodesetval->nodeTab[k];
|
|
||||||
struct locale *lang;
|
|
||||||
xmlChar *propText;
|
|
||||||
|
|
||||||
xml_readtext(textNode, &lang, &propText);
|
|
||||||
if (propText != NULL) {
|
|
||||||
assert(strcmp(zName,
|
|
||||||
(const char *)xml_cleanup_string(BAD_CAST zName)) == 0);
|
|
||||||
if (lang) {
|
|
||||||
xml_cleanup_string(propText);
|
|
||||||
locale_setstring(lang, zName, (const char *)propText);
|
|
||||||
}
|
|
||||||
xmlFree(propText);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
log_warning("string %s has no text in locale %s\n", zName, locale_name(lang));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
xmlXPathFreeObject(result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static int parse_strings(xmlDocPtr doc)
|
|
||||||
{
|
|
||||||
xmlXPathContextPtr xpath = xmlXPathNewContext(doc);
|
|
||||||
xmlXPathObjectPtr strings;
|
|
||||||
int results = 0;
|
|
||||||
|
|
||||||
/* reading eressea/strings/string */
|
|
||||||
strings = xmlXPathEvalExpression(BAD_CAST "/eressea/strings/string", xpath);
|
|
||||||
xml_readstrings(xpath, strings->nodesetval->nodeTab,
|
|
||||||
strings->nodesetval->nodeNr, false);
|
|
||||||
results += strings->nodesetval->nodeNr;
|
|
||||||
xmlXPathFreeObject(strings);
|
|
||||||
|
|
||||||
strings =
|
|
||||||
xmlXPathEvalExpression(BAD_CAST "/eressea/strings/namespace/string", xpath);
|
|
||||||
xml_readstrings(xpath, strings->nodesetval->nodeTab,
|
|
||||||
strings->nodesetval->nodeNr, true);
|
|
||||||
results += strings->nodesetval->nodeNr;
|
|
||||||
xmlXPathFreeObject(strings);
|
|
||||||
|
|
||||||
xmlXPathFreeContext(xpath);
|
|
||||||
return results;
|
|
||||||
}
|
|
||||||
|
|
||||||
void register_xmlreader(void)
|
void register_xmlreader(void)
|
||||||
{
|
{
|
||||||
xml_register_callback(parse_races);
|
xml_register_callback(parse_races);
|
||||||
|
@ -1482,6 +1392,5 @@ void register_xmlreader(void)
|
||||||
xml_register_callback(parse_spellbooks); /* requires spells */
|
xml_register_callback(parse_spellbooks); /* requires spells */
|
||||||
xml_register_callback(parse_spells); /* requires resources */
|
xml_register_callback(parse_spells); /* requires resources */
|
||||||
|
|
||||||
xml_register_callback(parse_strings);
|
|
||||||
xml_register_callback(parse_messages);
|
xml_register_callback(parse_messages);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue