mirror of
				https://github.com/pocoproject/poco.git
				synced 2025-10-25 02:06:04 +02:00 
			
		
		
		
	remove serializer part
This commit is contained in:
		| @@ -25,12 +25,6 @@ else() | ||||
|     ) | ||||
| endif (POCO_UNBUNDLED) | ||||
|  | ||||
| # GENX lib | ||||
| POCO_SOURCES( SRCS genx  | ||||
|     src/genx.c | ||||
|     src/char-props.c | ||||
| ) | ||||
|  | ||||
| if(WIN32) | ||||
| #TODO: Is XML_STATIC only required with Windows? What does it do? | ||||
| 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 \ | ||||
| 	TreeWalker WhitespaceFilter XMLException XMLFilter XMLFilterImpl XMLReader \ | ||||
| 	XMLString XMLWriter XMLStreamParser XMLStreamParserException XMLStreamSerializer \ | ||||
| 	XMLStreamSerializerException char-props genx | ||||
| 	XMLStreamSerializerException | ||||
|  | ||||
| expat_objects = xmlparse xmlrole xmltok | ||||
|  | ||||
|   | ||||
| @@ -22,7 +22,6 @@ | ||||
|  | ||||
|  | ||||
| #include "XMLStreamParserException.h" | ||||
| #include "XMLStreamSerializerException.h" | ||||
| #include <string> | ||||
| #include <cstddef> // std::size_t | ||||
| #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(PrettyPrint) | ||||
| add_subdirectory(SAXParser) | ||||
| add_subdirectory(RoundTrip) | ||||
| #add_subdirectory(RoundTrip) | ||||
|  | ||||
|   | ||||
| @@ -6,7 +6,6 @@ | ||||
| #include <iostream> | ||||
|  | ||||
| #include "Poco/XML/XMLStreamParser.h" | ||||
| #include "Poco/XML/XMLStreamSerializer.h" | ||||
|  | ||||
| using namespace std; | ||||
| 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 "DOMTestSuite.h" | ||||
| #include "XMLStreamParserTestSuite.h" | ||||
| #include "XMLStreamSerializerTestSuite.h" | ||||
|  | ||||
| CppUnit::Test* XMLTestSuite::suite() | ||||
| { | ||||
| @@ -29,7 +28,6 @@ CppUnit::Test* XMLTestSuite::suite() | ||||
| 	pSuite->addTest(SAXTestSuite::suite()); | ||||
| 	pSuite->addTest(DOMTestSuite::suite()); | ||||
| 	pSuite->addTest(XMLStreamParserTestSuite::suite()); | ||||
| 	pSuite->addTest(XMLStreamSerializerTestSuite::suite()); | ||||
|  | ||||
| 	return pSuite; | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Marian Krivos
					Marian Krivos