1 /* -*- Mode: C++; tab-width: 4; indent-tabs-mode: nil; c-basic-offset: 4 -*- */
2 /* ***** BEGIN LICENSE BLOCK *****
3 * Version: MPL 1.1/GPL 2.0/LGPL 2.1
5 * The contents of this file are subject to the Mozilla Public License Version
6 * 1.1 (the "License"); you may not use this file except in compliance with
7 * the License. You may obtain a copy of the License at
8 * http://www.mozilla.org/MPL/
10 * Software distributed under the License is distributed on an "AS IS" basis,
11 * WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
12 * for the specific language governing rights and limitations under the
15 * The Original Code is mozilla.org code.
17 * The Initial Developer of the Original Code is
18 * Netscape Communications Corporation.
19 * Portions created by the Initial Developer are Copyright (C) 1998
20 * the Initial Developer. All Rights Reserved.
24 * Alternatively, the contents of this file may be used under the terms of
25 * either of the GNU General Public License Version 2 or later (the "GPL"),
26 * or the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
27 * in which case the provisions of the GPL or the LGPL are applicable instead
28 * of those above. If you wish to allow use of your version of this file only
29 * under the terms of either the GPL or the LGPL, and not to allow others to
30 * use your version of this file under the terms of the MPL, indicate your
31 * decision by deleting the provisions above and replace them with the notice
32 * and other provisions required by the GPL or the LGPL. If you do not delete
33 * the provisions above, a recipient may use your version of this file under
34 * the terms of any one of the MPL, the GPL or the LGPL.
36 * ***** END LICENSE BLOCK *****
37 * This Original Code has been modified by IBM Corporation.
38 * Modifications made by IBM described herein are
39 * Copyright (c) International Business Machines
42 * Modifications to Mozilla code or documentation
43 * identified per MPL Section 3.3
45 * Date Modified by Description of modification
46 * 04/20/2000 IBM Corp. Added PR_CALLBACK for Optlink use in OS2
50 * nsHashtable is OBSOLETE. Use nsTHashtable or a derivative instead.
53 #ifndef nsHashtable_h__
54 #define nsHashtable_h__
60 #include "nsISupportsBase.h"
61 #include "nsTraceRefcnt.h"
63 class nsIObjectInputStream
;
64 class nsIObjectOutputStream
;
69 class NS_COM nsHashKey
{
73 mKeyType
= UnknownKey
;
75 MOZ_COUNT_CTOR(nsHashKey
);
80 // Virtual destructor because all hash keys are |delete|d via a
83 virtual ~nsHashKey(void);
84 virtual PRUint32
HashCode(void) const = 0;
85 virtual PRBool
Equals(const nsHashKey
*aKey
) const = 0;
86 virtual nsHashKey
*Clone() const = 0;
87 virtual nsresult
Write(nsIObjectOutputStream
* aStream
) const;
91 // used for verification that we're casting to the correct key type
101 nsHashKeyType
GetKeyType() const { return mKeyType
; }
103 nsHashKeyType mKeyType
;
107 // Enumerator and Read/Write callback functions.
109 // Return values for nsHashtableEnumFunc
111 kHashEnumerateStop
= PR_FALSE
,
112 kHashEnumerateNext
= PR_TRUE
,
113 kHashEnumerateRemove
= 2
117 (* nsHashtableEnumFunc
)(nsHashKey
*aKey
, void *aData
, void* aClosure
);
120 (* nsHashtableReadEntryFunc
)(nsIObjectInputStream
*aStream
, nsHashKey
**aKey
,
123 // NB: may be called with null aKey or aData, to free just one of the two.
125 (* nsHashtableFreeEntryFunc
)(nsIObjectInputStream
*aStream
, nsHashKey
*aKey
,
129 (* nsHashtableWriteDataFunc
)(nsIObjectOutputStream
*aStream
, void *aData
);
131 class NS_COM nsHashtable
{
135 PLDHashTable mHashtable
;
139 nsHashtable(PRUint32 aSize
= 16, PRBool threadSafe
= PR_FALSE
);
140 virtual ~nsHashtable();
142 PRInt32
Count(void) { return mHashtable
.entryCount
; }
143 PRBool
Exists(nsHashKey
*aKey
);
144 void *Put(nsHashKey
*aKey
, void *aData
);
145 void *Get(nsHashKey
*aKey
);
146 void *Remove(nsHashKey
*aKey
);
147 nsHashtable
*Clone();
148 void Enumerate(nsHashtableEnumFunc aEnumFunc
, void* aClosure
= NULL
);
150 void Reset(nsHashtableEnumFunc destroyFunc
, void* aClosure
= NULL
);
152 nsHashtable(nsIObjectInputStream
* aStream
,
153 nsHashtableReadEntryFunc aReadEntryFunc
,
154 nsHashtableFreeEntryFunc aFreeEntryFunc
,
156 nsresult
Write(nsIObjectOutputStream
* aStream
,
157 nsHashtableWriteDataFunc aWriteDataFunc
) const;
160 ////////////////////////////////////////////////////////////////////////////////
161 // nsObjectHashtable: an nsHashtable where the elements are C++ objects to be
164 typedef void* (* nsHashtableCloneElementFunc
)(nsHashKey
*aKey
, void *aData
, void* aClosure
);
166 class NS_COM nsObjectHashtable
: public nsHashtable
{
168 nsObjectHashtable(nsHashtableCloneElementFunc cloneElementFun
,
169 void* cloneElementClosure
,
170 nsHashtableEnumFunc destroyElementFun
,
171 void* destroyElementClosure
,
172 PRUint32 aSize
= 16, PRBool threadSafe
= PR_FALSE
);
173 ~nsObjectHashtable();
175 nsHashtable
*Clone();
177 PRBool
RemoveAndDelete(nsHashKey
*aKey
);
180 static PLDHashOperator
CopyElement(PLDHashTable
* table
,
181 PLDHashEntryHdr
* hdr
,
182 PRUint32 i
, void *arg
);
184 nsHashtableCloneElementFunc mCloneElementFun
;
185 void* mCloneElementClosure
;
186 nsHashtableEnumFunc mDestroyElementFun
;
187 void* mDestroyElementClosure
;
190 ////////////////////////////////////////////////////////////////////////////////
191 // nsSupportsHashtable: an nsHashtable where the elements are nsISupports*
195 class NS_COM nsSupportsHashtable
196 : private nsHashtable
199 typedef PRBool (* EnumFunc
) (nsHashKey
*aKey
, void *aData
, void* aClosure
);
201 nsSupportsHashtable(PRUint32 aSize
= 16, PRBool threadSafe
= PR_FALSE
)
202 : nsHashtable(aSize
, threadSafe
) {}
203 ~nsSupportsHashtable();
205 PRInt32
Count(void) {
206 return nsHashtable::Count();
208 PRBool
Exists(nsHashKey
*aKey
) {
209 return nsHashtable::Exists (aKey
);
211 PRBool
Put(nsHashKey
*aKey
,
213 nsISupports
**value
= nsnull
);
214 nsISupports
* Get(nsHashKey
*aKey
);
215 PRBool
Remove(nsHashKey
*aKey
, nsISupports
**value
= nsnull
);
216 nsHashtable
*Clone();
217 void Enumerate(EnumFunc aEnumFunc
, void* aClosure
= NULL
) {
218 nsHashtable::Enumerate(aEnumFunc
, aClosure
);
223 static PRBool
ReleaseElement(nsHashKey
*, void *, void *);
224 static PLDHashOperator
EnumerateCopy(PLDHashTable
*,
225 PLDHashEntryHdr
* hdr
,
226 PRUint32 i
, void *arg
);
229 ////////////////////////////////////////////////////////////////////////////////
230 // nsISupportsKey: Where keys are nsISupports objects that get refcounted.
232 #include "nsISupports.h"
234 class NS_COM nsISupportsKey
: public nsHashKey
{
239 nsISupportsKey(const nsISupportsKey
& aKey
) : mKey(aKey
.mKey
) {
241 mKeyType
= SupportsKey
;
246 nsISupportsKey(nsISupports
* key
) {
248 mKeyType
= SupportsKey
;
254 ~nsISupportsKey(void) {
258 PRUint32
HashCode(void) const {
259 return NS_PTR_TO_INT32(mKey
);
262 PRBool
Equals(const nsHashKey
*aKey
) const {
263 NS_ASSERTION(aKey
->GetKeyType() == SupportsKey
, "mismatched key types");
264 return (mKey
== ((nsISupportsKey
*) aKey
)->mKey
);
267 nsHashKey
*Clone() const {
268 return new nsISupportsKey(mKey
);
271 nsISupportsKey(nsIObjectInputStream
* aStream
, nsresult
*aResult
);
272 nsresult
Write(nsIObjectOutputStream
* aStream
) const;
276 class nsPRUint32Key
: public nsHashKey
{
280 nsPRUint32Key(PRUint32 key
) {
282 mKeyType
= PRUint32Key
;
287 PRUint32
HashCode(void) const {
291 PRBool
Equals(const nsHashKey
*aKey
) const {
292 return mKey
== ((const nsPRUint32Key
*) aKey
)->mKey
;
294 nsHashKey
*Clone() const {
295 return new nsPRUint32Key(mKey
);
297 PRUint32
GetValue() { return mKey
; }
300 ////////////////////////////////////////////////////////////////////////////////
301 // nsVoidKey: Where keys are void* objects that don't get refcounted.
303 class nsVoidKey
: public nsHashKey
{
308 nsVoidKey(const nsVoidKey
& aKey
) : mKey(aKey
.mKey
) {
310 mKeyType
= aKey
.mKeyType
;
314 nsVoidKey(void* key
) {
321 PRUint32
HashCode(void) const {
322 return NS_PTR_TO_INT32(mKey
);
325 PRBool
Equals(const nsHashKey
*aKey
) const {
326 NS_ASSERTION(aKey
->GetKeyType() == VoidKey
, "mismatched key types");
327 return (mKey
== ((const nsVoidKey
*) aKey
)->mKey
);
330 nsHashKey
*Clone() const {
331 return new nsVoidKey(mKey
);
334 void* GetValue() { return mKey
; }
337 ////////////////////////////////////////////////////////////////////////////////
338 // nsIDKey: Where keys are nsIDs (e.g. nsIID, nsCID).
342 class NS_COM nsIDKey
: public nsHashKey
{
347 nsIDKey(const nsIDKey
& aKey
) : mID(aKey
.mID
) {
353 nsIDKey(const nsID
&aID
) {
360 PRUint32
HashCode(void) const {
364 PRBool
Equals(const nsHashKey
*aKey
) const {
365 NS_ASSERTION(aKey
->GetKeyType() == IDKey
, "mismatched key types");
366 return (mID
.Equals(((const nsIDKey
*) aKey
)->mID
));
369 nsHashKey
*Clone() const {
370 return new nsIDKey(mID
);
373 nsIDKey(nsIObjectInputStream
* aStream
, nsresult
*aResult
);
374 nsresult
Write(nsIObjectOutputStream
* aStream
) const;
377 ////////////////////////////////////////////////////////////////////////////////
379 #include "nsString.h"
381 // for null-terminated c-strings
382 class NS_COM nsCStringKey
: public nsHashKey
{
385 // NB: when serializing, NEVER_OWN keys are deserialized as OWN.
387 NEVER_OWN
, // very long lived, even clones don't need to copy it.
388 OWN_CLONE
, // as long lived as this key. But clones make a copy.
389 OWN
// to be free'd in key dtor. Clones make their own copy.
392 nsCStringKey(const nsCStringKey
& aStrKey
);
393 nsCStringKey(const char* str
, PRInt32 strLen
= -1, Ownership own
= OWN_CLONE
);
394 nsCStringKey(const nsAFlatCString
& str
);
395 nsCStringKey(const nsACString
& str
);
398 PRUint32
HashCode(void) const;
399 PRBool
Equals(const nsHashKey
* aKey
) const;
400 nsHashKey
* Clone() const;
401 nsCStringKey(nsIObjectInputStream
* aStream
, nsresult
*aResult
);
402 nsresult
Write(nsIObjectOutputStream
* aStream
) const;
404 // For when the owner of the hashtable wants to peek at the actual
405 // string in the key. No copy is made, so be careful.
406 const char* GetString() const { return mStr
; }
407 PRUint32
GetStringLength() const { return mStrLen
; }
412 Ownership mOwnership
;
415 // for null-terminated unicode strings
416 class NS_COM nsStringKey
: public nsHashKey
{
419 // NB: when serializing, NEVER_OWN keys are deserialized as OWN.
421 NEVER_OWN
, // very long lived, even clones don't need to copy it.
422 OWN_CLONE
, // as long lived as this key. But clones make a copy.
423 OWN
// to be free'd in key dtor. Clones make their own copy.
426 nsStringKey(const nsStringKey
& aKey
);
427 nsStringKey(const PRUnichar
* str
, PRInt32 strLen
= -1, Ownership own
= OWN_CLONE
);
428 nsStringKey(const nsAFlatString
& str
);
429 nsStringKey(const nsAString
& str
);
432 PRUint32
HashCode(void) const;
433 PRBool
Equals(const nsHashKey
* aKey
) const;
434 nsHashKey
* Clone() const;
435 nsStringKey(nsIObjectInputStream
* aStream
, nsresult
*aResult
);
436 nsresult
Write(nsIObjectOutputStream
* aStream
) const;
438 // For when the owner of the hashtable wants to peek at the actual
439 // string in the key. No copy is made, so be careful.
440 const PRUnichar
* GetString() const { return mStr
; }
441 PRUint32
GetStringLength() const { return mStrLen
; }
446 Ownership mOwnership
;
449 ////////////////////////////////////////////////////////////////////////////////
451 #endif // nsHashtable_h__