apply USE_LIBXML consistently, so tests can be built without libxml2

This commit is contained in:
Enno Rehling 2014-06-09 20:14:08 -07:00
parent a10ccac64b
commit 3dda5d3033
8 changed files with 22 additions and 24 deletions

View file

@ -68,8 +68,6 @@ without prior permission by the authors of Eressea.
#include <util/nrmessage.h>
#include <quicklist.h>
#include <libxml/encoding.h>
/* libc includes */
#include <assert.h>
#include <errno.h>
@ -1470,7 +1468,6 @@ report_computer(const char *filename, report_context * ctx, const char *charset)
#if SCORE_MODULE
int score = 0, avgscore = 0;
#endif
int enc = xmlParseCharEncoding(charset);
FILE *F = fopen(filename, "wt");
if (era < 0) {
@ -1479,7 +1476,7 @@ report_computer(const char *filename, report_context * ctx, const char *charset)
if (F == NULL) {
perror(filename);
return -1;
} else if (enc == XML_CHAR_ENCODING_UTF8) {
} else if (_strcmpl(charset, "utf-8")==0 || _strcmpl(charset, "utf8")==0) {
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
fwrite(utf8_bom, 1, 3, F);
}

View file

@ -59,14 +59,13 @@
#include <util/console.h>
#include <util/listbox.h>
#include <libxml/encoding.h>
#include <storage.h>
#include <lua.h>
#include <assert.h>
#include <string.h>
#include <locale.h>
#include <stdlib.h>
#include <string.h>
static int g_quit;
int force_color = 0;

View file

@ -58,8 +58,9 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <critbit.h>
#include <util/crmessage.h>
#include <util/event.h>
#include <util/functions.h>
#include <util/language.h>
#include <util/filereader.h>
#include <util/functions.h>
#include <util/log.h>
#include <util/lists.h>
#include <util/parser.h>
@ -72,9 +73,11 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <util/umlaut.h>
#include <util/xml.h>
#ifdef USE_LIBXML2
/* libxml includes */
#include <libxml/tree.h>
#include <libxml/xpath.h>
#endif
/* external libraries */
#include <iniparser.h>
@ -3139,8 +3142,9 @@ void load_inifile(dictionary * d)
lomem = iniparser_getint(d, "eressea:lomem", lomem) ? 1 : 0;
str = iniparser_getstring(d, "eressea:encoding", NULL);
if (str)
enc_gamedata = xmlParseCharEncoding(str);
if (str && (_strcmpl(str, "utf8")==0 || _strcmpl(str, "utf-8")==0)) {
enc_gamedata = ENCODING_UTF8;
}
verbosity = iniparser_getint(d, "eressea:verbose", 2);
sqlpatch = iniparser_getint(d, "eressea:sqlpatch", false);

View file

@ -73,8 +73,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <storage.h>
#include <binarystore.h>
#include <libxml/encoding.h>
/* libc includes */
#include <string.h>
#include <errno.h>
@ -92,7 +90,7 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
/* exported symbols symbols */
const char *game_name = "eressea";
int firstx = 0, firsty = 0;
int enc_gamedata = XML_CHAR_ENCODING_UTF8;
int enc_gamedata = ENCODING_UTF8;
/* local symbols */
static region *current_region;

View file

@ -82,8 +82,6 @@ OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
#include <quicklist.h>
#include <util/rng.h>
#include <libxml/encoding.h>
/* libc includes */
#include <assert.h>
#include <ctype.h>
@ -1472,15 +1470,14 @@ report_template(const char *filename, report_context * ctx, const char *charset)
char buf[8192], *bufp;
size_t size;
int bytes;
int enc = xmlParseCharEncoding(charset);
bool utf8 = _strcmpl(charset, "utf8")==0 || _strcmpl(charset, "utf-8")==0;
if (F == NULL) {
perror(filename);
return -1;
}
if (enc == XML_CHAR_ENCODING_UTF8) {
if (utf8) {
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
fwrite(utf8_bom, 1, 3, F);
}
@ -2106,7 +2103,7 @@ report_plaintext(const char *filename, report_context * ctx,
seen_region *sr = NULL;
char buf[8192];
char *bufp;
int enc = xmlParseCharEncoding(charset);
bool utf8 = _strcmpl(charset, "utf8")==0 || _strcmpl(charset, "utf-8")==0;
size_t size;
/* static variables can cope with writing for different turns */
@ -2126,7 +2123,7 @@ report_plaintext(const char *filename, report_context * ctx,
perror(filename);
return -1;
}
if (enc == XML_CHAR_ENCODING_UTF8) {
if (utf8) {
const unsigned char utf8_bom[4] = { 0xef, 0xbb, 0xbf, 0 };
fwrite(utf8_bom, 1, 3, F);
}

View file

@ -4,8 +4,6 @@
#include <util/log.h>
#include <util/unicode.h>
#include <libxml/encoding.h>
#include <ctype.h>
#include <wctype.h>
@ -322,7 +320,7 @@ static const char *getbuf_utf8(FILE * F)
const char *getbuf(FILE * F, int encoding)
{
if (encoding == XML_CHAR_ENCODING_UTF8)
if (encoding == ENCODING_UTF8)
return getbuf_utf8(F);
return getbuf_latin1(F);
}

View file

@ -15,6 +15,9 @@
extern "C" {
#endif
#define ENCODING_UTF8 0
#define ENCODING_LATIN1 1
const char *getbuf(FILE *, int encoding);
#ifdef __cplusplus

View file

@ -15,8 +15,10 @@
/* util includes */
#include "log.h"
#ifdef USE_LIBXML2
#include <libxml/catalog.h>
#include <libxml/xmlstring.h>
#endif
/* libc includes */
#include <assert.h>
@ -25,6 +27,7 @@
#include <string.h>
#include <ctype.h>
#ifdef USE_LIBXML2
const xmlChar *xml_i(double number)
{
static char buffer[128];
@ -85,7 +88,6 @@ double xml_fvalue(xmlNodePtr node, const char *name, double dflt)
#include <libxml/parser.h>
#include <libxml/xinclude.h>
#ifdef USE_LIBXML2
typedef struct xml_reader {
struct xml_reader *next;
xml_callback callback;