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

Revision 188, 7.0 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.hpp,v $
59 * Revision 1.3  2004/01/29 11:46:30  cargilld
60 * Code cleanup changes to get rid of various compiler diagnostic messages.
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#if !defined(XSNAMEDMAP_HPP)
72#define XSNAMEDMAP_HPP
73
74
75#include <xercesc/util/XMemory.hpp>
76#include <xercesc/util/RefHash2KeysTableOf.hpp>
77
78XERCES_CPP_NAMESPACE_BEGIN
79
80class XMLStringPool;
81
82/*
83 * This template provides convenient mappings between name,namespace
84 * pairs and individual components, as well as means to iterate through all the
85 * named components on some object.
86 */
87
88template <class TVal> class XSNamedMap: public XMemory
89{
90public:
91    // -----------------------------------------------------------------------
92    //  Constructors and Destructor
93    // -----------------------------------------------------------------------
94    /** @name Constructors */
95    //@{
96
97    XSNamedMap(const unsigned int maxElems,
98        const unsigned int modulus,
99        XMLStringPool* uriStringPool,
100        const bool adoptElems,
101        MemoryManager* const manager = XMLPlatformUtils::fgMemoryManager
102    );
103    //@}
104
105    /** @name Destructor */
106    //@{
107    ~XSNamedMap();
108
109    //@}
110
111    // -----------------------------------------------------------------------
112    //  XSNamedMap methods
113    // -----------------------------------------------------------------------
114    /** @name XSNamedMap methods */
115    //@{
116
117    /**
118     * The number of <code>XSObjects</code> in the <code>XSObjectList</code>.
119     * The range of valid child object indices is 0 to
120     * <code>mapLength-1</code> inclusive.
121     */
122    unsigned int getLength();
123
124    /**
125     *  Returns the <code>index</code>th item in the collection. The index
126     * starts at 0. If <code>index</code> is greater than or equal to the
127     * number of objects in the list, this returns <code>null</code>.
128     * @param index  index into the collection.
129     * @return  The <code>XSObject</code> at the <code>index</code>th
130     *   position in the <code>XSObjectList</code>, or <code>null</code> if
131     *   that is not a valid index.
132     */
133    TVal *item(unsigned int index);
134
135    /**
136     * Retrieves a component specified by local name and namespace URI.
137     * <br>applications must use the value null as the
138     * <code>compNamespace</code> parameter for components whose targetNamespace property
139     * is absent.
140     * @param compNamespace The namespace URI of the component to retrieve.
141     * @param localName The local name of the component to retrieve.
142     * @return A component (of any type) with the specified local
143     *   name and namespace URI, or <code>null</code> if they do not
144     *   identify any node in this map.
145     */
146    TVal *itemByName(const XMLCh *compNamespace,
147                              const XMLCh *localName);
148
149    //@}
150
151    //----------------------------------
152    /** methods needed by implementation */
153
154    //@{
155    void addElement(TVal* const toAdd, const XMLCh* key1, const XMLCh* key2);
156    //@}
157   
158
159private :
160    // -----------------------------------------------------------------------
161    //  Unimplemented constructors and operators
162    // -----------------------------------------------------------------------
163    XSNamedMap(const XSNamedMap<TVal>&);
164    XSNamedMap<TVal>& operator=(const XSNamedMap<TVal>&);
165
166    // -----------------------------------------------------------------------
167    //  Data members
168    //
169    // fMemoryManager
170    //  manager used to allocate memory needed by this object
171    MemoryManager *const        fMemoryManager;
172    XMLStringPool*              fURIStringPool;
173    RefVectorOf<TVal>*          fVector;
174    RefHash2KeysTableOf<TVal>*  fHash;
175};
176
177
178
179XERCES_CPP_NAMESPACE_END
180
181#if !defined(XERCES_TMPLSINC)
182#include <xercesc/framework/psvi/XSNamedMap.c>
183#endif
184
185#endif
Note: See TracBrowser for help on using the repository browser.