Source code of Windows XP (NT5)
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
/*++
Copyright(c) 1995 Microsoft Corporation
MODULE NAME table.h
ABSTRACT Header file for generic hash table routines.
AUTHOR Anthony Discolo (adiscolo) 28-Jul-1995
REVISION HISTORY
--*/
//
// Number of hash table buckets.
//
#define NBUCKETS 13
//
// Generic hash table structure.
//
typedef struct _HASH_TABLE { LIST_ENTRY ListEntry[NBUCKETS]; // the hash buckets
ULONG ulSize; // number of total entries
} HASH_TABLE, *PHASH_TABLE;
//
// Hash table enumerator procedure.
// Returns TRUE to continue enumeration,
// FALSE to terminate enumeration.
//
typedef BOOLEAN (*PHASH_TABLE_ENUM_PROC)(PVOID, LPTSTR, PVOID);
PHASH_TABLE NewTable();
VOID ClearTable( IN PHASH_TABLE pTable );
VOID FreeTable( IN PHASH_TABLE pTable );
ULONG TableSize( IN PHASH_TABLE pTable );
VOID EnumTable( IN PHASH_TABLE pTable, IN PHASH_TABLE_ENUM_PROC pProc, IN PVOID pArg );
BOOLEAN GetTableEntry( IN PHASH_TABLE pTable, IN LPTSTR pszKey, OUT PVOID *pData );
BOOLEAN PutTableEntry( IN PHASH_TABLE pTable, IN LPTSTR pszKey, IN PVOID pData );
BOOLEAN DeleteTableEntry( IN PHASH_TABLE pTable, IN LPTSTR pszKey );
|