Reducing header overuse, non-inlining selected methods (CPPOST-35).
[shibboleth/cpp-xmltooling.git] / xmltooling / AbstractComplexElement.cpp
1 /*
2 *  Copyright 2001-2009 Internet2
3  * 
4 * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *     http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16
17 /**
18  * AbstractComplexElement.cpp
19  * 
20  * Implementation of AbstractComplexElement.
21  */
22
23 #include "internal.h"
24 #include "AbstractComplexElement.h"
25
26 #include <algorithm>
27
28 using namespace xmltooling;
29 using namespace std;
30
31 using xercesc::XMLString;
32
33 namespace {
34     bool _nonnull(const XMLObject* ptr) {
35         return (ptr!=NULL);
36     }
37 }
38
39 AbstractComplexElement::AbstractComplexElement()
40 {
41 }
42
43 AbstractComplexElement::AbstractComplexElement(const AbstractComplexElement& src)
44 {
45     for (vector<XMLCh*>::const_iterator i=src.m_text.begin(); i!=src.m_text.end(); ++i)
46         m_text.push_back(XMLString::replicate(*i));
47 }
48
49 AbstractComplexElement::~AbstractComplexElement() {
50     for_each(m_children.begin(), m_children.end(), cleanup<XMLObject>());
51     for (vector<XMLCh*>::iterator i=m_text.begin(); i!=m_text.end(); ++i)
52         XMLString::release(&(*i));
53 }
54
55 bool AbstractComplexElement::hasChildren() const
56 {
57     if (m_children.empty())
58         return false;
59     return (find_if(m_children.begin(), m_children.end(), _nonnull) != m_children.end());
60 }
61
62 const list<XMLObject*>& AbstractComplexElement::getOrderedChildren() const
63 {
64     return m_children;
65 }
66
67 void AbstractComplexElement::removeChild(XMLObject* child)
68 {
69     m_children.erase(remove(m_children.begin(), m_children.end(), child), m_children.end());
70 }
71
72 const XMLCh* AbstractComplexElement::getTextContent(unsigned int position) const
73 {
74     return (m_text.size() > position) ? m_text[position] : NULL;
75 }
76
77 void AbstractComplexElement::setTextContent(const XMLCh* value, unsigned int position)
78 {
79     if (position > m_children.size())
80         throw XMLObjectException("Can't set text content relative to non-existent child position.");
81     vector<XMLCh*>::size_type size = m_text.size();
82     while (position >= size) {
83         m_text.push_back(NULL);
84         ++size;
85     }
86     m_text[position]=prepareForAssignment(m_text[position],value);
87 }