70 lines
1.3 KiB
C
70 lines
1.3 KiB
C
|
/*
|
||
|
* Copyright 2004-2007, Ingo Weinhold, bonefish@users.sf.net. All rights reserved.
|
||
|
* Distributed under the terms of the MIT License.
|
||
|
*/
|
||
|
#ifndef HASH_STRING_H
|
||
|
#define HASH_STRING_H
|
||
|
|
||
|
#include <SupportDefs.h>
|
||
|
|
||
|
// string_hash
|
||
|
//
|
||
|
// from the Dragon Book: a slightly modified hashpjw()
|
||
|
static inline
|
||
|
uint32
|
||
|
string_hash(const char *name)
|
||
|
{
|
||
|
uint32 h = 0;
|
||
|
if (name) {
|
||
|
for (; *name; name++) {
|
||
|
uint32 g = h & 0xf0000000;
|
||
|
if (g)
|
||
|
h ^= g >> 24;
|
||
|
h = (h << 4) + *name;
|
||
|
}
|
||
|
}
|
||
|
return h;
|
||
|
}
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
|
||
|
namespace BPrivate {
|
||
|
|
||
|
// HashString
|
||
|
class HashString {
|
||
|
public:
|
||
|
HashString();
|
||
|
HashString(const HashString &string);
|
||
|
HashString(const char *string, int32 length = -1);
|
||
|
~HashString();
|
||
|
|
||
|
bool SetTo(const char *string, int32 maxLength = -1);
|
||
|
void Unset();
|
||
|
|
||
|
void Truncate(int32 newLength);
|
||
|
|
||
|
const char *GetString() const;
|
||
|
int32 GetLength() const { return fLength; }
|
||
|
|
||
|
uint32 GetHashCode() const { return string_hash(GetString()); }
|
||
|
|
||
|
HashString &operator=(const HashString &string);
|
||
|
bool operator==(const HashString &string) const;
|
||
|
bool operator!=(const HashString &string) const { return !(*this == string); }
|
||
|
|
||
|
private:
|
||
|
bool _SetTo(const char *string, int32 length);
|
||
|
|
||
|
private:
|
||
|
int32 fLength;
|
||
|
char *fString;
|
||
|
};
|
||
|
|
||
|
} // namespace BPrivate
|
||
|
|
||
|
using BPrivate::HashString;
|
||
|
|
||
|
#endif // __cplusplus
|
||
|
|
||
|
#endif // HASH_STRING_H
|