5#ifndef __IRR_XML_H_INCLUDED__
6#define __IRR_XML_H_INCLUDED__
225 virtual int read(
void* buffer,
int sizeToRead) = 0;
274 template<
class char_type,
class super_
class>
370 template <
typename T>
376 xmlChar<T>(
wchar_t in) :
c(static_cast<T>(in)) {}
377#if defined(__BORLANDC__)
380 xmlChar<T>(
unsigned char in) :
c(static_cast<T>(in)) {}
381 xmlChar<T>(
unsigned short in) :
c(static_cast<T>(in)) {}
382 xmlChar<T>(
unsigned int in) :
c(static_cast<T>(in)) {}
383 xmlChar<T>(
unsigned long in) :
c(static_cast<T>(in)) {}
385 explicit xmlChar<T>(
unsigned char in) :
c(static_cast<T>(in)) {}
386 explicit xmlChar<T>(
unsigned short in) :
c(static_cast<T>(in)) {}
387 explicit xmlChar<T>(
unsigned int in) :
c(static_cast<T>(in)) {}
388 explicit xmlChar<T>(
unsigned long in) :
c(static_cast<T>(in)) {}
390 operator T()
const {
return c; }
466 bool deleteCallback =
false);
506 bool deleteCallback =
false);
547 bool deleteCallback =
false);
#define IRRLICHT_API
Set FPU settings.
Callback class for file read abstraction.
virtual ~IFileReadCallBack()
Destructor.
virtual long getSize() const =0
Returns size of file in bytes.
virtual int read(void *buffer, int sizeToRead)=0
Reads an amount of bytes from the file.
Interface providing easy read access to a XML file.
virtual ETEXT_FORMAT getSourceFormat() const =0
Returns format of the source xml file.
virtual bool read()=0
Reads forward to the next xml node.
virtual float getAttributeValueAsFloat(const char_type *name) const =0
Returns the value of an attribute as float.
virtual EXML_NODE getNodeType() const =0
Returns the type of the current XML node.
virtual const char_type * getAttributeValueSafe(const char_type *name) const =0
Returns the value of an attribute in a safe way.
virtual float getAttributeValueAsFloat(int idx) const =0
Returns the value of an attribute as float.
virtual bool isEmptyElement() const =0
Returns if an element is an empty element, like <foo />
virtual const char_type * getNodeName() const =0
Returns the name of the current node.
virtual int getAttributeValueAsInt(int idx) const =0
Returns the value of an attribute as integer.
virtual unsigned int getAttributeCount() const =0
Returns attribute count of the current XML node.
virtual ETEXT_FORMAT getParserFormat() const =0
Returns format of the strings returned by the parser.
virtual const char_type * getAttributeValue(const char_type *name) const =0
Returns the value of an attribute.
virtual const char_type * getAttributeName(int idx) const =0
Returns name of an attribute.
virtual int getAttributeValueAsInt(const char_type *name) const =0
Returns the value of an attribute as integer.
virtual const char_type * getAttributeValue(int idx) const =0
Returns the value of an attribute.
virtual ~IIrrXMLReader()
Destructor.
virtual const char_type * getNodeData() const =0
Returns data of the current node.
Empty class to be used as parent class for IrrXMLReader.
IIrrXMLReader< char, IXMLBase > IrrXMLReader
A UTF-8 or ASCII character xml parser.
IRRLICHT_API IrrXMLReaderUTF16 *IRRCALLCONV createIrrXMLReaderUTF16(const char *filename)
Creates an instance of an UFT-16 xml parser.
IIrrXMLReader< char16, IXMLBase > IrrXMLReaderUTF16
A UTF-16 xml parser.
IRRLICHT_API IrrXMLReader *IRRCALLCONV createIrrXMLReader(const char *filename)
Creates an instance of an UFT-8 or ASCII character xml parser.
IRRLICHT_API IrrXMLReaderUTF32 *IRRCALLCONV createIrrXMLReaderUTF32(const char *filename)
Creates an instance of an UFT-32 xml parser.
IIrrXMLReader< char32, IXMLBase > IrrXMLReaderUTF32
A UTF-32 xml parser.
EXML_NODE
Enumeration for all xml nodes which are parsed by IrrXMLReader.
@ EXN_ELEMENT_END
End of an xml element such as </foo>.
@ EXN_ELEMENT
An xml element such as <foo>.
@ EXN_NONE
No xml node. This is usually the node if you did not read anything yet.
@ EXN_CDATA
An xml cdata section like <![CDATA[ this is some CDATA ]]>.
@ EXN_COMMENT
An xml comment like <!– I am a comment –> or a DTD definition.
@ EXN_UNKNOWN
Unknown element.
xmlChar< unsigned short > char16
defines the utf-16 type.
ETEXT_FORMAT
Enumeration of all supported source text file formats.
@ ETF_UTF32_LE
UTF-32 format, little endian.
@ ETF_UTF16_LE
UTF-16 format, little endian.
@ ETF_UTF16_BE
UTF-16 format, big endian.
@ ETF_UTF32_BE
UTF-32 format, big endian.
@ ETF_ASCII
ASCII, file without byte order mark, or not a text file.
xmlChar< unsigned int > char32
defines the utf-32 type.
Everything in the Irrlicht Engine can be found in this namespace.