blob: 19df427af07be5f6d3a0c8be22625037ead89d15 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
#ifndef XMLSTRINGREADER
#define XMLSTRINGREADER
#include <stdio.h>
#include "xmlreader.h"
#include "flexbuf.h"
/**
* Takes care of reading in xml formatted data from a file. This could/should
* be made more arbitrary in the future so that we can read the data from any
* source. This is actually made quite simple already since all data read in
* is handled by one single helper function and then palced into a FlexBuf for
* easy access by the other functions. The FlexBuf also allows for block
* reading from disk, which improves speed by a noticable amount.
* <br>
* There are also some extra features implemented that allow you to break the
* standard XML reader specs and eliminate leading and trailing whitespace in
* all read content. This is useful in situations where you allow additional
* whitespace in the files to make them easily human readable. The resturned
* content will be NULL in sitautions where all content between nodes was
* stripped.
*@author Mike Buland
*/
class XmlStringReader : public XmlReader
{
public:
/**
* Create a new string reader around an already created and formatted
* null-terminated string.
*@param sString A pointer to the string data that will be used. This data
* is not changed during processing.
*@param bStrip Strip out leading and trailing whitespace.
*/
XmlStringReader( const char *sString, bool bStrip=false );
/**
* Destroy this string reader.
*/
~XmlStringReader();
private:
char getChar( int nIndex = 0 );
void usedChar( int nAmnt = 1 );
const char *sString; /**< Internal pointer to the input string. */
int nIndex; /**< Our index into the string */
int nLength; /**< The computed length of the string */
};
#endif
|