WMap.h
上传用户:hmc_gdtv
上传日期:2013-08-04
资源大小:798k
文件大小:2k
源码类别:

Windows Mobile

开发平台:

Visual C++

  1. /*
  2.  * Copyright (c) 2001,2002,2003 Mike Matsnev.  All Rights Reserved.
  3.  *
  4.  * Redistribution and use in source and binary forms, with or without
  5.  * modification, are permitted provided that the following conditions
  6.  * are met:
  7.  *
  8.  * 1. Redistributions of source code must retain the above copyright
  9.  *    notice immediately at the beginning of the file, without modification,
  10.  *    this list of conditions, and the following disclaimer.
  11.  * 2. Redistributions in binary form must reproduce the above copyright
  12.  *    notice, this list of conditions and the following disclaimer in the
  13.  *    documentation and/or other materials provided with the distribution.
  14.  * 3. Absolutely no warranty of function or purpose is made by the author
  15.  *    Mike Matsnev.
  16.  *
  17.  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  18.  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  19.  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
  20.  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
  21.  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
  22.  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  23.  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  24.  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  25.  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
  26.  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  27.  * 
  28.  * $Id: WMap.h,v 1.2.2.1 2003/04/12 22:52:34 mike Exp $
  29.  * 
  30.  */
  31. #ifndef WMAP_H
  32. #define WMAP_H
  33. class WMap {
  34. private:
  35.   enum {
  36.     STARTSIZE=128,
  37.     FILLFACTOR=3
  38.   };
  39.   struct HE {
  40.     HE     *next;
  41.     const wchar_t   *key;
  42.     UINT     hash;
  43.     void     *value;
  44.   };
  45.   int m_cursize;
  46.   int m_curmask;
  47.   int m_numkeys;
  48.   HE **m_array;
  49.   FastArray<HE> m_hepool;
  50.   StrBuf m_strbuf;
  51.   HANDLE m_heap;
  52.   bool m_freemem;
  53.   void Extend(); // grow the array
  54.   HE *RealLookup(const wchar_t *key,bool add,bool copykey);
  55. public:
  56.   WMap(HANDLE heap,bool freemem=false);
  57.   ~WMap();
  58.   bool Lookup(const wchar_t *key,void*& value);
  59.   void Add(const wchar_t *key,void *value) { RealLookup(key,true,false)->value=value; }
  60.   void AddCopy(const wchar_t *key,void *value) { RealLookup(key,true,true)->value=value; }
  61.   void RemoveAll();
  62.   static unsigned int Hash(const wchar_t *data);
  63. };
  64. #endif