Newer
Older
* Copyright 1999-2002,2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
* Revision 1.8 2004/09/08 13:56:13 peiyongz
* Apache License Version 2.0
*
David Abram Cargill
committed
* Revision 1.7 2003/12/17 00:18:34 cargilld
* Update to memory management so that the static memory manager (one used to call Initialize) is only for static data.
*
* Revision 1.6 2003/05/15 18:26:29 knoaman
* Partial implementation of the configurable memory manager.
*
* Revision 1.5 2002/11/04 14:58:18 tng
* C++ Namespace Support.
*
* Revision 1.4 2002/09/24 20:02:20 tng
* Performance: use XMLString::equals instead of XMLString::compareString
*
Tinny Ng
committed
* Revision 1.3 2002/07/05 20:12:35 tng
* [Bug 9788] VecAttrListImpl::getValue skips prefix if SAX namespace validation is on.
*
* Revision 1.2 2002/02/27 16:49:40 tng
* Fix: AttributeList::getName should attach prefix if present
*
* Revision 1.1.1.1 2002/02/01 22:21:58 peiyongz
* sane_include
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
*
* Revision 1.6 2000/11/02 01:14:07 andyh
* SAX bug fix: Attribute lists were throwing exceptions rather than returning
* null when an attribute could not be found by name. Fixed by Tinny Ng.
*
* Revision 1.5 2000/03/13 20:19:11 rahulj
* Fixed #54. Changed self-assignment to now use the parameter value.
* Reported by Helmut Eiken <H.Eiken@cli.de>
*
* Revision 1.4 2000/03/02 19:54:29 roddey
* This checkin includes many changes done while waiting for the
* 1.1.0 code to be finished. I can't list them all here, but a list is
* available elsewhere.
*
* Revision 1.3 2000/02/06 07:47:53 rahulj
* Year 2K copyright swat.
*
* Revision 1.2 1999/12/15 19:49:37 roddey
* Added second getValue() method which takes a short name for the attribute
* to get the value for. Just a convenience method.
*
* Revision 1.1.1.1 1999/11/09 01:08:19 twl
* Initial checkin
*
* Revision 1.2 1999/11/08 20:44:44 rahul
* Swat for adding in Product name and CVS comment log variable.
*
*/
// ---------------------------------------------------------------------------
// Includes
// ---------------------------------------------------------------------------
#include <xercesc/util/Janitor.hpp>
#include <xercesc/internal/VecAttrListImpl.hpp>
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
// ---------------------------------------------------------------------------
// Constructors and Destructor
// ---------------------------------------------------------------------------
VecAttrListImpl::VecAttrListImpl() :
fAdopt(false)
, fCount(0)
, fVector(0)
{
}
VecAttrListImpl::~VecAttrListImpl()
{
//
// Note that some compilers can't deal with the fact that the pointer
// is to a const object, so we have to cast off the const'ness here!
//
if (fAdopt)
delete (RefVectorOf<XMLAttr>*)fVector;
}
// ---------------------------------------------------------------------------
// Implementation of the attribute list interface
// ---------------------------------------------------------------------------
unsigned int VecAttrListImpl::getLength() const
{
return fCount;
}
const XMLCh* VecAttrListImpl::getName(const unsigned int index) const
{
if (index >= fCount) {
return 0;
}
return fVector->elementAt(index)->getQName();
}
const XMLCh* VecAttrListImpl::getType(const unsigned int index) const
{
if (index >= fCount) {
return 0;
}
David Abram Cargill
committed
return XMLAttDef::getAttTypeString(fVector->elementAt(index)->getType(), fVector->getMemoryManager());
}
const XMLCh* VecAttrListImpl::getValue(const unsigned int index) const
{
if (index >= fCount) {
return 0;
}
return fVector->elementAt(index)->getValue();
}
const XMLCh* VecAttrListImpl::getType(const XMLCh* const name) const
{
//
// Search the vector for the attribute with the given name and return
// its type.
//
for (unsigned int index = 0; index < fCount; index++)
{
const XMLAttr* curElem = fVector->elementAt(index);
if (XMLString::equals(curElem->getQName(), name))
David Abram Cargill
committed
return XMLAttDef::getAttTypeString(curElem->getType(), fVector->getMemoryManager());
}
return 0;
}
const XMLCh* VecAttrListImpl::getValue(const XMLCh* const name) const
{
//
// Search the vector for the attribute with the given name and return
// its type.
//
for (unsigned int index = 0; index < fCount; index++)
{
const XMLAttr* curElem = fVector->elementAt(index);
if (XMLString::equals(curElem->getQName(), name))
return curElem->getValue();
}
return 0;
}
const XMLCh* VecAttrListImpl::getValue(const char* const name) const
{
// Temporarily transcode the name for lookup
XMLCh* wideName = XMLString::transcode(name, XMLPlatformUtils::fgMemoryManager);
ArrayJanitor<XMLCh> janName(wideName, XMLPlatformUtils::fgMemoryManager);
//
// Search the vector for the attribute with the given name and return
// its type.
//
for (unsigned int index = 0; index < fCount; index++)
{
const XMLAttr* curElem = fVector->elementAt(index);
if (XMLString::equals(curElem->getQName(), wideName))
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
return curElem->getValue();
}
return 0;
}
// ---------------------------------------------------------------------------
// Setter methods
// ---------------------------------------------------------------------------
void VecAttrListImpl::setVector(const RefVectorOf<XMLAttr>* const srcVec
, const unsigned int count
, const bool adopt)
{
//
// Delete the previous vector (if any) if we are adopting. Note that some
// compilers can't deal with the fact that the pointer is to a const
// object, so we have to cast off the const'ness here!
//
if (fAdopt)
delete (RefVectorOf<XMLAttr>*)fVector;
fAdopt = adopt;
fCount = count;
fVector = srcVec;
}