git://scm.lunaixsky.com
/
lunaix-os.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
feat: brk and sbrk (mmap based)
[lunaix-os.git]
/
lunaix-os
/
includes
/
lunaix
/
ds
/
hstr.h
diff --git
a/lunaix-os/includes/lunaix/ds/hstr.h
b/lunaix-os/includes/lunaix/ds/hstr.h
index 5fb84d94bc36f0354b0088d761f53ccea0c8df49..d954103ce44f797024133d41f2189e37c97bc4ca 100644
(file)
--- a/
lunaix-os/includes/lunaix/ds/hstr.h
+++ b/
lunaix-os/includes/lunaix/ds/hstr.h
@@
-7,9
+7,9
@@
struct hstr
{
struct hstr
{
- u
nsigned in
t hash;
- u
nsigned in
t len;
- char* value;
+ u
32_
t hash;
+ u
32_
t len;
+ c
onst c
har* value;
};
#define HSTR(str, length) \
};
#define HSTR(str, length) \
@@
-18,12
+18,21
@@
struct hstr
.len = (length), .value = (str) \
}
.len = (length), .value = (str) \
}
+#define HHSTR(str, length, strhash) \
+ (struct hstr) \
+ { \
+ .len = (length), .value = (str), .hash = (strhash) \
+ }
+
#define HSTR_EQ(str1, str2) ((str1)->hash == (str2)->hash)
inline void
#define HSTR_EQ(str1, str2) ((str1)->hash == (str2)->hash)
inline void
-hstr_rehash(struct hstr* hash_str, u
nsigned in
t truncate_to)
+hstr_rehash(struct hstr* hash_str, u
32_
t truncate_to)
{
hash_str->hash = strhash_32(hash_str->value, truncate_to);
}
{
hash_str->hash = strhash_32(hash_str->value, truncate_to);
}
+void
+hstrcpy(struct hstr* dest, struct hstr* src);
+
#endif /* __LUNAIX_HSTR_H */
#endif /* __LUNAIX_HSTR_H */