⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 qvdict.cpp

📁 Windows上的MUD客户端程序
💻 CPP
字号:
#include <QvDict.h>

struct QvDictListThing {
    QvPList	*keyList;
    QvPList	*valueList;
};

QvDict::QvDict( int entries )
{
    tableSize=entries;
    buckets=new QvDictEntry *[tableSize];
    for (int i = 0; i < tableSize; i++)
	buckets[i] = NULL;
}

QvDict::~QvDict()
{
    clear();
    delete [] buckets;
}

void
QvDict::clear()
{
    int		i;
    QvDictEntry	*entry, *nextEntry;

    for (i = 0; i < tableSize; i++) {

	for (entry = buckets[i]; entry != NULL; entry = nextEntry) {
	    nextEntry = entry->next;
		if (entry->boolDelete)		   // Added by jwd to delete QvPLists along with names
			delete ((QvPList*)(entry->value));
	    delete entry;
	}
	buckets[i] = NULL;
    }
}

QvBool
QvDict::enter(u_long key, void *value, unsigned char boolDelete /*= FALSE */)
{
    QvDictEntry		*&entry = findEntry(key);

    if (entry == NULL) {
	entry = new QvDictEntry(key, value);
	entry->next = NULL;
	entry->boolDelete = boolDelete;
	return TRUE;
    }
    else {
	entry->value = value;
	return FALSE;
    }
}

QvBool
QvDict::find(u_long key, void *&value) const
{
    QvDictEntry		*&entry = findEntry(key);

    if (entry == NULL) {
	value = NULL;
	return FALSE;
    }
    else {
	value = entry->value;
	return TRUE;
    }
}

QvDictEntry *&
QvDict::findEntry(u_long key) const
{
    QvDictEntry		**entry;

    entry = &buckets[key % tableSize];

    while (*entry != NULL) {
	if ((*entry)->key == key)
	    break;
	entry = &(*entry)->next;
    }
    return *entry;
}

QvBool
QvDict::remove(u_long key)
{
    QvDictEntry		*&entry = findEntry(key);
    QvDictEntry		*tmp;

    if (entry == NULL)
	return FALSE;
    else {
	tmp = entry;
	entry = entry->next;
	delete tmp;
	return TRUE;
    }
}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -