X-Git-Url: http://www.project-moonshot.org/gitweb/?a=blobdiff_plain;f=xmltooling%2FAbstractComplexElement.cpp;h=a8e68ef7512266a8004099305a49bbb08bb4ff44;hb=30a436426f6fe4dd9f9657d131d09853fbd7b217;hp=7448602cfe6c08debd2a76780dcaf58efe70fc67;hpb=81b488b2790e7bdeb2f43560b1d4a7d22c3dfdf5;p=shibboleth%2Fcpp-xmltooling.git diff --git a/xmltooling/AbstractComplexElement.cpp b/xmltooling/AbstractComplexElement.cpp index 7448602..a8e68ef 100644 --- a/xmltooling/AbstractComplexElement.cpp +++ b/xmltooling/AbstractComplexElement.cpp @@ -28,17 +28,15 @@ #include "AbstractComplexElement.h" #include +#include +#include using namespace xmltooling; +using namespace xercesc; +using namespace boost::lambda; +using namespace boost; using namespace std; -using xercesc::XMLString; - -namespace { - bool _nonnull(const XMLObject* ptr) { - return (ptr!=nullptr); - } -} AbstractComplexElement::AbstractComplexElement() { @@ -46,21 +44,38 @@ AbstractComplexElement::AbstractComplexElement() AbstractComplexElement::AbstractComplexElement(const AbstractComplexElement& src) { - for (vector::const_iterator i=src.m_text.begin(); i!=src.m_text.end(); ++i) - m_text.push_back(XMLString::replicate(*i)); + static void (vector::* push_back)(XMLCh* const&) = &vector::push_back; + static XMLCh* (*replicate)(const XMLCh*,MemoryManager*) = &XMLString::replicate; + + for_each( + src.m_text.begin(), src.m_text.end(), + lambda::bind(push_back, boost::ref(m_text), lambda::bind(replicate, _1, XMLPlatformUtils::fgMemoryManager)) + ); } AbstractComplexElement::~AbstractComplexElement() { +#ifdef XMLTOOLING_XERCESC_HAS_XMLBYTE_RELEASE + static void (*release)(XMLCh**) = &XMLString::release; +#else + static void (*release)(XMLCh**,MemoryManager*) = &XMLString::release; +#endif + for_each(m_children.begin(), m_children.end(), cleanup()); - for (vector::iterator i=m_text.begin(); i!=m_text.end(); ++i) - XMLString::release(&(*i)); + for_each(m_text.begin(), m_text.end(), + lambda::bind( + release, &_1 +#ifndef XMLTOOLING_XERCESC_HAS_XMLBYTE_RELEASE + ,XMLPlatformUtils::fgMemoryManager +#endif + ) + ); } bool AbstractComplexElement::hasChildren() const { if (m_children.empty()) return false; - return (find_if(m_children.begin(), m_children.end(), _nonnull) != m_children.end()); + return (find_if(m_children.begin(), m_children.end(), (_1 != ((XMLObject*)nullptr))) != m_children.end()); } const list& AbstractComplexElement::getOrderedChildren() const @@ -87,5 +102,5 @@ void AbstractComplexElement::setTextContent(const XMLCh* value, unsigned int pos m_text.push_back(nullptr); ++size; } - m_text[position]=prepareForAssignment(m_text[position],value); + m_text[position] = prepareForAssignment(m_text[position], value); }