2011-09-27 22:25:35 +02:00
|
|
|
/* $Id: minixml.h,v 1.6 2006/11/30 11:47:21 nanard Exp $ */
|
|
|
|
/* 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.
|
|
|
|
* */
|
2012-09-20 17:52:51 -03:00
|
|
|
#ifndef MINIXML_H_INCLUDED
|
|
|
|
#define MINIXML_H_INCLUDED
|
2018-06-18 23:35:59 +03:00
|
|
|
#define IS_WHITE_SPACE(c) ((c)==' ' || (c)=='\t' || (c)=='\r' || (c)=='\n')
|
2011-09-27 22:25:35 +02: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
|
|
|
|
|