1998-12-17 07:00:17 +00:00
|
|
|
/* -*- Mode: C; tab-width: 8; indent-tabs-mode: nil; -*-
|
|
|
|
*
|
1999-11-02 06:38:29 +00:00
|
|
|
* The contents of this file are subject to the Netscape Public
|
|
|
|
* License Version 1.1 (the "License"); you may not use this file
|
|
|
|
* except in compliance with the License. You may obtain a copy of
|
|
|
|
* the License at http://www.mozilla.org/NPL/
|
1998-12-17 07:00:17 +00:00
|
|
|
*
|
1999-11-02 06:38:29 +00:00
|
|
|
* Software distributed under the License is distributed on an "AS
|
|
|
|
* IS" basis, WITHOUT WARRANTY OF ANY KIND, either express or
|
|
|
|
* implied. See the License for the specific language governing
|
|
|
|
* rights and limitations under the License.
|
1998-12-17 07:00:17 +00:00
|
|
|
*
|
1999-11-02 06:38:29 +00:00
|
|
|
* The Original Code is mozilla.org code.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is Netscape
|
1998-12-17 07:00:17 +00:00
|
|
|
* Communications Corporation. Portions created by Netscape are
|
1999-11-02 06:38:29 +00:00
|
|
|
* Copyright (C) 1998 Netscape Communications Corporation. All
|
|
|
|
* Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
1998-12-17 07:00:17 +00:00
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef openhash_h__
|
|
|
|
#define openhash_h__
|
|
|
|
|
|
|
|
#include "prtypes.h"
|
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
/*******************************************************************************
|
|
|
|
* PLOpenhash
|
|
|
|
******************************************************************************/
|
|
|
|
|
|
|
|
typedef struct PLOpenhashElement {
|
|
|
|
PRUword key;
|
|
|
|
void* value;
|
|
|
|
} PLOpenhashElement;
|
|
|
|
|
|
|
|
typedef PRUword
|
|
|
|
(PR_CALLBACK* PLOpenhashHashFun)(void* context,
|
|
|
|
PLOpenhashElement* x);
|
|
|
|
|
|
|
|
typedef PRBool
|
|
|
|
(PR_CALLBACK* PLOpenhashEqualFun)(void* context,
|
|
|
|
PLOpenhashElement* x, PLOpenhashElement* y);
|
|
|
|
|
|
|
|
typedef void
|
|
|
|
(PR_CALLBACK* PLOpenhashDestroyFun)(void* context,
|
|
|
|
PLOpenhashElement* x);
|
|
|
|
|
|
|
|
typedef struct PLOpenhashHeader {
|
|
|
|
PRUword size;
|
|
|
|
PLOpenhashHashFun hash;
|
|
|
|
PLOpenhashEqualFun equal;
|
|
|
|
PLOpenhashDestroyFun destroy;
|
|
|
|
void* context;
|
|
|
|
} PLOpenhashHeader;
|
|
|
|
|
|
|
|
typedef struct PLOpenhash {
|
|
|
|
PLOpenhashHeader header;
|
|
|
|
PLOpenhashElement element[1];
|
|
|
|
/* more elements follow */
|
|
|
|
} PLOpenhash;
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
|
|
|
|
PR_EXTERN(PRStatus)
|
|
|
|
PL_OpenhashInit(PLOpenhash* self, PRUint32 initialSize,
|
|
|
|
PLOpenhashHashFun hash, PLOpenhashEqualFun equal,
|
|
|
|
PLOpenhashDestroyFun del, void* context);
|
|
|
|
|
|
|
|
PR_EXTERN(void)
|
|
|
|
PL_OpenhashCleanup(PLOpenhash* self);
|
|
|
|
|
|
|
|
PR_EXTERN(PLOpenhash*)
|
|
|
|
PL_NewOpenhash(PRUint32 initialSize,
|
|
|
|
PLOpenhashHashFun hash, PLOpenhashEqualFun equal,
|
|
|
|
PLOpenhashDestroyFun del, void* context);
|
|
|
|
|
|
|
|
PR_EXTERN(void)
|
|
|
|
PL_OpenhashDestroy(PLOpenhash* self);
|
|
|
|
|
|
|
|
PR_EXTERN(void*)
|
|
|
|
PL_OpenhashLookup(PLOpenhash* self, PRUword key);
|
|
|
|
|
|
|
|
PR_EXTERN(void)
|
|
|
|
PL_OpenhashAdd(PLOpenhash* self, PRUword key, void* value);
|
|
|
|
|
|
|
|
PR_EXTERN(PRStatus)
|
|
|
|
PL_OpenhashRemove(PLOpenhash* self, PRUword key);
|
|
|
|
|
|
|
|
PR_EXTERN(void)
|
|
|
|
PL_OpenhashEmpty(PLOpenhash* self);
|
|
|
|
|
|
|
|
#define PL_OpenhashSize(self) ((self)->keyCount)
|
|
|
|
|
|
|
|
/******************************************************************************/
|
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
|
|
|
#endif /* __cplusplus */
|
|
|
|
|
|
|
|
#endif /* openhash_h__ */
|
|
|
|
/******************************************************************************/
|