committed latest 1.3 snapshot

This commit is contained in:
Guenter Obiltschnig 2007-04-18 16:23:42 +00:00
parent b7a945da93
commit b60344ddcd
18 changed files with 483 additions and 22 deletions

View File

@ -1,7 +1,7 @@
# #
# Makefile # Makefile
# #
# $Id: //poco/Main/XML/Makefile#11 $ # $Id: //poco/Main/XML/Makefile#12 $
# #
# Makefile for Poco XML # Makefile for Poco XML
# #
@ -22,7 +22,7 @@ objects = AbstractContainerNode AbstractNode Attr AttrMap Attributes \
NamespaceSupport Node NodeFilter NodeIterator NodeList Notation \ NamespaceSupport Node NodeFilter NodeIterator NodeList Notation \
ParserEngine ProcessingInstruction SAXException SAXParser Text \ ParserEngine ProcessingInstruction SAXException SAXParser Text \
TreeWalker WhitespaceFilter XMLException XMLFilter XMLFilterImpl XMLReader \ TreeWalker WhitespaceFilter XMLException XMLFilter XMLFilterImpl XMLReader \
XMLString XMLWriter xmlparse xmlrole xmltok XMLString XMLWriter NodeAppender xmlparse xmlrole xmltok
target = PocoXML target = PocoXML
target_version = $(LIBVERSION) target_version = $(LIBVERSION)

View File

@ -538,6 +538,9 @@
<File <File
RelativePath=".\include\Poco\DOM\Node.h"> RelativePath=".\include\Poco\DOM\Node.h">
</File> </File>
<File
RelativePath=".\include\Poco\Dom\NodeAppender.h">
</File>
<File <File
RelativePath=".\include\Poco\DOM\NodeFilter.h"> RelativePath=".\include\Poco\DOM\NodeFilter.h">
</File> </File>
@ -659,6 +662,9 @@
<File <File
RelativePath=".\src\Node.cpp"> RelativePath=".\src\Node.cpp">
</File> </File>
<File
RelativePath=".\src\NodeAppender.cpp">
</File>
<File <File
RelativePath=".\src\NodeFilter.cpp"> RelativePath=".\src\NodeFilter.cpp">
</File> </File>

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="Windows-1252"?> <?xml version="1.0" encoding="Windows-1252"?>
<VisualStudioProject <VisualStudioProject
ProjectType="Visual C++" ProjectType="Visual C++"
Version="8,00" Version="8.00"
Name="XML" Name="XML"
ProjectGUID="{9E211743-85FE-4977-82F3-4F04B40C912D}" ProjectGUID="{9E211743-85FE-4977-82F3-4F04B40C912D}"
> >
@ -735,6 +735,10 @@
RelativePath=".\include\Poco\DOM\Node.h" RelativePath=".\include\Poco\DOM\Node.h"
> >
</File> </File>
<File
RelativePath=".\include\Poco\DOM\NodeAppender.h"
>
</File>
<File <File
RelativePath=".\include\Poco\Dom\NodeFilter.h" RelativePath=".\include\Poco\Dom\NodeFilter.h"
> >
@ -895,6 +899,10 @@
RelativePath=".\src\Node.cpp" RelativePath=".\src\Node.cpp"
> >
</File> </File>
<File
RelativePath=".\src\NodeAppender.cpp"
>
</File>
<File <File
RelativePath=".\src\NodeFilter.cpp" RelativePath=".\src\NodeFilter.cpp"
> >

View File

@ -1,7 +1,7 @@
// //
// AbstractContainerNode.h // AbstractContainerNode.h
// //
// $Id: //poco/Main/XML/include/Poco/DOM/AbstractContainerNode.h#2 $ // $Id: //poco/Main/XML/include/Poco/DOM/AbstractContainerNode.h#3 $
// //
// Library: XML // Library: XML
// Package: DOM // Package: DOM
@ -77,6 +77,7 @@ private:
AbstractNode* _pFirstChild; AbstractNode* _pFirstChild;
friend class AbstractNode; friend class AbstractNode;
friend class NodeAppender;
}; };

