SourceForge.net Logo

StringPool.hpp

Go to the documentation of this file.
00001 /*
00002  * Copyright (c) 2001-2008
00003  *     DecisionSoft Limited. All rights reserved.
00004  * Copyright (c) 2004-2008
00005  *     Oracle. All rights reserved.
00006  *
00007  * Licensed under the Apache License, Version 2.0 (the "License");
00008  * you may not use this file except in compliance with the License.
00009  * You may obtain a copy of the License at
00010  *
00011  *     http://www.apache.org/licenses/LICENSE-2.0
00012  *
00013  * Unless required by applicable law or agreed to in writing, software
00014  * distributed under the License is distributed on an "AS IS" BASIS,
00015  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
00016  * See the License for the specific language governing permissions and
00017  * limitations under the License.
00018  *
00019  * $Id: StringPool.hpp 511 2008-02-25 20:25:17Z lauren_foutz $
00020  */
00021 
00022 #ifndef __STRINGPOOL_HPP
00023 #define __STRINGPOOL_HPP
00024 
00025 #include <xqilla/framework/XQillaExport.hpp>
00026 #include <xercesc/framework/MemoryManager.hpp>
00027 #include <memory>
00028 #include <cstring>
00029 //Added so xqilla will compile under CC on Solaris
00030 #include <string>
00031 
00032 class XQILLA_API StringPool
00033 {
00034 public:
00035   StringPool(XERCES_CPP_NAMESPACE_QUALIFIER MemoryManager *mm);
00036   ~StringPool();
00037 
00039   const XMLCh* getPooledString(const XMLCh *src);
00041   const XMLCh* getPooledString(const XMLCh *src, unsigned int length);
00043   const XMLCh* getPooledString(const char *src);
00044 
00045   unsigned int getCount() const { return _count; }
00046   unsigned int getHits() const { return _hits; }
00047   unsigned int getMisses() const { return _misses; }
00048   unsigned int getTooBig() const { return _toobig; }
00049   void dumpStatistics() const;
00050 
00051 private:
00052   StringPool(const StringPool&);
00053   StringPool &operator=(const StringPool&);
00054 
00055   static unsigned int hash(const XMLCh *v, unsigned int length);
00056   const XMLCh *replicate(const XMLCh *v, unsigned int length) const;
00057   void resize();
00058 
00059   class Bucket
00060   {
00061   public:
00062     Bucket(const XMLCh *v, unsigned int l, unsigned int h, Bucket *n)
00063       : value(v), length(l), hashValue(h), next(n) {}
00064 
00065     const XMLCh *value;
00066     unsigned int length;
00067     unsigned int hashValue;
00068     Bucket *next;
00069   };
00070 
00071   XERCES_CPP_NAMESPACE_QUALIFIER MemoryManager *_mm;
00072   Bucket **_bucketList;
00073   unsigned int _modulus;
00074   unsigned int _count;
00075   unsigned int _hits;
00076   unsigned int _misses;
00077   unsigned int _toobig;
00078 };
00079 
00080 inline unsigned int StringPool::hash(const XMLCh *v, unsigned int length)
00081 {
00082   unsigned int hashVal = 0;
00083   while(length) {
00084     hashVal += (hashVal * 37) + (hashVal >> 24) + (unsigned int)(*v);
00085     ++v;
00086     --length;
00087   }
00088   return hashVal;
00089 }
00090 
00091 inline const XMLCh *StringPool::replicate(const XMLCh *v, unsigned int length) const
00092 {
00093   unsigned int size = length * sizeof(XMLCh);
00094   XMLCh *ret = (XMLCh*)_mm->allocate(size + sizeof(XMLCh));
00095   memcpy(ret, v, size);
00096   ret[length] = 0;
00097   return ret;
00098 }
00099 
00100 #endif

Generated on Mon Apr 28 16:40:48 2008 for XQilla Simple API by  doxygen 1.5.1