Main Page   Class Hierarchy   Compound List   File List   Compound Members  

StringPool.hpp

00001 /*
00002  * The Apache Software License, Version 1.1
00003  *
00004  * Copyright (c) 1999-2001 The Apache Software Foundation.  All rights
00005  * reserved.
00006  *
00007  * Redistribution and use in source and binary forms, with or without
00008  * modification, are permitted provided that the following conditions
00009  * are met:
00010  *
00011  * 1. Redistributions of source code must retain the above copyright
00012  *    notice, this list of conditions and the following disclaimer.
00013  *
00014  * 2. Redistributions in binary form must reproduce the above copyright
00015  *    notice, this list of conditions and the following disclaimer in
00016  *    the documentation and/or other materials provided with the
00017  *    distribution.
00018  *
00019  * 3. The end-user documentation included with the redistribution,
00020  *    if any, must include the following acknowledgment:
00021  *       "This product includes software developed by the
00022  *        Apache Software Foundation (http://www.apache.org/)."
00023  *    Alternately, this acknowledgment may appear in the software itself,
00024  *    if and wherever such third-party acknowledgments normally appear.
00025  *
00026  * 4. The names "Xerces" and "Apache Software Foundation" must
00027  *    not be used to endorse or promote products derived from this
00028  *    software without prior written permission. For written
00029  *    permission, please contact apache\@apache.org.
00030  *
00031  * 5. Products derived from this software may not be called "Apache",
00032  *    nor may "Apache" appear in their name, without prior written
00033  *    permission of the Apache Software Foundation.
00034  *
00035  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
00036  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
00037  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
00038  * DISCLAIMED.  IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
00039  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
00040  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
00041  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
00042  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
00043  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
00044  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
00045  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
00046  * SUCH DAMAGE.
00047  * ====================================================================
00048  *
00049  * This software consists of voluntary contributions made by many
00050  * individuals on behalf of the Apache Software Foundation, and was
00051  * originally based on software copyright (c) 1999, International
00052  * Business Machines, Inc., http://www.ibm.com .  For more information
00053  * on the Apache Software Foundation, please see
00054  * <http://www.apache.org/>.
00055  */
00056 
00057 /*
00058  * $Log: StringPool.hpp,v $
00059  * Revision 1.1  2002/05/11 21:10:09  bhavani
00060  * CR#CR062582# adding xercesc 1.7 file
00061  *
00062  * Revision 1.1.1.1  2002/02/01 22:22:12  peiyongz
00063  * sane_include
00064  *
00065  * Revision 1.5  2001/10/22 15:43:35  tng
00066  * [Bug 3361] "String pool id was not legal" error in Attributes::getURI().
00067  *
00068  * Revision 1.4  2000/07/07 22:16:52  jpolast
00069  * remove old put(value) function.  use put(key,value) instead.
00070  *
00071  * Revision 1.3  2000/02/24 20:05:25  abagchi
00072  * Swat for removing Log from API docs
00073  *
00074  * Revision 1.2  2000/02/06 07:48:04  rahulj
00075  * Year 2K copyright swat.
00076  *
00077  * Revision 1.1.1.1  1999/11/09 01:05:11  twl
00078  * Initial checkin
00079  *
00080  * Revision 1.2  1999/11/08 20:45:15  rahul
00081  * Swat for adding in Product name and CVS comment log variable.
00082  *
00083  */
00084 
00085 #if !defined(STRINGPOOL_HPP)
00086 #define STRINGPOOL_HPP
00087 
00088 #include <xercesc/util/RefHashTableOf.hpp>
00089 
00090 //
00091 //  This class implements a string pool, in which strings can be added and
00092 //  given a unique id by which they can be refered. It has to provide fast
00093 //  access both mapping from a string to its id and mapping from an id to
00094 //  its string. This requires that it provide two separate data structures.
00095 //  The map one is a hash table for quick storage and look up by name. The
00096 //  other is an array ordered by unique id which maps to the element in the
00097 //  hash table.
00098 //
00099 //  This works because strings cannot be removed from the pool once added,
00100 //  other than flushing it completely, and because ids are assigned
00101 //  sequentially from 1.
00102 //
00103 class XMLUTIL_EXPORT XMLStringPool
00104 {
00105 public :
00106     // -----------------------------------------------------------------------
00107     //  Constructors and Destructor
00108     // -----------------------------------------------------------------------
00109     XMLStringPool
00110     (
00111         const   unsigned int    modulus = 109
00112     );
00113     ~XMLStringPool();
00114 
00115 
00116     // -----------------------------------------------------------------------
00117     //  Pool management methods
00118     // -----------------------------------------------------------------------
00119     unsigned int addOrFind(const XMLCh* const newString);
00120     bool exists(const XMLCh* const newString) const;
00121     bool exists(const unsigned int id) const;
00122     void flushAll();
00123     unsigned int getId(const XMLCh* const toFind) const;
00124     const XMLCh* getValueForId(const unsigned int id) const;
00125 
00126 
00127 private :
00128     // -----------------------------------------------------------------------
00129     //  Private data types
00130     // -----------------------------------------------------------------------
00131     class PoolElem
00132     {
00133         public :
00134             PoolElem(const XMLCh* const string, const unsigned int id);
00135             ~PoolElem();
00136 
00137             inline const XMLCh* getKey() const { return fString; }
00138             void reset(const XMLCh* const string, const unsigned int id);
00139 
00140             unsigned int    fId;
00141             XMLCh*          fString;
00142 
00143     };
00144 
00145 
00146     // -----------------------------------------------------------------------
00147     //  Unimplemented constructors and operators
00148     // -----------------------------------------------------------------------
00149     XMLStringPool(const XMLStringPool&);
00150     void operator=(const XMLStringPool&);
00151 
00152 
00153     // -----------------------------------------------------------------------
00154     //  Private helper methods
00155     // -----------------------------------------------------------------------
00156     unsigned int addNewEntry(const XMLCh* const newString);
00157 
00158 
00159     // -----------------------------------------------------------------------
00160     //  Private data members
00161     //
00162     //  fIdMap
00163     //      This is an array of pointers to the pool elements. It is ordered
00164     //      by unique id, so using an id to index it gives instant access to
00165     //      the string of that id. This is grown as required.
00166     //
00167     //  fHashTable
00168     //      This is the hash table used to store and quickly access the
00169     //      strings.
00170     //
00171     //  fMapCapacity
00172     //      The current capacity of the id map. When the current id hits this
00173     //      value the map must must be expanded.
00174     //
00175     //  fCurId
00176     //      This is the counter used to assign unique ids. It is just bumped
00177     //      up one for each new string added.
00178     // -----------------------------------------------------------------------
00179     PoolElem**                  fIdMap;
00180     RefHashTableOf<PoolElem>*   fHashTable;
00181     unsigned int                fMapCapacity;
00182     unsigned int                fCurId;
00183 };
00184 
00185 #endif

Generated on Tue Nov 19 09:36:33 2002 by doxygen1.3-rc1