View File

@ -1,7 +1,7 @@
// //
// AbstractNode.h // AbstractNode.h
// //
// $Id: //poco/Main/XML/include/Poco/DOM/AbstractNode.h#2 $ // $Id: //poco/Main/XML/include/Poco/DOM/AbstractNode.h#3 $
// //
// Library: XML // Library: XML
// Package: DOM // Package: DOM
@ -135,6 +135,7 @@ private:
friend class Attr; friend class Attr;
friend class CharacterData; friend class CharacterData;
friend class DOMBuilder; friend class DOMBuilder;
friend class NodeAppender;
}; };

View File

@ -1,7 +1,7 @@
// //
// DOMWriter.h // DOMWriter.h
// //
// $Id: //poco/Main/XML/include/Poco/DOM/DOMWriter.h#3 $ // $Id: //poco/Main/XML/include/Poco/DOM/DOMWriter.h#4 $
// //
// Library: XML // Library: XML
// Package: DOM // Package: DOM
@ -94,7 +94,7 @@ public:
void writeNode(const std::string& systemId, const Node* pNode); void writeNode(const std::string& systemId, const Node* pNode);
/// Writes the XML for the given node to the file specified in systemId, /// Writes the XML for the given node to the file specified in systemId,
/// using a standard file output stream (std::ofstream). /// using a standard file output stream (Poco::FileOutputStream).
private: private:
std::string _encodingName; std::string _encodingName;

View File

@ -0,0 +1,103 @@
//
// NodeAppender.h
//
// $Id: //poco/Main/XML/include/Poco/DOM/NodeAppender.h#1 $
//
// Library: XML
// Package: DOM
// Module: NodeAppender
//
// Definition of the NodeAppender class.
//
// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// Permission is hereby granted, free of charge, to any person or organization
// obtaining a copy of the software and accompanying documentation covered by
// this license (the "Software") to use, reproduce, display, distribute,
// execute, and transmit the Software, and to prepare derivative works of the
// Software, and to permit third-parties to whom the Software is furnished to
// do so, all subject to the following:
//
// The copyright notices in the Software and this entire statement, including
// the above license grant, this restriction and the following disclaimer,
// must be included in all copies of the Software, in whole or in part, and
// all derivative works of the Software, unless such copies or derivative
// works are solely in the form of machine-executable object code generated by
// a source language processor.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
#ifndef DOM_NodeAppender_INCLUDED
#define DOM_NodeAppender_INCLUDED
#include "Poco/XML/XML.h"
#include "Poco/DOM/Node.h"
namespace Poco {
namespace XML {
class AbstractNode;
class Element;
class XML_API NodeAppender
/// The NodeAppender class provides a very fast way to
/// build larger DOM documents.
///
/// In the DOM, child nodes are usually appended to a parent
/// node using the appendChild() method. For nodes containing
/// more than a few children, this method can be quite slow,
/// due to the way it's implemented, and because of the
/// requirements of the DOM specification.
///
/// While the NodeAppender is being used on an Element, no
/// children-modifying methods of that Element must be used.
///
/// This class is not part of the DOM specification.
{
public:
NodeAppender(Element* parent);
/// Creates the NodeAppender for the given parent node,
/// which must be an Element.
~NodeAppender();
/// Destroys the NodeAppender.
void appendChild(Node* newChild);
/// Appends the node newChild to the end of the list of children of
/// the parent node specified in the constructor.
/// If the newChild is already in the tree, it is first removed.
///
/// NewChild can be a DocumentFragment. In this case, all children
/// of the fragment become children of the parent element.
///
/// In order to speed up the function, no DOM events
/// are fired.
private:
NodeAppender();
NodeAppender(const NodeAppender&);
NodeAppender& operator = (const NodeAppender&);
Element* _pParent;
AbstractNode* _pLast;
};
} } // namespace Poco::XML
#endif // #include "Poco/XML/XML.h"

