From 460c52653ab0dcca6f19a4f492ed2c5e4e963ab0 Mon Sep 17 00:00:00 2001 From: toma Date: Wed, 25 Nov 2009 17:56:58 +0000 Subject: Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features. BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdepim@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da --- kmail/kmdict.cpp | 117 +++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 117 insertions(+) create mode 100644 kmail/kmdict.cpp (limited to 'kmail/kmdict.cpp') diff --git a/kmail/kmdict.cpp b/kmail/kmdict.cpp new file mode 100644 index 00000000..3386f16a --- /dev/null +++ b/kmail/kmdict.cpp @@ -0,0 +1,117 @@ +/* simple hash table for kmail. inspired by QDict */ +/* Author: Ronen Tzur */ + +#ifdef HAVE_CONFIG_H +#include +#endif + +#include "kmdict.h" +#include "kmglobal.h" +#include + +#include +//----------------------------------------------------------------------------- + +KMDict::KMDict( int size ) +{ + init( ( int ) KMail::nextPrime( size ) ); + //kdDebug( 5006 ) << "KMMDict::KMDict Size: " << mSize << endl; +} + +//----------------------------------------------------------------------------- + +KMDict::~KMDict() +{ + clear(); +} + +//----------------------------------------------------------------------------- + +void KMDict::init(int size) +{ + mSize = size; + mVecs = new KMDictItem *[mSize]; + memset(mVecs, 0, mSize * sizeof(KMDictItem *)); +} + +//----------------------------------------------------------------------------- + +void KMDict::clear() +{ + if (!mVecs) + return; + for (int i = 0; i < mSize; i++) { + KMDictItem *item = mVecs[i]; + while (item) { + KMDictItem *nextItem = item->next; + delete item; + item = nextItem; + } + } + delete [] mVecs; + mVecs = 0; +} + +//----------------------------------------------------------------------------- + +void KMDict::replace( long key, KMDictItem *item ) +{ + insert( key, item ); + removeFollowing( item, key ); // remove other items with same key +} + +//----------------------------------------------------------------------------- + + +void KMDict::insert( long key, KMDictItem *item ) +{ + item->key = key; + int idx = (unsigned long)key % mSize; // insert in + item->next = mVecs[idx]; // appropriate + mVecs[idx] = item; // column +} + +//----------------------------------------------------------------------------- + +void KMDict::remove(long key) +{ + int idx = (unsigned long)key % mSize; + KMDictItem *item = mVecs[idx]; + + if (item) { + if (item->key == key) { // if first in the column + mVecs[idx] = item->next; + delete item; + } else + removeFollowing(item, key); // if deep in the column + } +} + +//----------------------------------------------------------------------------- + +void KMDict::removeFollowing(KMDictItem *item, long key) +{ + while (item) { + KMDictItem *itemNext = item->next; + if (itemNext && itemNext->key == key) { + KMDictItem *itemNextNext = itemNext->next; + delete itemNext; + item->next = itemNextNext; + } else + item = itemNext; + } +} + +//----------------------------------------------------------------------------- + +KMDictItem *KMDict::find(long key) +{ + int idx = (unsigned long)key % mSize; + KMDictItem *item = mVecs[idx]; + while (item) { + if (item->key == key) + break; + item = item->next; + } + return item; +} -- cgit v1.2.3