mirror of
https://github.com/pocoproject/poco.git
synced 2025-10-24 09:12:28 +02:00
remove serializer part
This commit is contained in:
@@ -25,12 +25,6 @@ else()
|
|||||||
)
|
)
|
||||||
endif (POCO_UNBUNDLED)
|
endif (POCO_UNBUNDLED)
|
||||||
|
|
||||||
# GENX lib
|
|
||||||
POCO_SOURCES( SRCS genx
|
|
||||||
src/genx.c
|
|
||||||
src/char-props.c
|
|
||||||
)
|
|
||||||
|
|
||||||
if(WIN32)
|
if(WIN32)
|
||||||
#TODO: Is XML_STATIC only required with Windows? What does it do?
|
#TODO: Is XML_STATIC only required with Windows? What does it do?
|
||||||
add_definitions(-DXML_STATIC -DXML_NS -DXML_DTD -DHAVE_EXPAT_CONFIG_H)
|
add_definitions(-DXML_STATIC -DXML_NS -DXML_DTD -DHAVE_EXPAT_CONFIG_H)
|
||||||
|
@@ -23,7 +23,7 @@ objects = AbstractContainerNode AbstractNode Attr AttrMap Attributes \
|
|||||||
ParserEngine ProcessingInstruction QName SAXException SAXParser Text \
|
ParserEngine ProcessingInstruction QName SAXException SAXParser Text \
|
||||||
TreeWalker WhitespaceFilter XMLException XMLFilter XMLFilterImpl XMLReader \
|
TreeWalker WhitespaceFilter XMLException XMLFilter XMLFilterImpl XMLReader \
|
||||||
XMLString XMLWriter XMLStreamParser XMLStreamParserException XMLStreamSerializer \
|
XMLString XMLWriter XMLStreamParser XMLStreamParserException XMLStreamSerializer \
|
||||||
XMLStreamSerializerException char-props genx
|
XMLStreamSerializerException
|
||||||
|
|
||||||
expat_objects = xmlparse xmlrole xmltok
|
expat_objects = xmlparse xmlrole xmltok
|
||||||
|
|
||||||
|
@@ -22,7 +22,6 @@
|
|||||||
|
|
||||||
|
|
||||||
#include "XMLStreamParserException.h"
|
#include "XMLStreamParserException.h"
|
||||||
#include "XMLStreamSerializerException.h"
|
|
||||||
#include <string>
|
#include <string>
|
||||||
#include <cstddef> // std::size_t
|
#include <cstddef> // std::size_t
|
||||||
#include <iostream>
|
#include <iostream>
|
||||||
@@ -100,16 +99,6 @@ T default_value_traits<T>::parse(std::string s, const XMLStreamParser& p)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
std::string default_value_traits<T>::serialize(const T& v, const XMLStreamSerializer& s)
|
|
||||||
{
|
|
||||||
std::ostringstream os;
|
|
||||||
if (!(os << v))
|
|
||||||
throw XMLStreamSerializerException(s, "invalid value");
|
|
||||||
return os.str();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,389 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializer.h
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// Library: XML
|
|
||||||
// Package: XML
|
|
||||||
// Module: XMLStreamSerializer
|
|
||||||
//
|
|
||||||
// Definition of the XMLStreamSerializer class.
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2015, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
// copyright : Copyright (c) 2013-2014 Code Synthesis Tools CC
|
|
||||||
// license : MIT; see accompanying LICENSE file
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef POCO_XML_XMLSERIALIZER_Included
|
|
||||||
#define POCO_XML_XMLSERIALIZER_Included
|
|
||||||
|
|
||||||
|
|
||||||
#include "QName.h"
|
|
||||||
#include "ValueTraits.h"
|
|
||||||
#include "genx.h"
|
|
||||||
#include <string>
|
|
||||||
#include <ostream>
|
|
||||||
#include <cstddef> // std::size_t
|
|
||||||
|
|
||||||
|
|
||||||
namespace Poco
|
|
||||||
{
|
|
||||||
namespace XML
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
class XML_API XMLStreamSerializer
|
|
||||||
/// see: http://www.codesynthesis.com/projects/libstudxml/doc/intro.xhtml
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
XMLStreamSerializer(std::ostream&, const std::string& output_name, unsigned short indentation = 2);
|
|
||||||
/// Serialize to std::ostream. Output name is used in diagnostics to
|
|
||||||
/// identify the document being serialized. The indentation argument
|
|
||||||
/// specifies the number of indentation spaces that should be used for
|
|
||||||
/// pretty-printing. If 0 is passed, no pretty-printing is performed.
|
|
||||||
///
|
|
||||||
/// If stream exceptions are enabled then std::ios_base::failure
|
|
||||||
/// exception is used to report io errors (badbit and failbit).
|
|
||||||
/// Otherwise, those are reported as the XMLStreamSerializerException exception.
|
|
||||||
|
|
||||||
~XMLStreamSerializer();
|
|
||||||
|
|
||||||
const std::string& outputName() const;
|
|
||||||
void startElement(const QName& qname);
|
|
||||||
void startElement(const std::string& name);
|
|
||||||
void startElement(const std::string& ns, const std::string& name);
|
|
||||||
|
|
||||||
void endElement();
|
|
||||||
|
|
||||||
// "Checked" end element. That is, it checks that the element
|
|
||||||
// you think you are ending matches the current one.
|
|
||||||
//
|
|
||||||
void endElement (const QName& qname);
|
|
||||||
void endElement (const std::string& name);
|
|
||||||
void endElement (const std::string& ns, const std::string& name);
|
|
||||||
|
|
||||||
// Helpers for serializing elements with simple content. The first two
|
|
||||||
// functions assume that startElement() has already been called. The
|
|
||||||
// other two serialize the complete element, from start to end.
|
|
||||||
|
|
||||||
void element(const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void element(const T& value);
|
|
||||||
void element(const std::string& name, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void element(const std::string& name, const T& value);
|
|
||||||
void element(const QName& qname, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void element(const QName& qname, const T& value);
|
|
||||||
void element(const std::string& namespace_, const std::string& name, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void element(const std::string& namespace_, const std::string& name, const T& value);
|
|
||||||
|
|
||||||
// Attributes.
|
|
||||||
//
|
|
||||||
void startAttribute(const QName& qname);
|
|
||||||
void startAttribute(const std::string& name);
|
|
||||||
void startAttribute(const std::string& ns, const std::string& name);
|
|
||||||
|
|
||||||
void endAttribute();
|
|
||||||
// "Checked" end attribute. That is, it checks that the attribute
|
|
||||||
// you think you are ending matches the current one.
|
|
||||||
//
|
|
||||||
void endAttribute (const QName& qname);
|
|
||||||
|
|
||||||
void endAttribute (const std::string& name);
|
|
||||||
|
|
||||||
void endAttribute (const std::string& ns, const std::string& name);
|
|
||||||
|
|
||||||
void attribute(const QName& qname, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void attribute(const QName& qname, const T& value);
|
|
||||||
void attribute(const std::string& name, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void attribute(const std::string& name, const T& value);
|
|
||||||
void attribute(const std::string& ns, const std::string& name, const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void attribute(const std::string& ns, const std::string& name, const T& value);
|
|
||||||
|
|
||||||
// Characters.
|
|
||||||
//
|
|
||||||
void characters(const std::string& value);
|
|
||||||
template<typename T>
|
|
||||||
void characters(const T& value);
|
|
||||||
|
|
||||||
void namespaceDecl(const std::string& ns, const std::string& prefix);
|
|
||||||
/// Namespaces declaration. If prefix is empty, then the default
|
|
||||||
/// namespace is declared. If both prefix and namespace are empty,
|
|
||||||
/// then the default namespace declaration is cleared (xmlns="").
|
|
||||||
/// This function should be called after start_element().
|
|
||||||
|
|
||||||
void xmlDecl(const std::string& version = "1.0", const std::string& encoding = "UTF-8", const std::string& standalone = "");
|
|
||||||
/// XML declaration. If encoding or standalone are not specified,
|
|
||||||
/// then these attributes are omitted from the output.
|
|
||||||
|
|
||||||
// DOCTYPE declaration. If encoding or standalone are not specified,
|
|
||||||
// then these attributes are omitted from the output.
|
|
||||||
//
|
|
||||||
void doctypeDecl (const std::string& root_element,
|
|
||||||
const std::string& public_id = "",
|
|
||||||
const std::string& system_id = "",
|
|
||||||
const std::string& internal_subset = "");
|
|
||||||
|
|
||||||
// Utility functions.
|
|
||||||
//
|
|
||||||
|
|
||||||
bool lookupNamespacePrefix(const std::string& ns, std::string& prefix) const;
|
|
||||||
/// Return true if there is a mapping. In this case, prefix contains
|
|
||||||
/// the mapped prefix.
|
|
||||||
|
|
||||||
// Return the current element, that is, the latest element for which
|
|
||||||
// start_element() but not endElement() have been called.
|
|
||||||
//
|
|
||||||
QName currentElement () const;
|
|
||||||
|
|
||||||
// Return the current attribute, that is, the latest attribute for
|
|
||||||
// which start_attribute() but not endAttribute() have been called.
|
|
||||||
//
|
|
||||||
QName currentAttribute () const;
|
|
||||||
|
|
||||||
// Suspend/resume indentation.
|
|
||||||
//
|
|
||||||
// Indentation can be suspended only inside an element and, unless
|
|
||||||
// explicitly resumed, it will remain suspended until the end of
|
|
||||||
// that element. You should only explicitly resume indentation at
|
|
||||||
// the element nesting level of suspension. If indentation is already
|
|
||||||
// suspended at an outer nesting level, then subsequent calls to
|
|
||||||
// suspend/resume are ignored. The indentation_suspended() function
|
|
||||||
// can be used to check if indentation is currently suspended. If it
|
|
||||||
// is not, then this function returns 0. Otherwise, it returns the
|
|
||||||
// level at which pretty-printing was suspended, with root element
|
|
||||||
// being level 1.
|
|
||||||
//
|
|
||||||
void suspendIndentation ();
|
|
||||||
|
|
||||||
void resumeIndentation ();
|
|
||||||
|
|
||||||
std::size_t indentationSuspended () const;
|
|
||||||
|
|
||||||
private:
|
|
||||||
XMLStreamSerializer(const XMLStreamSerializer&);
|
|
||||||
XMLStreamSerializer& operator=(const XMLStreamSerializer&);
|
|
||||||
|
|
||||||
void handleError(genxStatus) const;
|
|
||||||
|
|
||||||
std::ostream& _outputStream;
|
|
||||||
std::ostream::iostate _lastStreamState;// Original exception state.
|
|
||||||
const std::string _outputName;
|
|
||||||
|
|
||||||
genxWriter _writer;
|
|
||||||
genxSender _sender;
|
|
||||||
std::size_t _depth;
|
|
||||||
};
|
|
||||||
|
|
||||||
XMLStreamSerializer& operator<< (XMLStreamSerializer&, void (*func) (XMLStreamSerializer&));
|
|
||||||
/// Stream-like interface for serializer. If the passed argument
|
|
||||||
/// is a function with the void f(serializer&) signature or is a
|
|
||||||
/// function object with the void operator() (serializer&) const
|
|
||||||
/// operator, then this function (object) is called with the passed
|
|
||||||
/// serializer. Otherwise, the argument is passed to the serializer's
|
|
||||||
// characters() function.
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
XMLStreamSerializer& operator<< (XMLStreamSerializer&, const T& value);
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::startElement(const QName& qname)
|
|
||||||
{
|
|
||||||
startElement(qname.namespace_(), qname.name());
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::startElement(const std::string& name)
|
|
||||||
{
|
|
||||||
startElement(std::string(), name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::endElement (const QName& qname)
|
|
||||||
{
|
|
||||||
endElement (qname.namespace_ (), qname.name ());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::endElement (const std::string& name)
|
|
||||||
{
|
|
||||||
endElement (std::string (), name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::element(const std::string& v)
|
|
||||||
{
|
|
||||||
if (!v.empty())
|
|
||||||
characters(v);
|
|
||||||
|
|
||||||
endElement();
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::element(const T& v)
|
|
||||||
{
|
|
||||||
element(ValueTraits < T > ::serialize(v, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::element(const std::string& n, const std::string& v)
|
|
||||||
{
|
|
||||||
element(std::string(), n, v);
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::element(const std::string& n, const T& v)
|
|
||||||
{
|
|
||||||
element(n, ValueTraits < T > ::serialize(v, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::element(const QName& qn, const std::string& v)
|
|
||||||
{
|
|
||||||
element(qn.namespace_(), qn.name(), v);
|
|
||||||
}
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::element(const QName& qn, const T& v)
|
|
||||||
{
|
|
||||||
element(qn, ValueTraits < T > ::serialize(v, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::element(const std::string& ns, const std::string& n, const T& v)
|
|
||||||
{
|
|
||||||
element(ns, n, ValueTraits < T > ::serialize(v, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::startAttribute(const QName& qname)
|
|
||||||
{
|
|
||||||
startAttribute(qname.namespace_(), qname.name());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::startAttribute(const std::string& name)
|
|
||||||
{
|
|
||||||
startAttribute(std::string(), name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::endAttribute (const QName& qname)
|
|
||||||
{
|
|
||||||
endAttribute (qname.namespace_ (), qname.name ());
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::endAttribute (const std::string& name)
|
|
||||||
{
|
|
||||||
endAttribute (std::string (), name);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::attribute(const QName& qname, const std::string& value)
|
|
||||||
{
|
|
||||||
attribute(qname.namespace_(), qname.name(), value);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::attribute(const QName& qname, const T& value)
|
|
||||||
{
|
|
||||||
attribute(qname, ValueTraits < T > ::serialize(value, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
inline void XMLStreamSerializer::attribute(const std::string& name, const std::string& value)
|
|
||||||
{
|
|
||||||
attribute(std::string(), name, value);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::attribute(const std::string& name, const T& value)
|
|
||||||
{
|
|
||||||
attribute(name, ValueTraits < T > ::serialize(value, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::attribute(const std::string& ns, const std::string& name, const T& value)
|
|
||||||
{
|
|
||||||
attribute(ns, name, ValueTraits < T > ::serialize(value, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template<typename T>
|
|
||||||
inline void XMLStreamSerializer::characters(const T& value)
|
|
||||||
{
|
|
||||||
characters(ValueTraits < T > ::serialize(value, *this));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
// operator<<
|
|
||||||
//
|
|
||||||
|
|
||||||
inline XMLStreamSerializer& operator<< (XMLStreamSerializer& s, void (*func) (XMLStreamSerializer&))
|
|
||||||
{
|
|
||||||
func (s);
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
namespace details
|
|
||||||
{
|
|
||||||
// Detect whether T defines void operator(A) const.
|
|
||||||
//
|
|
||||||
template <typename T, typename A>
|
|
||||||
struct is_functor
|
|
||||||
{
|
|
||||||
typedef char no[1];
|
|
||||||
typedef char yes[2];
|
|
||||||
|
|
||||||
template <typename X, X> struct check;
|
|
||||||
|
|
||||||
template <typename>
|
|
||||||
static no& test (...);
|
|
||||||
|
|
||||||
template <typename X>
|
|
||||||
static yes& test (check<void (X::*) (A) const, &X::operator ()>*);
|
|
||||||
|
|
||||||
static const bool value = sizeof (test<T> (0)) == sizeof (yes);
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T, bool = is_functor<T, XMLStreamSerializer&>::value>
|
|
||||||
struct inserter;
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct inserter<T, true>
|
|
||||||
{
|
|
||||||
static void insert (XMLStreamSerializer& s, const T& f) {f (s);}
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct inserter<T, false>
|
|
||||||
{
|
|
||||||
static void insert (XMLStreamSerializer& s, const T& v) {s.characters (v);}
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
inline XMLStreamSerializer& operator<< (XMLStreamSerializer& s, const T& value)
|
|
||||||
{
|
|
||||||
details::inserter<T>::insert (s, value);
|
|
||||||
return s;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
#endif // XML_SERIALIZER
|
|
@@ -1,53 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializerException.h
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// Library: XML
|
|
||||||
// Package: XML
|
|
||||||
// Module: XMLStreamSerializerException
|
|
||||||
//
|
|
||||||
// Definition of the XMLStreamSerializerException class.
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2015, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
// copyright : Copyright (c) 2013-2014 Code Synthesis Tools CC
|
|
||||||
// license : MIT; see accompanying LICENSE file
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef POCO_XML_XMLSTREAMSERIALIZEREXCEPTION_H_
|
|
||||||
#define POCO_XML_XMLSTREAMSERIALIZEREXCEPTION_H_
|
|
||||||
|
|
||||||
#include <Poco/DOM/DOMException.h>
|
|
||||||
|
|
||||||
namespace Poco
|
|
||||||
{
|
|
||||||
namespace XML
|
|
||||||
{
|
|
||||||
class XMLStreamSerializer;
|
|
||||||
|
|
||||||
struct XML_API XMLStreamSerializerException:
|
|
||||||
public Poco::XML::XMLException
|
|
||||||
{
|
|
||||||
XMLStreamSerializerException(const std::string& name, const std::string& description);
|
|
||||||
XMLStreamSerializerException(const XMLStreamSerializer&, const std::string& description);
|
|
||||||
virtual ~XMLStreamSerializerException() throw ();
|
|
||||||
|
|
||||||
const char* name() const throw ();
|
|
||||||
const std::string& description() const;
|
|
||||||
virtual const char* what() const throw ();
|
|
||||||
|
|
||||||
private:
|
|
||||||
void init();
|
|
||||||
|
|
||||||
std::string _name;
|
|
||||||
std::string _description;
|
|
||||||
std::string _what;
|
|
||||||
};
|
|
||||||
|
|
||||||
}
|
|
||||||
/* namespace XML */
|
|
||||||
} /* namespace Poco */
|
|
||||||
#endif /* POCO_XML_XMLSTREAMPARSEREXCEPTION_H_ */
|
|
@@ -1,390 +0,0 @@
|
|||||||
/*
|
|
||||||
* genx - C-callable library for generating XML documents
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Copyright (c) 2007-2013 Code Synthesis Tools CC.
|
|
||||||
* Copyright (c) 2004 by Tim Bray and Sun Microsystems.
|
|
||||||
*
|
|
||||||
* For copying permission, see the accompanying COPYING file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
#ifndef GENX_H
|
|
||||||
#define GENX_H
|
|
||||||
|
|
||||||
#include <stddef.h> /* size_t */
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
extern "C" {
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note on error handling: genx routines mostly return
|
|
||||||
* GENX_SUCCESS (guaranteed to be zero) in normal circumstances, one of
|
|
||||||
* these other GENX_ values on a memory allocation or I/O failure or if the
|
|
||||||
* call would result in non-well-formed output.
|
|
||||||
* You can associate an error message with one of these codes explicitly
|
|
||||||
* or with the most recent error using genxGetErrorMessage() and
|
|
||||||
* genxLastErrorMessage(); see below.
|
|
||||||
*/
|
|
||||||
typedef enum
|
|
||||||
{
|
|
||||||
GENX_SUCCESS = 0,
|
|
||||||
GENX_BAD_UTF8,
|
|
||||||
GENX_NON_XML_CHARACTER,
|
|
||||||
GENX_BAD_NAME,
|
|
||||||
GENX_ALLOC_FAILED,
|
|
||||||
GENX_BAD_NAMESPACE_NAME,
|
|
||||||
GENX_INTERNAL_ERROR,
|
|
||||||
GENX_DUPLICATE_PREFIX,
|
|
||||||
GENX_SEQUENCE_ERROR,
|
|
||||||
GENX_NO_START_TAG,
|
|
||||||
GENX_IO_ERROR,
|
|
||||||
GENX_MISSING_VALUE,
|
|
||||||
GENX_MALFORMED_COMMENT,
|
|
||||||
GENX_XML_PI_TARGET,
|
|
||||||
GENX_MALFORMED_PI,
|
|
||||||
GENX_DUPLICATE_ATTRIBUTE,
|
|
||||||
GENX_ATTRIBUTE_IN_DEFAULT_NAMESPACE,
|
|
||||||
GENX_DUPLICATE_NAMESPACE,
|
|
||||||
GENX_BAD_DEFAULT_DECLARATION
|
|
||||||
} genxStatus;
|
|
||||||
|
|
||||||
/* character types */
|
|
||||||
#define GENX_XML_CHAR 1
|
|
||||||
#define GENX_LETTER 2
|
|
||||||
#define GENX_NAMECHAR 4
|
|
||||||
|
|
||||||
/* The size of the character table. Valid values are 0x100 (first 255
|
|
||||||
chars are checked) and 0x10000 (all chars are checked). */
|
|
||||||
#ifndef GENX_CHAR_TABLE_SIZE
|
|
||||||
# define GENX_CHAR_TABLE_SIZE 0x100
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* a UTF-8 string */
|
|
||||||
typedef unsigned char * utf8;
|
|
||||||
typedef const unsigned char * constUtf8;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* genx's own types
|
|
||||||
*/
|
|
||||||
typedef struct genxWriter_rec * genxWriter;
|
|
||||||
typedef struct genxNamespace_rec * genxNamespace;
|
|
||||||
typedef struct genxElement_rec * genxElement;
|
|
||||||
typedef struct genxAttribute_rec * genxAttribute;
|
|
||||||
|
|
||||||
typedef void * (*genxAlloc) (void * userData, size_t bytes);
|
|
||||||
typedef void (*genxDealloc) (void * userData, void* data);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Constructors, set/get
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Create a new writer. For generating multiple XML documents, it's most
|
|
||||||
* efficient to re-use the same genx object. However, you can only write
|
|
||||||
* one document at a time with a writer.
|
|
||||||
* Returns NULL if it fails, which can only be due to an allocation failure.
|
|
||||||
*/
|
|
||||||
genxWriter genxNew(genxAlloc alloc, genxDealloc dealloc, void * userData);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Reset the writer object back into usable state after an error or
|
|
||||||
* interruption.
|
|
||||||
*/
|
|
||||||
genxStatus genxReset (genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Dispose of a writer, freeing all associated memory
|
|
||||||
*/
|
|
||||||
void genxDispose(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set/get
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The userdata pointer will be passed to memory-allocation
|
|
||||||
* and I/O callbacks. If not set, genx will pass NULL
|
|
||||||
*/
|
|
||||||
void genxSetUserData(genxWriter w, void * userData);
|
|
||||||
void * genxGetUserData(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set/get pretty-printing. If indentation is set to 0, then no pretty-
|
|
||||||
* printing is performed.
|
|
||||||
*/
|
|
||||||
genxStatus genxSetPrettyPrint(genxWriter w, int indentation);
|
|
||||||
int genxGetPrettyPrint(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Suspend/resume pretty-printing. Pretty-printing can be suspended
|
|
||||||
* only inside an element and, unless explicitly resumed, it will
|
|
||||||
* remain suspended until the end of that element. You should only
|
|
||||||
* explicitly resume pretty-printing at the element nesting level
|
|
||||||
* of suspension. If pretty-printing is already suspended at an
|
|
||||||
* outer nesting level, then subsequent calls to suspend/resume
|
|
||||||
* are ignored. The PrettyPrintSuspended() function can be used
|
|
||||||
* to check if pretty-printing is currently suspended. If it is
|
|
||||||
* not, then this function returns 0. Otherwise, it returns the
|
|
||||||
* level at which pretty-printing was suspended, with root element
|
|
||||||
* being level 1.
|
|
||||||
*/
|
|
||||||
genxStatus genxSuspendPrettyPrint(genxWriter w);
|
|
||||||
genxStatus genxResumePrettyPrint(genxWriter w);
|
|
||||||
int genxPrettyPrintSuspended(genxWriter w);
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Set/get canonicalization. If true, then output explicit closing
|
|
||||||
* tags and sort attributes. Default is false.
|
|
||||||
*/
|
|
||||||
genxStatus genxSetCanonical(genxWriter w, int flag);
|
|
||||||
int genxGetCanonical(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* User-provided memory allocator, if desired. For example, if you were
|
|
||||||
* in an Apache module, you could arrange for genx to use ap_palloc by
|
|
||||||
* making the pool accessible via the userData call.
|
|
||||||
* The "dealloc" is to be used to free memory allocated with "alloc". If
|
|
||||||
* alloc is provided but dealloc is NULL, genx will not attempt to free
|
|
||||||
* the memory; this would be appropriate in an Apache context.
|
|
||||||
* If "alloc" is not provided, genx routines use malloc() to allocate memory
|
|
||||||
*/
|
|
||||||
void genxSetAlloc(genxWriter w, genxAlloc alloc);
|
|
||||||
void genxSetDealloc(genxWriter w, genxDealloc dealloc);
|
|
||||||
genxAlloc genxGetAlloc(genxWriter w);
|
|
||||||
genxDealloc genxGetDealloc(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get the prefix associated with a namespace
|
|
||||||
*/
|
|
||||||
utf8 genxGetNamespacePrefix(genxNamespace ns);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Declaration functions
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Declare a namespace. The provided prefix is the default but can be
|
|
||||||
* overridden by genxAddNamespace. If no default prefiix is provided,
|
|
||||||
* genx will generate one of the form g-%d.
|
|
||||||
* On error, returns NULL and signals via statusp
|
|
||||||
*/
|
|
||||||
genxNamespace genxDeclareNamespace(genxWriter w,
|
|
||||||
constUtf8 uri, constUtf8 prefix,
|
|
||||||
genxStatus * statusP);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Declare an element
|
|
||||||
* If something failed, returns NULL and sets the status code via statusP
|
|
||||||
*/
|
|
||||||
genxElement genxDeclareElement(genxWriter w,
|
|
||||||
genxNamespace ns, constUtf8 name,
|
|
||||||
genxStatus * statusP);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Declare an attribute
|
|
||||||
*/
|
|
||||||
genxAttribute genxDeclareAttribute(genxWriter w,
|
|
||||||
genxNamespace ns,
|
|
||||||
constUtf8 name, genxStatus * statusP);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Writing XML
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Caller-provided I/O package.
|
|
||||||
* First form is for a null-terminated string.
|
|
||||||
* for second, if you have s="abcdef" and want to send "abc", you'd call
|
|
||||||
* sendBounded(userData, s, s + 3)
|
|
||||||
*/
|
|
||||||
typedef struct
|
|
||||||
{
|
|
||||||
genxStatus (* send)(void * userData, constUtf8 s);
|
|
||||||
genxStatus (* sendBounded)(void * userData, constUtf8 start, constUtf8 end);
|
|
||||||
genxStatus (* flush)(void * userData);
|
|
||||||
} genxSender;
|
|
||||||
|
|
||||||
genxStatus genxStartDocSender(genxWriter w, genxSender * sender);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* End a document. Calls "flush".
|
|
||||||
*/
|
|
||||||
genxStatus genxEndDocument(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write XML declaration. If encoding or standalone are NULL, then those
|
|
||||||
* attributes are omitted.
|
|
||||||
*/
|
|
||||||
genxStatus genxXmlDeclaration(genxWriter w,
|
|
||||||
constUtf8 version,
|
|
||||||
constUtf8 encoding,
|
|
||||||
constUtf8 standalone);
|
|
||||||
/*
|
|
||||||
* Write DOCTYPE declaration. If public_id is not NULL, then this is
|
|
||||||
* a PUBLIC DOCTYPE declaration, otherwise, if system_id is not NULL,
|
|
||||||
* then this is a SYSTEM DOCTYPE. If both are NULL, then a DOCTYPE
|
|
||||||
* that only contains the root element and, if not NULL, internal
|
|
||||||
* subset is written.
|
|
||||||
*/
|
|
||||||
genxStatus genxDoctypeDeclaration(genxWriter w,
|
|
||||||
constUtf8 root_element,
|
|
||||||
constUtf8 public_id,
|
|
||||||
constUtf8 system_id,
|
|
||||||
constUtf8 internal_subset);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write a comment
|
|
||||||
*/
|
|
||||||
genxStatus genxComment(genxWriter w, constUtf8 text);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write a PI
|
|
||||||
*/
|
|
||||||
genxStatus genxPI(genxWriter w, constUtf8 target, constUtf8 text);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Start an element
|
|
||||||
*/
|
|
||||||
genxStatus genxStartElementLiteral(genxWriter w,
|
|
||||||
constUtf8 xmlns, constUtf8 name);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Start a predeclared element
|
|
||||||
* - element must have been declared
|
|
||||||
*/
|
|
||||||
genxStatus genxStartElement(genxElement e);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get current element. The returned values are valid until this
|
|
||||||
* element ceases to be current (i.e., EndElement() is called).
|
|
||||||
* If the element is unqualified, then xmlns is set to NULL.
|
|
||||||
*/
|
|
||||||
genxStatus genxGetCurrentElement (genxWriter w,
|
|
||||||
constUtf8* xmlns, constUtf8* name);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write an attribute
|
|
||||||
*/
|
|
||||||
genxStatus genxAddAttributeLiteral(genxWriter w, constUtf8 xmlns,
|
|
||||||
constUtf8 name, constUtf8 value);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write a predeclared attribute
|
|
||||||
*/
|
|
||||||
genxStatus genxAddAttribute(genxAttribute a, constUtf8 value);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Start an attribute
|
|
||||||
*/
|
|
||||||
genxStatus genxStartAttributeLiteral(genxWriter w,
|
|
||||||
constUtf8 xmlns, constUtf8 name);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Start a predeclared attribute
|
|
||||||
*/
|
|
||||||
genxStatus genxStartAttribute(genxAttribute a);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Get current attribute. The returned values are valid until this
|
|
||||||
* attribute ceases to be current (i.e., EndAttribute() is called).
|
|
||||||
* If the attribute is unqualified, then xmlns is set to NULL.
|
|
||||||
*/
|
|
||||||
genxStatus genxGetCurrentAttribute (genxWriter w,
|
|
||||||
constUtf8* xmlns, constUtf8* name);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* End an attribute
|
|
||||||
*/
|
|
||||||
genxStatus genxEndAttribute(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* add a namespace declaration
|
|
||||||
*/
|
|
||||||
genxStatus genxAddNamespaceLiteral(genxWriter w,
|
|
||||||
constUtf8 uri, constUtf8 prefix);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* add a predefined namespace declaration
|
|
||||||
*/
|
|
||||||
genxStatus genxAddNamespace(genxNamespace ns, constUtf8 prefix);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Clear default namespace declaration
|
|
||||||
*/
|
|
||||||
genxStatus genxUnsetDefaultNamespace(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write an end tag
|
|
||||||
*/
|
|
||||||
genxStatus genxEndElement(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write some text
|
|
||||||
* You can't write any text outside the root element, except with
|
|
||||||
* genxComment and genxPI.
|
|
||||||
*/
|
|
||||||
genxStatus genxAddText(genxWriter w, constUtf8 start);
|
|
||||||
genxStatus genxAddCountedText(genxWriter w, constUtf8 start, size_t byteCount);
|
|
||||||
genxStatus genxAddBoundedText(genxWriter w, constUtf8 start, constUtf8 end);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Write one character. The integer value is the Unicode character
|
|
||||||
* value, as usually expressed in U+XXXX notation.
|
|
||||||
*/
|
|
||||||
genxStatus genxAddCharacter(genxWriter w, int c);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Utility routines
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Return the Unicode character encoded by the UTF-8 pointed-to by the
|
|
||||||
* argument, and advance the argument past the encoding of the character.
|
|
||||||
* Returns -1 if the UTF-8 is malformed, in which case advances the
|
|
||||||
* argument to point at the first byte past the point past the malformed
|
|
||||||
* ones.
|
|
||||||
*/
|
|
||||||
int genxNextUnicodeChar(constUtf8 * sp);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Scan a buffer allegedly full of UTF-8 encoded XML characters; return
|
|
||||||
* one of GENX_SUCCESS, GENX_BAD_UTF8, or GENX_NON_XML_CHARACTER
|
|
||||||
*/
|
|
||||||
genxStatus genxCheckText(genxWriter w, constUtf8 s);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* return character status, the OR of GENX_XML_CHAR,
|
|
||||||
* GENX_LETTER, and GENX_NAMECHAR
|
|
||||||
*/
|
|
||||||
int genxCharClass(genxWriter w, int c);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Silently wipe any non-XML characters out of a chunk of text.
|
|
||||||
* If you call this on a string before you pass it addText or
|
|
||||||
* addAttribute, you will never get an error from genx unless
|
|
||||||
* (a) there's a bug in your software, e.g. a malformed element name, or
|
|
||||||
* (b) there's a memory allocation or I/O error
|
|
||||||
* The output can never be longer than the input.
|
|
||||||
* Returns true if any changes were made.
|
|
||||||
*/
|
|
||||||
int genxScrubText(genxWriter w, constUtf8 in, utf8 out);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* return error messages
|
|
||||||
*/
|
|
||||||
char * genxGetErrorMessage(genxWriter w, genxStatus status);
|
|
||||||
char * genxLastErrorMessage(genxWriter w);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* return version
|
|
||||||
*/
|
|
||||||
char * genxGetVersion();
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#endif /* GENX_H */
|
|
@@ -2,5 +2,5 @@ add_subdirectory(DOMParser)
|
|||||||
add_subdirectory(DOMWriter)
|
add_subdirectory(DOMWriter)
|
||||||
add_subdirectory(PrettyPrint)
|
add_subdirectory(PrettyPrint)
|
||||||
add_subdirectory(SAXParser)
|
add_subdirectory(SAXParser)
|
||||||
add_subdirectory(RoundTrip)
|
#add_subdirectory(RoundTrip)
|
||||||
|
|
||||||
|
@@ -6,7 +6,6 @@
|
|||||||
#include <iostream>
|
#include <iostream>
|
||||||
|
|
||||||
#include "Poco/XML/XMLStreamParser.h"
|
#include "Poco/XML/XMLStreamParser.h"
|
||||||
#include "Poco/XML/XMLStreamSerializer.h"
|
|
||||||
|
|
||||||
using namespace std;
|
using namespace std;
|
||||||
using namespace Poco::XML;
|
using namespace Poco::XML;
|
||||||
|
@@ -1,318 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializer.cpp
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// Library: XML
|
|
||||||
// Package: XML
|
|
||||||
// Module: XMLStreamSerializer
|
|
||||||
//
|
|
||||||
// Definition of the XMLStreamSerializer class.
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2015, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
// copyright : Copyright (c) 2013-2014 Code Synthesis Tools CC
|
|
||||||
// license : MIT; see accompanying LICENSE file
|
|
||||||
|
|
||||||
|
|
||||||
#include "Poco/XML/XMLStreamSerializer.h"
|
|
||||||
#include "Poco/XML/XMLStreamSerializerException.h"
|
|
||||||
#include <new> // std::bad_alloc
|
|
||||||
#include <cstring> // std::strlen
|
|
||||||
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
|
|
||||||
namespace Poco
|
|
||||||
{
|
|
||||||
namespace XML
|
|
||||||
{
|
|
||||||
|
|
||||||
|
|
||||||
extern "C" genxStatus genx_write(void* p, constUtf8 us)
|
|
||||||
{
|
|
||||||
// It would have been easier to throw the exception directly,
|
|
||||||
// however, the Genx code is most likely not exception safe.
|
|
||||||
//
|
|
||||||
ostream* os(static_cast<ostream*>(p));
|
|
||||||
const char* s(reinterpret_cast<const char*>(us));
|
|
||||||
os->write(s, static_cast<streamsize>(strlen(s)));
|
|
||||||
return os->good() ? GENX_SUCCESS : GENX_IO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
extern "C" genxStatus genx_write_bound(void* p, constUtf8 start, constUtf8 end)
|
|
||||||
{
|
|
||||||
ostream* os(static_cast<ostream*>(p));
|
|
||||||
const char* s(reinterpret_cast<const char*>(start));
|
|
||||||
streamsize n(static_cast<streamsize>(end - start));
|
|
||||||
os->write(s, n);
|
|
||||||
return os->good() ? GENX_SUCCESS : GENX_IO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
extern "C" genxStatus genx_flush(void* p)
|
|
||||||
{
|
|
||||||
ostream* os(static_cast<ostream*>(p));
|
|
||||||
os->flush();
|
|
||||||
return os->good() ? GENX_SUCCESS : GENX_IO_ERROR;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
XMLStreamSerializer::~XMLStreamSerializer()
|
|
||||||
{
|
|
||||||
if (_writer != 0)
|
|
||||||
genxDispose (_writer);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
XMLStreamSerializer::XMLStreamSerializer(ostream& os, const string& oname, unsigned short ind) :
|
|
||||||
_outputStream(os),
|
|
||||||
_lastStreamState(os.exceptions()),
|
|
||||||
_outputName(oname),
|
|
||||||
_depth(0)
|
|
||||||
{
|
|
||||||
// Temporarily disable exceptions on the stream.
|
|
||||||
//
|
|
||||||
_outputStream.exceptions(ostream::goodbit);
|
|
||||||
|
|
||||||
// Allocate the XMLStreamSerializer. Make sure nothing else can throw after
|
|
||||||
// this call since otherwise we will leak it.
|
|
||||||
//
|
|
||||||
_writer = genxNew(0, 0, 0);
|
|
||||||
|
|
||||||
if (_writer == 0)
|
|
||||||
throw bad_alloc();
|
|
||||||
|
|
||||||
genxSetUserData(_writer, &_outputStream);
|
|
||||||
|
|
||||||
if (ind != 0)
|
|
||||||
genxSetPrettyPrint(_writer, ind);
|
|
||||||
|
|
||||||
_sender.send = &genx_write;
|
|
||||||
_sender.sendBounded = &genx_write_bound;
|
|
||||||
_sender.flush = &genx_flush;
|
|
||||||
|
|
||||||
if (genxStatus e = genxStartDocSender(_writer, &_sender))
|
|
||||||
{
|
|
||||||
string m(genxGetErrorMessage(_writer, e));
|
|
||||||
genxDispose (_writer);
|
|
||||||
throw XMLStreamSerializerException(oname, m);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::handleError(genxStatus e) const
|
|
||||||
{
|
|
||||||
switch (e)
|
|
||||||
{
|
|
||||||
case GENX_ALLOC_FAILED:
|
|
||||||
throw bad_alloc();
|
|
||||||
case GENX_IO_ERROR:
|
|
||||||
// Restoring the original exception state should trigger the
|
|
||||||
// exception. If it doesn't (e.g., because the user didn't
|
|
||||||
// configure the stream to throw), then fall back to the
|
|
||||||
// serialiation exception.
|
|
||||||
//
|
|
||||||
_outputStream.exceptions(_lastStreamState);
|
|
||||||
// Fall through.
|
|
||||||
default:
|
|
||||||
throw XMLStreamSerializerException(_outputName, genxGetErrorMessage(_writer, e));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::startElement(const string& ns, const string& name)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxStartElementLiteral(_writer, reinterpret_cast<constUtf8>(ns.empty() ? 0 : ns.c_str()), reinterpret_cast<constUtf8>(name.c_str())))
|
|
||||||
handleError(e);
|
|
||||||
|
|
||||||
_depth++;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::endElement()
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxEndElement(_writer))
|
|
||||||
handleError(e);
|
|
||||||
|
|
||||||
// Call EndDocument() if we are past the root element.
|
|
||||||
//
|
|
||||||
if (--_depth == 0)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxEndDocument(_writer))
|
|
||||||
handleError(e);
|
|
||||||
|
|
||||||
// Also restore the original exception state on the stream.
|
|
||||||
//
|
|
||||||
_outputStream.exceptions(_lastStreamState);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::endElement (const string& ns, const string& name)
|
|
||||||
{
|
|
||||||
constUtf8 cns, cn;
|
|
||||||
genxStatus e;
|
|
||||||
if ((e = genxGetCurrentElement (_writer, &cns, &cn)) ||
|
|
||||||
reinterpret_cast<const char*> (cn) != name ||
|
|
||||||
(cns == 0 ? !ns.empty () : reinterpret_cast<const char*> (cns) != ns))
|
|
||||||
{
|
|
||||||
handleError (e != GENX_SUCCESS ? e : GENX_SEQUENCE_ERROR);
|
|
||||||
}
|
|
||||||
|
|
||||||
endElement ();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::element(const string& ns, const string& n, const string& v)
|
|
||||||
{
|
|
||||||
startElement(ns, n);
|
|
||||||
element(v);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::startAttribute(const string& ns, const string& name)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxStartAttributeLiteral(_writer, reinterpret_cast<constUtf8>(ns.empty() ? 0 : ns.c_str()), reinterpret_cast<constUtf8>(name.c_str())))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const std::string& XMLStreamSerializer::outputName() const
|
|
||||||
{
|
|
||||||
return _outputName;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::endAttribute()
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxEndAttribute(_writer))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::endAttribute (const string& ns, const string& name)
|
|
||||||
{
|
|
||||||
constUtf8 cns, cn;
|
|
||||||
genxStatus e;
|
|
||||||
if ((e = genxGetCurrentAttribute (_writer, &cns, &cn)) ||
|
|
||||||
reinterpret_cast<const char*> (cn) != name ||
|
|
||||||
(cns == 0 ? !ns.empty () : reinterpret_cast<const char*> (cns) != ns))
|
|
||||||
{
|
|
||||||
handleError (e != GENX_SUCCESS ? e : GENX_SEQUENCE_ERROR);
|
|
||||||
}
|
|
||||||
|
|
||||||
endAttribute ();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::attribute(const string& ns, const string& name, const string& value)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxAddAttributeLiteral(_writer, reinterpret_cast<constUtf8>(ns.empty() ? 0 : ns.c_str()), reinterpret_cast<constUtf8>(name.c_str()),
|
|
||||||
reinterpret_cast<constUtf8>(value.c_str())))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::characters(const string& value)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxAddCountedText(_writer, reinterpret_cast<constUtf8>(value.c_str()), value.size()))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::namespaceDecl(const string& ns, const string& p)
|
|
||||||
{
|
|
||||||
if (genxStatus e =
|
|
||||||
ns.empty() && p.empty() ?
|
|
||||||
genxUnsetDefaultNamespace(_writer) :
|
|
||||||
genxAddNamespaceLiteral(_writer, reinterpret_cast<constUtf8>(ns.c_str()), reinterpret_cast<constUtf8>(p.c_str())))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::xmlDecl(const string& ver, const string& enc, const string& stl)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxXmlDeclaration(_writer, reinterpret_cast<constUtf8>(ver.c_str()), (enc.empty() ? 0 : reinterpret_cast<constUtf8>(enc.c_str())),
|
|
||||||
(stl.empty() ? 0 : reinterpret_cast<constUtf8>(stl.c_str()))))
|
|
||||||
handleError(e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::doctypeDecl (const string& re,
|
|
||||||
const string& pi,
|
|
||||||
const string& si,
|
|
||||||
const string& is)
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxDoctypeDeclaration (
|
|
||||||
_writer,
|
|
||||||
reinterpret_cast<constUtf8> (re.c_str ()),
|
|
||||||
(pi.empty () ? 0 : reinterpret_cast<constUtf8> (pi.c_str ())),
|
|
||||||
(si.empty () ? 0 : reinterpret_cast<constUtf8> (si.c_str ())),
|
|
||||||
(is.empty () ? 0 : reinterpret_cast<constUtf8> (is.c_str ()))))
|
|
||||||
handleError (e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
bool XMLStreamSerializer::lookupNamespacePrefix(const string& ns, string& p) const
|
|
||||||
{
|
|
||||||
// Currently Genx will create a namespace mapping if one doesn't
|
|
||||||
// already exist.
|
|
||||||
//
|
|
||||||
genxStatus e;
|
|
||||||
genxNamespace gns(genxDeclareNamespace(_writer, reinterpret_cast<constUtf8>(ns.c_str()), 0, &e));
|
|
||||||
|
|
||||||
if (e != GENX_SUCCESS)
|
|
||||||
handleError(e);
|
|
||||||
|
|
||||||
p = reinterpret_cast<const char*>(genxGetNamespacePrefix(gns));
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QName XMLStreamSerializer::currentElement () const
|
|
||||||
{
|
|
||||||
constUtf8 ns, n;
|
|
||||||
if (genxStatus e = genxGetCurrentElement (_writer, &ns, &n))
|
|
||||||
handleError (e);
|
|
||||||
|
|
||||||
return QName (ns != 0 ? reinterpret_cast<const char*> (ns) : "", reinterpret_cast<const char*> (n));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
QName XMLStreamSerializer::currentAttribute () const
|
|
||||||
{
|
|
||||||
constUtf8 ns, n;
|
|
||||||
if (genxStatus e = genxGetCurrentAttribute (_writer, &ns, &n))
|
|
||||||
handleError (e);
|
|
||||||
|
|
||||||
return QName (ns != 0 ? reinterpret_cast<const char*> (ns) : "", reinterpret_cast<const char*> (n));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::suspendIndentation ()
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxSuspendPrettyPrint (_writer))
|
|
||||||
handleError (e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
void XMLStreamSerializer::resumeIndentation ()
|
|
||||||
{
|
|
||||||
if (genxStatus e = genxResumePrettyPrint (_writer))
|
|
||||||
handleError (e);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
size_t XMLStreamSerializer::indentationSuspended () const
|
|
||||||
{
|
|
||||||
return static_cast<size_t> (genxPrettyPrintSuspended (_writer));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
@@ -1,77 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializerException.cpp
|
|
||||||
//
|
|
||||||
// $Id$
|
|
||||||
//
|
|
||||||
// Library: XML
|
|
||||||
// Package: XML
|
|
||||||
// Module: XMLStreamSerializerException
|
|
||||||
//
|
|
||||||
// Definition of the XMLStreamSerializerException class.
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2015, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
// copyright : Copyright (c) 2013-2014 Code Synthesis Tools CC
|
|
||||||
// license : MIT; see accompanying LICENSE file
|
|
||||||
|
|
||||||
|
|
||||||
#include "Poco/XML/XMLStreamParserException.h"
|
|
||||||
#include "Poco/XML/XMLStreamSerializer.h"
|
|
||||||
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
namespace Poco
|
|
||||||
{
|
|
||||||
namespace XML
|
|
||||||
{
|
|
||||||
|
|
||||||
XMLStreamSerializerException::~XMLStreamSerializerException() throw ()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
XMLStreamSerializerException::XMLStreamSerializerException(const string& n, const string& d)
|
|
||||||
: _name(n), _description(d)
|
|
||||||
{
|
|
||||||
init();
|
|
||||||
}
|
|
||||||
|
|
||||||
XMLStreamSerializerException::XMLStreamSerializerException(const XMLStreamSerializer& s, const std::string& d)
|
|
||||||
: _name(s.outputName()), _description(d)
|
|
||||||
{
|
|
||||||
init();
|
|
||||||
}
|
|
||||||
|
|
||||||
void XMLStreamSerializerException::init()
|
|
||||||
{
|
|
||||||
if (!_name.empty())
|
|
||||||
{
|
|
||||||
_what += _name;
|
|
||||||
_what += ": ";
|
|
||||||
}
|
|
||||||
|
|
||||||
_what += "error: ";
|
|
||||||
_what += _description;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const char* XMLStreamSerializerException::name() const throw ()
|
|
||||||
{
|
|
||||||
return _name.c_str();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
const std::string& XMLStreamSerializerException::description() const
|
|
||||||
{
|
|
||||||
return _description;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
char const* XMLStreamSerializerException::what() const throw ()
|
|
||||||
{
|
|
||||||
return _what.c_str();
|
|
||||||
}
|
|
||||||
|
|
||||||
} /* namespace XML */
|
|
||||||
} /* namespace Poco */
|
|
@@ -1,394 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (c) 2007-2013 Code Synthesis Tools CC.
|
|
||||||
* Copyright (c) 2004 by Tim Bray and Sun Microsystems.
|
|
||||||
*
|
|
||||||
* For copying permission, see the accompanying COPYING file.
|
|
||||||
*/
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Construct character-properties tables for genx.
|
|
||||||
* Quite likely there's a better way.
|
|
||||||
* This version is generated semi-automatically from the source code of the
|
|
||||||
* XML specification via emacs global replace and keyboard macros
|
|
||||||
*/
|
|
||||||
#include "Poco/XML/genx.h"
|
|
||||||
|
|
||||||
static void charProp(char * p, int c, int prop)
|
|
||||||
{
|
|
||||||
p[c] |= prop;
|
|
||||||
}
|
|
||||||
|
|
||||||
static void rangeProp(char * p, size_t start, size_t end, int prop)
|
|
||||||
{
|
|
||||||
size_t i;
|
|
||||||
for (i = start; i <= end; i++)
|
|
||||||
p[i] |= prop;
|
|
||||||
}
|
|
||||||
|
|
||||||
void genxSetCharProps(char * p)
|
|
||||||
{
|
|
||||||
size_t i;
|
|
||||||
|
|
||||||
for (i = 0; i < GENX_CHAR_TABLE_SIZE; i++)
|
|
||||||
p[i] = 0;
|
|
||||||
|
|
||||||
/* per XML 1.0 */
|
|
||||||
charProp(p, 0x9, GENX_XML_CHAR);
|
|
||||||
charProp(p, 0xa, GENX_XML_CHAR);
|
|
||||||
charProp(p, 0xd, GENX_XML_CHAR);
|
|
||||||
rangeProp(p, 0x20, 0xff, GENX_XML_CHAR);
|
|
||||||
|
|
||||||
#if GENX_CHAR_TABLE_SIZE == 0x10000
|
|
||||||
rangeProp(p, 0x0100, 0xd7ff, GENX_XML_CHAR);
|
|
||||||
rangeProp(p, 0xe000, 0xfffd, GENX_XML_CHAR);
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* Letter ::= BaseChar | Ideographic */
|
|
||||||
rangeProp(p, 0x0041, 0x005A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0061, 0x007A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x00C0, 0x00D6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x00D8, 0x00F6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x00F8, 0x00FF, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
|
|
||||||
#if GENX_CHAR_TABLE_SIZE == 0x10000
|
|
||||||
|
|
||||||
rangeProp(p, 0x0100, 0x0131, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0134, 0x013E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0141, 0x0148, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x014A, 0x017E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0180, 0x01C3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x01CD, 0x01F0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x01F4, 0x01F5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x01FA, 0x0217, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0250, 0x02A8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x02BB, 0x02C1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0386, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0388, 0x038A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x038C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x038E, 0x03A1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x03A3, 0x03CE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x03D0, 0x03D6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x03DA, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x03DC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x03DE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x03E0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x03E2, 0x03F3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0401, 0x040C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x040E, 0x044F, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0451, 0x045C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x045E, 0x0481, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0490, 0x04C4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x04C7, 0x04C8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x04CB, 0x04CC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x04D0, 0x04EB, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x04EE, 0x04F5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x04F8, 0x04F9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0531, 0x0556, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0559, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0561, 0x0586, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x05D0, 0x05EA, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x05F0, 0x05F2, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0621, 0x063A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0641, 0x064A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0671, 0x06B7, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06BA, 0x06BE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06C0, 0x06CE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06D0, 0x06D3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x06D5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06E5, 0x06E6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0905, 0x0939, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x093D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0958, 0x0961, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0985, 0x098C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x098F, 0x0990, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0993, 0x09A8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09AA, 0x09B0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x09B2, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09B6, 0x09B9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09DC, 0x09DD, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09DF, 0x09E1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09F0, 0x09F1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A05, 0x0A0A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A0F, 0x0A10, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A13, 0x0A28, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A2A, 0x0A30, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A32, 0x0A33, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A35, 0x0A36, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A38, 0x0A39, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A59, 0x0A5C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A5E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A72, 0x0A74, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A85, 0x0A8B, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A8D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A8F, 0x0A91, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A93, 0x0AA8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0AAA, 0x0AB0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0AB2, 0x0AB3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0AB5, 0x0AB9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0ABD, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0AE0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B05, 0x0B0C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B0F, 0x0B10, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B13, 0x0B28, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B2A, 0x0B30, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B32, 0x0B33, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B36, 0x0B39, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0B3D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B5C, 0x0B5D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B5F, 0x0B61, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B85, 0x0B8A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B8E, 0x0B90, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B92, 0x0B95, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B99, 0x0B9A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0B9C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B9E, 0x0B9F, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BA3, 0x0BA4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BA8, 0x0BAA, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BAE, 0x0BB5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BB7, 0x0BB9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C05, 0x0C0C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C0E, 0x0C10, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C12, 0x0C28, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C2A, 0x0C33, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C35, 0x0C39, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C60, 0x0C61, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C85, 0x0C8C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C8E, 0x0C90, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C92, 0x0CA8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CAA, 0x0CB3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CB5, 0x0CB9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0CDE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CE0, 0x0CE1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D05, 0x0D0C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D0E, 0x0D10, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D12, 0x0D28, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D2A, 0x0D39, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D60, 0x0D61, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E01, 0x0E2E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E30, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E32, 0x0E33, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E40, 0x0E45, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E81, 0x0E82, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E84, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E87, 0x0E88, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E8A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E8D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E94, 0x0E97, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E99, 0x0E9F, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EA1, 0x0EA3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EA5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EA7, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EAA, 0x0EAB, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EAD, 0x0EAE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EB0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EB2, 0x0EB3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EBD, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EC0, 0x0EC4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F40, 0x0F47, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F49, 0x0F69, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x10A0, 0x10C5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x10D0, 0x10F6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1100, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1102, 0x1103, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1105, 0x1107, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1109, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x110B, 0x110C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x110E, 0x1112, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x113C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x113E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1140, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x114C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x114E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1150, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1154, 0x1155, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1159, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x115F, 0x1161, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1163, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1165, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1167, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1169, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x116D, 0x116E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1172, 0x1173, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1175, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x119E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11A8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11AB, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x11AE, 0x11AF, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x11B7, 0x11B8, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11BA, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x11BC, 0x11C2, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11EB, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11F0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x11F9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1E00, 0x1E9B, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1EA0, 0x1EF9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F00, 0x1F15, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F18, 0x1F1D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F20, 0x1F45, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F48, 0x1F4D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F50, 0x1F57, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1F59, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1F5B, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1F5D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F5F, 0x1F7D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1F80, 0x1FB4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FB6, 0x1FBC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x1FBE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FC2, 0x1FC4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FC6, 0x1FCC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FD0, 0x1FD3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FD6, 0x1FDB, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FE0, 0x1FEC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FF2, 0x1FF4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x1FF6, 0x1FFC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x2126, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x212A, 0x212B, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x212E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x2180, 0x2182, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x3041, 0x3094, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x30A1, 0x30FA, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x3105, 0x312C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0xAC00, 0xD7A3, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x4E00, 0x9FA5, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x3007, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x3021, 0x3029, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
|
|
||||||
#endif /* GENX_CHAR_TABLE_SIZE == 0x10000 */
|
|
||||||
|
|
||||||
/*
|
|
||||||
* NameChar ::=
|
|
||||||
* Letter | Digit | '.' | '-' | '_' | ':' | CombiningChar | Extender
|
|
||||||
*/
|
|
||||||
|
|
||||||
charProp(p, '.', GENX_NAMECHAR);
|
|
||||||
charProp(p, '-', GENX_NAMECHAR);
|
|
||||||
charProp(p, '_', GENX_NAMECHAR);
|
|
||||||
|
|
||||||
rangeProp(p, 0x0030, 0x0039, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x00B7, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
|
|
||||||
#if GENX_CHAR_TABLE_SIZE == 0x10000
|
|
||||||
|
|
||||||
rangeProp(p, 0x0660, 0x0669, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06F0, 0x06F9, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0966, 0x096F, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09E6, 0x09EF, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A66, 0x0A6F, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0AE6, 0x0AEF, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B66, 0x0B6F, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BE7, 0x0BEF, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C66, 0x0C6F, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CE6, 0x0CEF, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D66, 0x0D6F, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E50, 0x0E59, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0ED0, 0x0ED9, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F20, 0x0F29, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0300, 0x0345, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0360, 0x0361, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0483, 0x0486, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0591, 0x05A1, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x05A3, 0x05B9, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x05BB, 0x05BD, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x05BF, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x05C1, 0x05C2, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x05C4, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x064B, 0x0652, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0670, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06D6, 0x06DC, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06DD, 0x06DF, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06E0, 0x06E4, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06E7, 0x06E8, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x06EA, 0x06ED, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0901, 0x0903, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x093C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x093E, 0x094C, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x094D, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0951, 0x0954, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0962, 0x0963, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0981, 0x0983, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x09BC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x09BE, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x09BF, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09C0, 0x09C4, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09C7, 0x09C8, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09CB, 0x09CD, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x09D7, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x09E2, 0x09E3, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A02, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A3C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A3E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0A3F, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A40, 0x0A42, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A47, 0x0A48, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A4B, 0x0A4D, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A70, 0x0A71, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0A81, 0x0A83, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0ABC, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0ABE, 0x0AC5, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0AC7, 0x0AC9, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0ACB, 0x0ACD, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B01, 0x0B03, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0B3C, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B3E, 0x0B43, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B47, 0x0B48, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B4B, 0x0B4D, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B56, 0x0B57, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0B82, 0x0B83, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BBE, 0x0BC2, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BC6, 0x0BC8, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0BCA, 0x0BCD, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0BD7, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C01, 0x0C03, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C3E, 0x0C44, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C46, 0x0C48, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C4A, 0x0C4D, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C55, 0x0C56, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0C82, 0x0C83, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CBE, 0x0CC4, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CC6, 0x0CC8, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CCA, 0x0CCD, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0CD5, 0x0CD6, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D02, 0x0D03, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D3E, 0x0D43, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D46, 0x0D48, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0D4A, 0x0D4D, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0D57, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E31, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E34, 0x0E3A, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0E47, 0x0E4E, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EB1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EB4, 0x0EB9, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EBB, 0x0EBC, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0EC8, 0x0ECD, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F18, 0x0F19, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F35, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F37, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F39, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F3E, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F3F, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F71, 0x0F84, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F86, 0x0F8B, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F90, 0x0F95, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0F97, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0F99, 0x0FAD, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x0FB1, 0x0FB7, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0FB9, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x20D0, 0x20DC, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x20E1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x302A, 0x302F, GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x3099, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x309A, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
|
|
||||||
charProp(p, 0x02D0, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x02D1, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0387, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0640, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0E46, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x0EC6, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
charProp(p, 0x3005, GENX_LETTER|GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x3031, 0x3035, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x309D, 0x309E, GENX_NAMECHAR);
|
|
||||||
rangeProp(p, 0x30FC, 0x30FE, GENX_NAMECHAR);
|
|
||||||
|
|
||||||
#endif /* GENX_CHAR_TABLE_SIZE == 0x10000 */
|
|
||||||
}
|
|
2502
XML/src/genx.c
2502
XML/src/genx.c
File diff suppressed because it is too large
Load Diff
@@ -1,131 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializerTestSuite.cpp
|
|
||||||
//
|
|
||||||
// $Id: //poco/1.4/XML/testsuite/src/XMLStreamSerializerTestSuite.cpp#4 $
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
//
|
|
||||||
|
|
||||||
#include "XMLStreamSerializerTestSuite.h"
|
|
||||||
#include "CppUnit/TestCaller.h"
|
|
||||||
#include "CppUnit/TestSuite.h"
|
|
||||||
#include "Poco/XML/XMLStreamSerializer.h"
|
|
||||||
#include "Poco/Exception.h"
|
|
||||||
#include <sstream>
|
|
||||||
#include <string>
|
|
||||||
#include <vector>
|
|
||||||
#include <iostream>
|
|
||||||
|
|
||||||
using namespace Poco::XML;
|
|
||||||
using namespace std;
|
|
||||||
|
|
||||||
XMLStreamSerializerTestSuite::XMLStreamSerializerTestSuite(const std::string& name)
|
|
||||||
: CppUnit::TestCase(name)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
XMLStreamSerializerTestSuite::~XMLStreamSerializerTestSuite()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void XMLStreamSerializerTestSuite::testSerialize()
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ostringstream os;
|
|
||||||
XMLStreamSerializer s (os, "test");
|
|
||||||
|
|
||||||
s.attribute ("foo", "bar");
|
|
||||||
assert (false);
|
|
||||||
}
|
|
||||||
catch (const Poco::Exception&)
|
|
||||||
{
|
|
||||||
// cerr << e.what () << endl;
|
|
||||||
}
|
|
||||||
|
|
||||||
try
|
|
||||||
{
|
|
||||||
ostringstream os;
|
|
||||||
os.exceptions (ios_base::badbit | ios_base::failbit);
|
|
||||||
XMLStreamSerializer s (os, "test");
|
|
||||||
|
|
||||||
s.startElement ("root");
|
|
||||||
s.characters ("one");
|
|
||||||
os.setstate (ios_base::badbit);
|
|
||||||
s.characters ("two");
|
|
||||||
assert (false);
|
|
||||||
}
|
|
||||||
catch (const ios_base::failure&)
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test value serialization.
|
|
||||||
//
|
|
||||||
{
|
|
||||||
ostringstream os;
|
|
||||||
XMLStreamSerializer s (os, "test", 0);
|
|
||||||
|
|
||||||
s.startElement ("root");
|
|
||||||
s.attribute ("version", 123);
|
|
||||||
s.characters (true);
|
|
||||||
s.endElement ();
|
|
||||||
|
|
||||||
assert (os.str () == "<root version=\"123\">true</root>\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
// Test helpers for serializing elements with simple content.
|
|
||||||
//
|
|
||||||
{
|
|
||||||
ostringstream os;
|
|
||||||
XMLStreamSerializer s (os, "element", 0);
|
|
||||||
|
|
||||||
s.startElement ("root");
|
|
||||||
|
|
||||||
s.startElement ("nested");
|
|
||||||
s.element ("X");
|
|
||||||
|
|
||||||
s.startElement ("nested");
|
|
||||||
s.element (123);
|
|
||||||
|
|
||||||
s.element ("nested", "X");
|
|
||||||
s.element ("nested", 123);
|
|
||||||
s.element ("test", "nested", "X");
|
|
||||||
s.element ("test", "nested", 123);
|
|
||||||
s.element (QName ("test", "nested"), "X");
|
|
||||||
s.element (QName ("test", "nested"), 123);
|
|
||||||
|
|
||||||
s.endElement (); // root
|
|
||||||
|
|
||||||
assert (os.str () ==
|
|
||||||
"<root>"
|
|
||||||
"<nested>X</nested>"
|
|
||||||
"<nested>123</nested>"
|
|
||||||
"<nested>X</nested>"
|
|
||||||
"<nested>123</nested>"
|
|
||||||
"<g1:nested xmlns:g1=\"test\">X</g1:nested>"
|
|
||||||
"<g1:nested xmlns:g1=\"test\">123</g1:nested>"
|
|
||||||
"<g1:nested xmlns:g1=\"test\">X</g1:nested>"
|
|
||||||
"<g1:nested xmlns:g1=\"test\">123</g1:nested>"
|
|
||||||
"</root>\n");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void XMLStreamSerializerTestSuite::setUp()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
void XMLStreamSerializerTestSuite::tearDown()
|
|
||||||
{
|
|
||||||
}
|
|
||||||
|
|
||||||
CppUnit::Test* XMLStreamSerializerTestSuite::suite()
|
|
||||||
{
|
|
||||||
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("XMLStreamSerializerTestSuite");
|
|
||||||
|
|
||||||
CppUnit_addTest(pSuite, XMLStreamSerializerTestSuite, testSerialize);
|
|
||||||
|
|
||||||
return pSuite;
|
|
||||||
}
|
|
@@ -1,40 +0,0 @@
|
|||||||
//
|
|
||||||
// XMLStreamSerializerTestSuite.h
|
|
||||||
//
|
|
||||||
// $Id: //poco/1.4/XML/testsuite/src/XMLStreamSerializerTestSuite.h#2 $
|
|
||||||
//
|
|
||||||
// Definition of the XMLStreamSerializerTestSuite class.
|
|
||||||
//
|
|
||||||
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
||||||
// and Contributors.
|
|
||||||
//
|
|
||||||
// SPDX-License-Identifier: BSL-1.0
|
|
||||||
//
|
|
||||||
|
|
||||||
|
|
||||||
#ifndef XMLStreamSerializerTestSuite_INCLUDED
|
|
||||||
#define XMLStreamSerializerTestSuite_INCLUDED
|
|
||||||
|
|
||||||
|
|
||||||
#include "Poco/XML/XML.h"
|
|
||||||
#include "CppUnit/TestCase.h"
|
|
||||||
|
|
||||||
|
|
||||||
class XMLStreamSerializerTestSuite: public CppUnit::TestCase
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
XMLStreamSerializerTestSuite(const std::string& name);
|
|
||||||
~XMLStreamSerializerTestSuite();
|
|
||||||
|
|
||||||
void testSerialize();
|
|
||||||
|
|
||||||
void setUp();
|
|
||||||
void tearDown();
|
|
||||||
|
|
||||||
static CppUnit::Test* suite();
|
|
||||||
|
|
||||||
private:
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
#endif // XMLStreamSerializerTestSuite_INCLUDED
|
|
@@ -17,7 +17,6 @@
|
|||||||
#include "SAXTestSuite.h"
|
#include "SAXTestSuite.h"
|
||||||
#include "DOMTestSuite.h"
|
#include "DOMTestSuite.h"
|
||||||
#include "XMLStreamParserTestSuite.h"
|
#include "XMLStreamParserTestSuite.h"
|
||||||
#include "XMLStreamSerializerTestSuite.h"
|
|
||||||
|
|
||||||
CppUnit::Test* XMLTestSuite::suite()
|
CppUnit::Test* XMLTestSuite::suite()
|
||||||
{
|
{
|
||||||
@@ -29,7 +28,6 @@ CppUnit::Test* XMLTestSuite::suite()
|
|||||||
pSuite->addTest(SAXTestSuite::suite());
|
pSuite->addTest(SAXTestSuite::suite());
|
||||||
pSuite->addTest(DOMTestSuite::suite());
|
pSuite->addTest(DOMTestSuite::suite());
|
||||||
pSuite->addTest(XMLStreamParserTestSuite::suite());
|
pSuite->addTest(XMLStreamParserTestSuite::suite());
|
||||||
pSuite->addTest(XMLStreamSerializerTestSuite::suite());
|
|
||||||
|
|
||||||
return pSuite;
|
return pSuite;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user