source: NonGTP/Xerces/xercesc/framework/psvi/XSNamedMap.c @ 188

Revision 188, 6.5 KB checked in by mattausch, 19 years ago (diff)

added xercesc to support

Line 
1/*
2 * The Apache Software License, Version 1.1
3 *
4 * Copyright (c) 2003 The Apache Software Foundation.  All rights
5 * reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without
8 * modification, are permitted provided that the following conditions
9 * are met:
10 *
11 * 1. Redistributions of source code must retain the above copyright
12 *    notice, this list of conditions and the following disclaimer.
13 *
14 * 2. Redistributions in binary form must reproduce the above copyright
15 *    notice, this list of conditions and the following disclaimer in
16 *    the documentation and/or other materials provided with the
17 *    distribution.
18 *
19 * 3. The end-user documentation included with the redistribution,
20 *    if any, must include the following acknowledgment:
21 *       "This product includes software developed by the
22 *        Apache Software Foundation (http://www.apache.org/)."
23 *    Alternately, this acknowledgment may appear in the software itself,
24 *    if and wherever such third-party acknowledgments normally appear.
25 *
26 * 4. The names "Xerces" and "Apache Software Foundation" must
27 *    not be used to endorse or promote products derived from this
28 *    software without prior written permission. For written
29 *    permission, please contact apache\@apache.org.
30 *
31 * 5. Products derived from this software may not be called "Apache",
32 *    nor may "Apache" appear in their name, without prior written
33 *    permission of the Apache Software Foundation.
34 *
35 * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
36 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
37 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
38 * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
39 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
40 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
41 * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
42 * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
43 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
44 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
45 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
46 * SUCH DAMAGE.
47 * ====================================================================
48 *
49 * This software consists of voluntary contributions made by many
50 * individuals on behalf of the Apache Software Foundation, and was
51 * originally based on software copyright (c) 1999, International
52 * Business Machines, Inc., http://www.ibm.com .  For more information
53 * on the Apache Software Foundation, please see
54 * <http://www.apache.org/>.
55 */
56
57/**
58 * $Log: XSNamedMap.c,v $
59 * Revision 1.3  2003/11/07 20:30:28  neilg
60 * fix compilation errors on AIX and HPUX; thanks to David Cargill
61 *
62 * Revision 1.2  2003/11/06 15:30:04  neilg
63 * first part of PSVI/schema component model implementation, thanks to David Cargill.  This covers setting the PSVIHandler on parser objects, as well as implementing XSNotation, XSSimpleTypeDefinition, XSIDCDefinition, and most of XSWildcard, XSComplexTypeDefinition, XSElementDeclaration, XSAttributeDeclaration and XSAttributeUse.
64 *
65 * Revision 1.1  2003/09/16 14:33:36  neilg
66 * PSVI/schema component model classes, with Makefile/configuration changes necessary to build them
67 *
68 */
69
70
71// ---------------------------------------------------------------------------
72//  Include
73// ---------------------------------------------------------------------------
74#if defined(XERCES_TMPLSINC)
75#include <xercesc/framework/psvi/XSNamedMap.hpp>
76#endif
77
78#include <xercesc/util/RefVectorOf.hpp>
79#include <xercesc/util/StringPool.hpp>
80
81XERCES_CPP_NAMESPACE_BEGIN
82
83// ---------------------------------------------------------------------------
84//  XSNamedMap: Constructors and Destructor
85// ---------------------------------------------------------------------------
86template <class TVal>
87XSNamedMap<TVal>::XSNamedMap(const unsigned int maxElems,
88                             const unsigned int modulus,
89                             XMLStringPool* uriStringPool,
90                             const bool adoptElems,
91                             MemoryManager* const manager)
92    : fMemoryManager(manager)
93    , fURIStringPool(uriStringPool)
94{
95    // allow one of the Vector or Hash to own the data... but not both...
96    fVector = new (manager) RefVectorOf<TVal> (maxElems, false, manager);
97    fHash = new (manager) RefHash2KeysTableOf<TVal> (modulus, adoptElems, manager);
98}
99template <class TVal> XSNamedMap<TVal>::~XSNamedMap()
100{
101    delete fVector;
102    delete fHash;
103}
104
105
106/**
107 * The number of <code>XSObjects</code> in the <code>XSObjectList</code>.
108 * The range of valid child object indices is 0 to
109 * <code>mapLength-1</code> inclusive.
110 */
111template <class TVal>
112unsigned int XSNamedMap<TVal>::getLength()
113{
114    return fVector->size();
115}
116
117/**
118 * Returns the <code>index</code>th item in the collection. The index
119 * starts at 0. If <code>index</code> is greater than or equal to the
120 * number of objects in the list, this returns <code>null</code>.
121 * @param index  index into the collection.
122 * @return  The <code>XSObject</code> at the <code>index</code>th
123 *   position in the <code>XSObjectList</code>, or <code>null</code> if
124 *   that is not a valid index.
125 */
126template <class TVal>
127TVal* XSNamedMap<TVal>::item(unsigned int index)
128{
129    if (index >= fVector->size())
130    {
131        return 0;
132    }
133    return fVector->elementAt(index);
134}
135
136/**
137 * Retrieves a component specified by local name and namespace URI.
138 * <br>applications must use the value null as the
139 * <code>compNamespace</code> parameter for components whose targetNamespace property
140 * is absent.
141 * @param compNamespace The namespace URI of the component to retrieve.
142 * @param localName The local name of the component to retrieve.
143 * @return A component (of any type) with the specified local
144 *   name and namespace URI, or <code>null</code> if they do not
145 *   identify any node in this map.
146 */
147template <class TVal>
148TVal *XSNamedMap<TVal>::itemByName(const XMLCh *compNamespace,
149                          const XMLCh *localName)
150{
151    return fHash->get((void*)localName, fURIStringPool->getId(compNamespace));
152}
153
154
155template <class TVal>
156void XSNamedMap<TVal>::addElement(TVal* const toAdd, const XMLCh* key1, const XMLCh* key2)
157{
158    fVector->addElement(toAdd);
159    fHash->put((void*)key1, fURIStringPool->getId(key2), toAdd);
160}
161
162XERCES_CPP_NAMESPACE_END
Note: See TracBrowser for help on using the repository browser.