2016-02-27 11:57:10 +02:00
|
|
|
#ifndef _XML_COMMON_HPP_
|
|
|
|
#define _XML_COMMON_HPP_
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
#include "ModBase.hpp"
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
2016-04-02 11:04:28 +03:00
|
|
|
#include <cassert>
|
2016-02-27 11:57:10 +02:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
#include <pugixml.hpp>
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
extern "C" {
|
|
|
|
struct SQVM;
|
|
|
|
typedef struct SQVM* HSQUIRRELVM;
|
|
|
|
} /*extern "C"*/
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
namespace SqMod {
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* SOFTWARE INFORMATION
|
|
|
|
*/
|
|
|
|
#define SQXML_NAME "Squirrel XML Module"
|
|
|
|
#define SQXML_AUTHOR "Sandu Liviu Catalin (S.L.C)"
|
|
|
|
#define SQXML_COPYRIGHT "Copyright (C) 2016 Sandu Liviu Catalin"
|
|
|
|
#define SQXML_HOST_NAME "SqModXMLHost"
|
|
|
|
#define SQXML_VERSION 001
|
|
|
|
#define SQXML_VERSION_STR "0.0.1"
|
|
|
|
#define SQXML_VERSION_MAJOR 0
|
|
|
|
#define SQXML_VERSION_MINOR 0
|
|
|
|
#define SQXML_VERSION_PATCH 1
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
using namespace pugi;
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
class Node;
|
|
|
|
class Text;
|
|
|
|
class Document;
|
|
|
|
class Attribute;
|
|
|
|
class XPathNode;
|
|
|
|
class XPathNodeSet;
|
|
|
|
class XPathVariable;
|
|
|
|
class XPathVariableSet;
|
|
|
|
class XPathVariableQuery;
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the temporary buffer.
|
|
|
|
*/
|
|
|
|
SStr GetTempBuff();
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the size of the temporary buffer.
|
|
|
|
*/
|
|
|
|
Uint32 GetTempBuffSize();
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Throw a formatted exception.
|
|
|
|
*/
|
|
|
|
void SqThrowF(CSStr str, ...);
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Generate a formatted string.
|
|
|
|
*/
|
|
|
|
CSStr FmtStr(CSStr str, ...);
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Implements RAII to restore the VM stack to it's initial size on function exit.
|
|
|
|
*/
|
|
|
|
struct StackGuard
|
|
|
|
{
|
2016-04-02 11:04:28 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Default constructor.
|
|
|
|
*/
|
|
|
|
StackGuard();
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Base constructor.
|
|
|
|
*/
|
|
|
|
StackGuard(HSQUIRRELVM vm);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Destructor.
|
|
|
|
*/
|
|
|
|
~StackGuard();
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy constructor.
|
|
|
|
*/
|
|
|
|
StackGuard(const StackGuard &);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move constructor.
|
|
|
|
*/
|
|
|
|
StackGuard(StackGuard &&);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy assignment operator.
|
|
|
|
*/
|
|
|
|
StackGuard & operator = (const StackGuard &);
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move assignment operator.
|
|
|
|
*/
|
|
|
|
StackGuard & operator = (StackGuard &&);
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
2016-04-02 11:04:28 +03:00
|
|
|
HSQUIRRELVM m_VM; // The VM where the stack should be restored.
|
|
|
|
Int32 m_Top; // The top of the stack when this instance was created.
|
2016-02-28 17:39:26 +02:00
|
|
|
};
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Manages a reference counted xml document instance.
|
|
|
|
*/
|
|
|
|
class DocumentRef
|
|
|
|
{
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
friend class Document;
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
typedef xml_document Type; /* The managed type. */
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
typedef Type* Pointer; /* Pointer to the managed type. */
|
|
|
|
typedef const Type* ConstPtr; /* Constant pointer to the managed type. */
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
typedef Type& Reference; /* Reference to the managed type. */
|
|
|
|
typedef const Type& ConstRef; /* Constant reference to the managed type. */
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
typedef unsigned int Counter; /* Reference counter type. */
|
|
|
|
|
2016-04-02 11:04:28 +03:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Validate the managed handle and throw exception if invalid.
|
|
|
|
*/
|
|
|
|
void Validate() const;
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
private:
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
Pointer m_Ptr; /* The document reader, writer and manager instance. */
|
|
|
|
Counter* m_Ref; /* Reference count to the managed instance. */
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Grab a strong reference to a document instance.
|
|
|
|
*/
|
|
|
|
void Grab()
|
|
|
|
{
|
|
|
|
if (m_Ptr)
|
|
|
|
++(*m_Ref);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Drop a strong reference to a document instance.
|
|
|
|
*/
|
|
|
|
void Drop()
|
|
|
|
{
|
|
|
|
if (m_Ptr && --(*m_Ref) == 0)
|
|
|
|
{
|
|
|
|
delete m_Ptr;
|
|
|
|
delete m_Ref;
|
|
|
|
m_Ptr = NULL;
|
|
|
|
m_Ref = NULL;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Base constructor.
|
|
|
|
*/
|
|
|
|
DocumentRef(VoidP /* unused */)
|
|
|
|
: m_Ptr(new Type())
|
|
|
|
, m_Ref(new Counter(1))
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Default constructor (null).
|
|
|
|
*/
|
|
|
|
DocumentRef()
|
|
|
|
: m_Ptr(NULL), m_Ref(NULL)
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy constructor.
|
|
|
|
*/
|
|
|
|
DocumentRef(const DocumentRef & o)
|
|
|
|
: m_Ptr(o.m_Ptr), m_Ref(o.m_Ref)
|
|
|
|
|
|
|
|
{
|
|
|
|
Grab();
|
|
|
|
}
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move constructor.
|
|
|
|
*/
|
|
|
|
DocumentRef(DocumentRef && o)
|
|
|
|
: m_Ptr(o.m_Ptr), m_Ref(o.m_Ref)
|
|
|
|
{
|
|
|
|
o.m_Ptr = NULL;
|
|
|
|
o.m_Ref = NULL;
|
|
|
|
}
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Destructor.
|
|
|
|
*/
|
|
|
|
~DocumentRef()
|
|
|
|
{
|
|
|
|
Drop();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy assignment operator.
|
|
|
|
*/
|
|
|
|
DocumentRef & operator = (const DocumentRef & o)
|
|
|
|
{
|
|
|
|
if (m_Ptr != o.m_Ptr)
|
|
|
|
{
|
|
|
|
Drop();
|
|
|
|
m_Ptr = o.m_Ptr;
|
|
|
|
m_Ref = o.m_Ref;
|
|
|
|
Grab();
|
|
|
|
}
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Move assignment operator.
|
|
|
|
*/
|
|
|
|
DocumentRef & operator = (DocumentRef && o)
|
|
|
|
{
|
|
|
|
if (m_Ptr != o.m_Ptr)
|
|
|
|
{
|
|
|
|
m_Ptr = o.m_Ptr;
|
|
|
|
m_Ref = o.m_Ref;
|
|
|
|
o.m_Ptr = NULL;
|
|
|
|
o.m_Ref = NULL;
|
|
|
|
}
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Perform an equality comparison between two document instances.
|
|
|
|
*/
|
|
|
|
bool operator == (const DocumentRef & o) const
|
|
|
|
{
|
|
|
|
return (m_Ptr == o.m_Ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Perform an inequality comparison between two document instances.
|
|
|
|
*/
|
|
|
|
bool operator != (const DocumentRef & o) const
|
|
|
|
{
|
|
|
|
return (m_Ptr != o.m_Ptr);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Implicit conversion to boolean for use in boolean operations.
|
|
|
|
*/
|
|
|
|
operator bool () const
|
|
|
|
{
|
|
|
|
return m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Implicit conversion to the managed instance pointer.
|
|
|
|
*/
|
|
|
|
operator Pointer ()
|
|
|
|
{
|
|
|
|
return m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Implicit conversion to the managed instance pointer.
|
|
|
|
*/
|
|
|
|
operator ConstPtr () const
|
|
|
|
{
|
|
|
|
return m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Implicit conversion to the managed instance reference.
|
|
|
|
*/
|
|
|
|
operator Reference ()
|
|
|
|
{
|
|
|
|
assert(m_Ptr);
|
|
|
|
return *m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Implicit conversion to the managed instance reference.
|
|
|
|
*/
|
|
|
|
operator ConstRef () const
|
|
|
|
{
|
|
|
|
assert(m_Ptr);
|
|
|
|
return *m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Member operator for dereferencing the managed pointer.
|
|
|
|
*/
|
|
|
|
Pointer operator -> () const
|
|
|
|
{
|
2016-02-28 17:39:26 +02:00
|
|
|
assert(m_Ptr);
|
2016-02-27 11:57:10 +02:00
|
|
|
return m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Indirection operator for obtaining a reference of the managed pointer.
|
|
|
|
*/
|
|
|
|
Reference operator * () const
|
|
|
|
{
|
2016-02-28 17:39:26 +02:00
|
|
|
assert(m_Ptr);
|
2016-02-27 11:57:10 +02:00
|
|
|
return *m_Ptr;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve the number of active references to the managed instance.
|
|
|
|
*/
|
|
|
|
Counter Count() const
|
|
|
|
{
|
|
|
|
return (m_Ptr && m_Ref) ? (*m_Ref) : 0;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------------------------------------
|
|
|
|
* Allows the user to inspect the result of certain operations and act accordingly.
|
|
|
|
*/
|
|
|
|
class ParseResult
|
|
|
|
{
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
friend class Document;
|
|
|
|
friend class Node;
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
|
|
|
// --------------------------------------------------------------------------------------------
|
|
|
|
typedef xml_parse_result Result;
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Explicit constructor.
|
|
|
|
*/
|
|
|
|
ParseResult(const DocumentRef doc, const Result & result)
|
|
|
|
: m_Doc(doc), m_Result(result)
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Validate the document reference and throw an error if invalid.
|
|
|
|
*/
|
2016-02-28 17:39:26 +02:00
|
|
|
void Validate() const;
|
2016-02-27 11:57:10 +02:00
|
|
|
|
|
|
|
private:
|
|
|
|
|
|
|
|
// ---------------------------------------------------------------------------------------------
|
2016-02-28 17:39:26 +02:00
|
|
|
DocumentRef m_Doc; /* The main xml document instance. */
|
|
|
|
Result m_Result; /* The managed parse result. */
|
2016-02-27 11:57:10 +02:00
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Default constructor.
|
|
|
|
*/
|
|
|
|
ParseResult()
|
|
|
|
: m_Doc(), m_Result()
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy constructor. (disabled)
|
|
|
|
*/
|
|
|
|
ParseResult(const ParseResult & o)
|
|
|
|
: m_Doc(o.m_Doc), m_Result(o.m_Result)
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Destructor.
|
|
|
|
*/
|
|
|
|
~ParseResult()
|
|
|
|
{
|
|
|
|
/* ... */
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Copy assignment operator. (disabled)
|
|
|
|
*/
|
|
|
|
ParseResult & operator = (const ParseResult & o)
|
|
|
|
{
|
|
|
|
m_Doc = o.m_Doc;
|
|
|
|
m_Result = o.m_Result;
|
|
|
|
return *this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to compare two instances of this type.
|
|
|
|
*/
|
|
|
|
Int32 Cmp(const ParseResult & o)
|
|
|
|
{
|
|
|
|
if (m_Result.status == o.m_Result.status)
|
|
|
|
return 0;
|
|
|
|
else if (m_Result.status > o.m_Result.status)
|
|
|
|
return 1;
|
|
|
|
else
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to convert an instance of this type to a string.
|
|
|
|
*/
|
|
|
|
CSStr ToString() const
|
|
|
|
{
|
|
|
|
return m_Result.description();
|
|
|
|
}
|
|
|
|
|
2016-02-28 17:39:26 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Used by the script engine to retrieve the name from instances of this type.
|
|
|
|
*/
|
|
|
|
static SQInteger Typename(HSQUIRRELVM vm);
|
|
|
|
|
2016-02-27 11:57:10 +02:00
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* See whether this instance references a valid xml document.
|
|
|
|
*/
|
|
|
|
bool IsValid() const
|
|
|
|
{
|
|
|
|
return m_Doc;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Return the number of active references to this document instance.
|
|
|
|
*/
|
|
|
|
Uint32 GetRefCount() const
|
|
|
|
{
|
|
|
|
return m_Doc.Count();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Cast to bool operator.
|
|
|
|
*/
|
|
|
|
bool IsOk() const
|
|
|
|
{
|
|
|
|
return m_Result;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Parsing status code.
|
|
|
|
*/
|
|
|
|
Int32 GetStatus() const
|
|
|
|
{
|
|
|
|
return (Int32)m_Result.status;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Last parsed offset. (in char_t units from start of input data)
|
|
|
|
*/
|
|
|
|
SQInteger GetOffset() const
|
|
|
|
{
|
|
|
|
return (SQInteger)m_Result.offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Source document encoding.
|
|
|
|
*/
|
|
|
|
Int32 GetEncoding() const
|
|
|
|
{
|
|
|
|
return m_Result.encoding;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Retrieve error description as a string.
|
|
|
|
*/
|
|
|
|
CSStr GetDescription() const
|
|
|
|
{
|
|
|
|
return m_Result.description();
|
|
|
|
}
|
|
|
|
|
|
|
|
/* --------------------------------------------------------------------------------------------
|
|
|
|
* Check the parse result and throw the necessary errors.
|
|
|
|
*/
|
|
|
|
void Check() const;
|
|
|
|
};
|
|
|
|
|
|
|
|
} // Namespace:: SqMod
|
|
|
|
|
|
|
|
#endif // _XML_COMMON_HPP_
|