View File

@ -1,7 +1,7 @@
// //
// EntityResolverImpl.h // EntityResolverImpl.h
// //
// $Id: //poco/Main/XML/include/Poco/SAX/EntityResolverImpl.h#2 $ // $Id: //poco/Main/XML/include/Poco/SAX/EntityResolverImpl.h#3 $
// //
// Library: XML // Library: XML
// Package: SAX // Package: SAX
@ -58,7 +58,7 @@ class XML_API EntityResolverImpl: public EntityResolver
/// for an InputSource. /// for an InputSource.
/// ///
/// If the system ID is not a valid URI, it is /// If the system ID is not a valid URI, it is
/// interpreted as a filesystem path and a ifstream /// interpreted as a filesystem path and a Poco::FileInputStream
/// is opened for it. /// is opened for it.
{ {
public: public:
@ -78,7 +78,7 @@ public:
/// for the given systemId, which is interpreted as an URI. /// for the given systemId, which is interpreted as an URI.
/// ///
/// If the systemId is not a valid URI, it is interpreted as /// If the systemId is not a valid URI, it is interpreted as
/// a local filesystem path and an ifstream is opened for it. /// a local filesystem path and a Poco::FileInputStream is opened for it.
void releaseInputSource(InputSource* pSource); void releaseInputSource(InputSource* pSource);
/// Deletes the InputSource's stream. /// Deletes the InputSource's stream.

View File

@ -1,7 +1,7 @@
// //
// DOMWriter.cpp // DOMWriter.cpp
// //
// $Id: //poco/Main/XML/src/DOMWriter.cpp#13 $ // $Id: //poco/Main/XML/src/DOMWriter.cpp#14 $
// //
// Library: XML // Library: XML
// Package: DOM // Package: DOM
@ -45,7 +45,7 @@
#include "Poco/SAX/LexicalHandler.h" #include "Poco/SAX/LexicalHandler.h"
#include "Poco/XML/XMLException.h" #include "Poco/XML/XMLException.h"
#include "Poco/Path.h" #include "Poco/Path.h"
#include <fstream> #include "Poco/FileStream.h"
namespace Poco { namespace Poco {
@ -104,7 +104,7 @@ void DOMWriter::writeNode(XMLByteOutputStream& ostr, const Node* pNode)
void DOMWriter::writeNode(const std::string& systemId, const Node* pNode) void DOMWriter::writeNode(const std::string& systemId, const Node* pNode)
{ {
std::ofstream ostr(Poco::Path::transcode(systemId).c_str()); Poco::FileOutputStream ostr(systemId);
if (ostr.good()) if (ostr.good())
writeNode(ostr, pNode); writeNode(ostr, pNode);
else else

104
XML/src/NodeAppender.cpp Normal file
View File

@ -0,0 +1,104 @@
//
// NodeAppender.cpp
//
// $Id: //poco/Main/XML/src/NodeAppender.cpp#1 $
//
// Library: XML
// Package: DOM
// Module: NodeAppender
//
// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// Permission is hereby granted, free of charge, to any person or organization
// obtaining a copy of the software and accompanying documentation covered by
// this license (the "Software") to use, reproduce, display, distribute,
// execute, and transmit the Software, and to prepare derivative works of the
// Software, and to permit third-parties to whom the Software is furnished to
// do so, all subject to the following:
//
// The copyright notices in the Software and this entire statement, including
// the above license grant, this restriction and the following disclaimer,
// must be included in all copies of the Software, in whole or in part, and
// all derivative works of the Software, unless such copies or derivative
// works are solely in the form of machine-executable object code generated by
// a source language processor.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
#include "Poco/DOM/NodeAppender.h"
#include "Poco/DOM/Element.h"
#include "Poco/DOM/DOMException.h"
namespace Poco {
namespace XML {
NodeAppender::NodeAppender(Element* parent):
_pParent(parent),
_pLast(0)
{
poco_check_ptr (parent);
_pLast = static_cast<AbstractNode*>(_pParent->lastChild());
}
NodeAppender::~NodeAppender()
{
}
void NodeAppender::appendChild(Node* newChild)
{
poco_check_ptr (newChild);
poco_assert (_pLast == 0 || _pLast->_pNext == 0);
if (static_cast<AbstractNode*>(newChild)->_pOwner != _pParent->_pOwner)
throw DOMException(DOMException::WRONG_DOCUMENT_ERR);
if (newChild->nodeType() == Node::DOCUMENT_FRAGMENT_NODE)
{
AbstractContainerNode* pFrag = static_cast<AbstractContainerNode*>(newChild);
AbstractNode* pChild = pFrag->_pFirstChild;
if (pChild)
{
if (_pLast)
_pLast->_pNext = pChild;
else
_pParent->_pFirstChild = pChild;
while (pChild)
{
_pLast = pChild;
pChild->_pParent = _pParent;
pChild = pChild->_pNext;
}
pFrag->_pFirstChild = 0;
}
}
else
{
AbstractNode* pAN = static_cast<AbstractNode*>(newChild);
pAN->duplicate();
if (pAN->_pParent)
pAN->_pParent->removeChild(pAN);
pAN->_pParent = _pParent;
if (_pLast)
_pLast->_pNext = pAN;
else
_pParent->_pFirstChild = pAN;
_pLast = pAN;
}
}
} } // namespace Poco::XML

View File

@ -1,7 +1,7 @@
# #
# Makefile # Makefile
# #
# $Id: //poco/Main/XML/testsuite/Makefile#5 $ # $Id: //poco/Main/XML/testsuite/Makefile#6 $
# #
# Makefile for Poco XML testsuite # Makefile for Poco XML testsuite
# #
@ -12,7 +12,7 @@ objects = AttributesImplTest ChildNodesTest DOMTestSuite DocumentTest \
DocumentTypeTest Driver ElementTest EventTest NamePoolTest NameTest \ DocumentTypeTest Driver ElementTest EventTest NamePoolTest NameTest \
NamespaceSupportTest NodeIteratorTest NodeTest ParserWriterTest \ NamespaceSupportTest NodeIteratorTest NodeTest ParserWriterTest \
SAXParserTest SAXTestSuite TextTest TreeWalkerTest \ SAXParserTest SAXTestSuite TextTest TreeWalkerTest \
XMLTestSuite XMLWriterTest XMLTestSuite XMLWriterTest NodeAppenderTest
target = testrunner target = testrunner
target_version = 1 target_version = 1

View File

@ -340,6 +340,9 @@
<File <File
RelativePath=".\src\EventTest.h"> RelativePath=".\src\EventTest.h">
</File> </File>
<File
RelativePath=".\src\NodeAppenderTest.h">
</File>
<File <File
RelativePath=".\src\NodeIteratorTest.h"> RelativePath=".\src\NodeIteratorTest.h">
</File> </File>
@ -377,6 +380,9 @@
<File <File
RelativePath=".\src\EventTest.cpp"> RelativePath=".\src\EventTest.cpp">
</File> </File>
<File
RelativePath=".\src\NodeAppenderTest.cpp">
</File>
<File <File
RelativePath=".\src\NodeIteratorTest.cpp"> RelativePath=".\src\NodeIteratorTest.cpp">
</File> </File>

View File

@ -1,7 +1,7 @@
<?xml version="1.0" encoding="Windows-1252"?> <?xml version="1.0" encoding="Windows-1252"?>
<VisualStudioProject <VisualStudioProject
ProjectType="Visual C++" ProjectType="Visual C++"
Version="8,00" Version="8.00"
Name="TestSuite" Name="TestSuite"
ProjectGUID="{C9ACF028-17A1-44C2-8C09-DFD3BD9E7D45}" ProjectGUID="{C9ACF028-17A1-44C2-8C09-DFD3BD9E7D45}"
Keyword="Win32Proj" Keyword="Win32Proj"
@ -482,6 +482,10 @@
RelativePath=".\src\EventTest.h" RelativePath=".\src\EventTest.h"
> >
</File> </File>
<File
RelativePath=".\src\NodeAppenderTest.h"
>
</File>
<File <File
RelativePath=".\src\NodeIteratorTest.h" RelativePath=".\src\NodeIteratorTest.h"
> >
@ -530,6 +534,10 @@
RelativePath=".\src\EventTest.cpp" RelativePath=".\src\EventTest.cpp"
> >
</File> </File>
<File
RelativePath=".\src\NodeAppenderTest.cpp"
>
</File>
<File <File
RelativePath=".\src\NodeIteratorTest.cpp" RelativePath=".\src\NodeIteratorTest.cpp"
> >

View File

@ -1,7 +1,7 @@
// //
// DOMTestSuite.cpp // DOMTestSuite.cpp
// //
// $Id: //poco/Main/XML/testsuite/src/DOMTestSuite.cpp#8 $ // $Id: //poco/Main/XML/testsuite/src/DOMTestSuite.cpp#9 $
// //
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH. // Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
// and Contributors. // and Contributors.
@ -41,6 +41,7 @@
#include "NodeIteratorTest.h" #include "NodeIteratorTest.h"
#include "TreeWalkerTest.h" #include "TreeWalkerTest.h"
#include "ParserWriterTest.h" #include "ParserWriterTest.h"
#include "NodeAppenderTest.h"
CppUnit::Test* DOMTestSuite::suite() CppUnit::Test* DOMTestSuite::suite()
@ -57,6 +58,7 @@ CppUnit::Test* DOMTestSuite::suite()
pSuite->addTest(NodeIteratorTest::suite()); pSuite->addTest(NodeIteratorTest::suite());
pSuite->addTest(TreeWalkerTest::suite()); pSuite->addTest(TreeWalkerTest::suite());
pSuite->addTest(ParserWriterTest::suite()); pSuite->addTest(ParserWriterTest::suite());
pSuite->addTest(NodeAppenderTest::suite());
return pSuite; return pSuite;
} }

View File

@ -0,0 +1,162 @@
//
// NodeAppenderTest.cpp
//
// $Id: //poco/Main/XML/testsuite/src/NodeAppenderTest.cpp#1 $
//
// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// Permission is hereby granted, free of charge, to any person or organization
// obtaining a copy of the software and accompanying documentation covered by
// this license (the "Software") to use, reproduce, display, distribute,
// execute, and transmit the Software, and to prepare derivative works of the
// Software, and to permit third-parties to whom the Software is furnished to
// do so, all subject to the following:
//
// The copyright notices in the Software and this entire statement, including
// the above license grant, this restriction and the following disclaimer,
// must be included in all copies of the Software, in whole or in part, and
// all derivative works of the Software, unless such copies or derivative
// works are solely in the form of machine-executable object code generated by
// a source language processor.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
#include "NodeAppenderTest.h"
#include "CppUnit/TestCaller.h"
#include "CppUnit/TestSuite.h"
#include "Poco/DOM/NodeAppender.h"
#include "Poco/DOM/Element.h"
#include "Poco/DOM/Document.h"
#include "Poco/DOM/DocumentFragment.h"
#include "Poco/DOM/AutoPtr.h"
using Poco::XML::NodeAppender;
using Poco::XML::Element;
using Poco::XML::Document;
using Poco::XML::DocumentFragment;
using Poco::XML::AutoPtr;
using Poco::XML::XMLString;
NodeAppenderTest::NodeAppenderTest(const std::string& name): CppUnit::TestCase(name)
{
}
NodeAppenderTest::~NodeAppenderTest()
{
}
void NodeAppenderTest::testAppendNode()
{
AutoPtr<Document> pDoc = new Document;
AutoPtr<Element> pRoot = pDoc->createElement("root");
pDoc->appendChild(pRoot);
NodeAppender appender(pRoot);
AutoPtr<Element> pElem1 = pDoc->createElement("elem");
AutoPtr<Element> pElem2 = pDoc->createElement("elem");
AutoPtr<Element> pElem3 = pDoc->createElement("elem");
appender.appendChild(pElem1);
appender.appendChild(pElem2);
appender.appendChild(pElem3);
assert (pRoot->firstChild() == pElem1);
assert (pRoot->lastChild() == pElem3);
assert (pElem1->nextSibling() == pElem2);
assert (pElem2->nextSibling() == pElem3);
assert (pElem3->nextSibling() == 0);
assert (pElem1->previousSibling() == 0);
assert (pElem2->previousSibling() == pElem1);
assert (pElem3->previousSibling() == pElem2);
assert (pElem1->parentNode() == pRoot);
assert (pElem2->parentNode() == pRoot);
assert (pElem3->parentNode() == pRoot);
}
void NodeAppenderTest::testAppendNodeList()
{
AutoPtr<Document> pDoc = new Document;
AutoPtr<Element> pRoot = pDoc->createElement("root");
pDoc->appendChild(pRoot);
NodeAppender appender(pRoot);
AutoPtr<DocumentFragment> pFrag1 = pDoc->createDocumentFragment();
AutoPtr<DocumentFragment> pFrag2 = pDoc->createDocumentFragment();
AutoPtr<DocumentFragment> pFrag3 = pDoc->createDocumentFragment();
AutoPtr<Element> pElem1 = pDoc->createElement("elem");
AutoPtr<Element> pElem2 = pDoc->createElement("elem");
AutoPtr<Element> pElem3 = pDoc->createElement("elem");
AutoPtr<Element> pElem4 = pDoc->createElement("elem");
pFrag2->appendChild(pElem1);
pFrag2->appendChild(pElem2);
pFrag2->appendChild(pElem3);
pFrag3->appendChild(pElem4);
appender.appendChild(pFrag1);
assert (pRoot->firstChild() == 0);
appender.appendChild(pFrag2);
assert (pRoot->firstChild() == pElem1);
assert (pRoot->lastChild() == pElem3);
assert (pElem1->nextSibling() == pElem2);
assert (pElem2->nextSibling() == pElem3);
assert (pElem3->nextSibling() == 0);
assert (pElem1->previousSibling() == 0);
assert (pElem2->previousSibling() == pElem1);
assert (pElem3->previousSibling() == pElem2);
assert (pElem1->parentNode() == pRoot);
assert (pElem2->parentNode() == pRoot);
assert (pElem3->parentNode() == pRoot);
appender.appendChild(pFrag3);
assert (pRoot->lastChild() == pElem4);
assert (pElem4->parentNode() == pRoot);
assert (pElem3->nextSibling() == pElem4);
assert (pElem4->previousSibling() == pElem3);
}
void NodeAppenderTest::setUp()
{
}
void NodeAppenderTest::tearDown()
{
}
CppUnit::Test* NodeAppenderTest::suite()
{
CppUnit::TestSuite* pSuite = new CppUnit::TestSuite("NodeAppenderTest");
CppUnit_addTest(pSuite, NodeAppenderTest, testAppendNode);
CppUnit_addTest(pSuite, NodeAppenderTest, testAppendNodeList);
return pSuite;
}

View File

@ -0,0 +1,61 @@
//
// NodeAppenderTest.h
//
// $Id: //poco/Main/XML/testsuite/src/NodeAppenderTest.h#1 $
//
// Definition of the NodeAppenderTest class.
//
// Copyright (c) 2007, Applied Informatics Software Engineering GmbH.
// and Contributors.
//
// Permission is hereby granted, free of charge, to any person or organization
// obtaining a copy of the software and accompanying documentation covered by
// this license (the "Software") to use, reproduce, display, distribute,
// execute, and transmit the Software, and to prepare derivative works of the
// Software, and to permit third-parties to whom the Software is furnished to
// do so, all subject to the following:
//
// The copyright notices in the Software and this entire statement, including
// the above license grant, this restriction and the following disclaimer,
// must be included in all copies of the Software, in whole or in part, and
// all derivative works of the Software, unless such copies or derivative
// works are solely in the form of machine-executable object code generated by
// a source language processor.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
// DEALINGS IN THE SOFTWARE.
//
#ifndef NodeAppenderTest_INCLUDED
#define NodeAppenderTest_INCLUDED
#include "Poco/XML/XML.h"
#include "CppUnit/TestCase.h"
class NodeAppenderTest: public CppUnit::TestCase
{
public:
NodeAppenderTest(const std::string& name);
~NodeAppenderTest();
void testAppendNode();
void testAppendNodeList();
void setUp();
void tearDown();
static CppUnit::Test* suite();
private:
};
#endif // NodeAppenderTest_INCLUDED

View File

@ -1,7 +1,7 @@
// //
// ParserWriterTest.cpp // ParserWriterTest.cpp
// //
// $Id: //poco/Main/XML/testsuite/src/ParserWriterTest.cpp#11 $ // $Id: //poco/Main/XML/testsuite/src/ParserWriterTest.cpp#12 $
// //
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH. // Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
// and Contributors. // and Contributors.
@ -40,7 +40,6 @@
#include "Poco/SAX/InputSource.h" #include "Poco/SAX/InputSource.h"
#include "Poco/XML/XMLWriter.h" #include "Poco/XML/XMLWriter.h"
#include <sstream> #include <sstream>
#include <fstream>
using Poco::XML::DOMParser; using Poco::XML::DOMParser;

View File

@ -1,7 +1,7 @@
// //
// SAXParserTest.cpp // SAXParserTest.cpp
// //
// $Id: //poco/Main/XML/testsuite/src/SAXParserTest.cpp#9 $ // $Id: //poco/Main/XML/testsuite/src/SAXParserTest.cpp#10 $
// //
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH. // Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
// and Contributors. // and Contributors.
@ -40,8 +40,8 @@
#include "Poco/SAX/WhitespaceFilter.h" #include "Poco/SAX/WhitespaceFilter.h"
#include "Poco/XML/XMLWriter.h" #include "Poco/XML/XMLWriter.h"
#include "Poco/Latin9Encoding.h" #include "Poco/Latin9Encoding.h"
#include "Poco/FileStream.h"
#include <sstream> #include <sstream>
#include <fstream>
using Poco::XML::SAXParser; using Poco::XML::SAXParser;
@ -277,7 +277,7 @@ void SAXParserTest::testRSS()
parser.setFeature(XMLReader::FEATURE_EXTERNAL_PARAMETER_ENTITIES, true); parser.setFeature(XMLReader::FEATURE_EXTERNAL_PARAMETER_ENTITIES, true);
std::istringstream istr(RSS); std::istringstream istr(RSS);
std::ofstream ostr("rss.xml", std::ios::binary); Poco::FileOutputStream ostr("rss.xml");
XMLWriter writer(ostr, XMLWriter::CANONICAL | XMLWriter::PRETTY_PRINT); XMLWriter writer(ostr, XMLWriter::CANONICAL | XMLWriter::PRETTY_PRINT);
filter.setContentHandler(&writer); filter.setContentHandler(&writer);
filter.setDTDHandler(&writer); filter.setDTDHandler(&writer);