2019-04-23 13:23:07 +02:00
|
|
|
/* $Id: minixml.h,v 1.8 2019/02/10 12:29:25 nanard Exp $ */
|
2014-11-07 12:32:20 +01:00
|
|
|
/* minimal xml parser
|
|
|
|
*
|
|
|
|
* Project : miniupnp
|
|
|
|
* Website : http://miniupnp.free.fr/
|
|
|
|
* Author : Thomas Bernard
|
|
|
|
* Copyright (c) 2005 Thomas Bernard
|
|
|
|
* This software is subject to the conditions detailed in the
|
|
|
|
* LICENCE file provided in this distribution.
|
|
|
|
* */
|
|
|
|
#ifndef MINIXML_H_INCLUDED
|
|
|
|
#define MINIXML_H_INCLUDED
|
2019-04-23 13:23:07 +02:00
|
|
|
#define IS_WHITE_SPACE(c) ((c)==' ' || (c)=='\t' || (c)=='\r' || (c)=='\n')
|
2014-11-07 12:32:20 +01:00
|
|
|
|
|
|
|
/* if a callback function pointer is set to NULL,
|
|
|
|
* the function is not called */
|
|
|
|
struct xmlparser {
|
|
|
|
const char *xmlstart;
|
|
|
|
const char *xmlend;
|
|
|
|
const char *xml; /* pointer to current character */
|
|
|
|
int xmlsize;
|
|
|
|
void * data;
|
|
|
|
void (*starteltfunc) (void *, const char *, int);
|
|
|
|
void (*endeltfunc) (void *, const char *, int);
|
|
|
|
void (*datafunc) (void *, const char *, int);
|
|
|
|
void (*attfunc) (void *, const char *, int, const char *, int);
|
|
|
|
};
|
|
|
|
|
|
|
|
/* parsexml()
|
|
|
|
* the xmlparser structure must be initialized before the call
|
|
|
|
* the following structure members have to be initialized :
|
|
|
|
* xmlstart, xmlsize, data, *func
|
|
|
|
* xml is for internal usage, xmlend is computed automatically */
|
|
|
|
void parsexml(struct xmlparser *);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|