diff options
author | Toni Uhlig <matzeton@googlemail.com> | 2023-07-16 02:03:33 +0200 |
---|---|---|
committer | Toni Uhlig <matzeton@googlemail.com> | 2023-07-16 02:03:33 +0200 |
commit | 5a40295c4cf0af5ea8da9ced04a4ce7d3621a080 (patch) | |
tree | cb21506e7b04d10b45d6066a0ee1655563d5d52b /external/hash/str_set.c |
Squashed 'flatcc/' content from commit 473da2a
git-subtree-dir: flatcc
git-subtree-split: 473da2afa5ca435363f8c5e6569167aee6bc31c5
Diffstat (limited to 'external/hash/str_set.c')
-rw-r--r-- | external/hash/str_set.c | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/external/hash/str_set.c b/external/hash/str_set.c new file mode 100644 index 0000000..87a3766 --- /dev/null +++ b/external/hash/str_set.c @@ -0,0 +1,61 @@ +/* + * The MIT License (MIT) + * + * Copyright (c) 2015 Mikkel F. Jørgensen, dvide.com + * + * Permission is hereby granted, free of charge, to any person obtaining a copy + * of this software and associated documentation files (the "Software"), to deal + * in the Software without restriction, including without limitation the rights + * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell + * copies of the Software, and to permit persons to whom the Software is + * furnished to do so, subject to the following conditions: + * + * The above copyright notice and this permission notice shall be included in all + * copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. + */ + +#include <string.h> + +#include "str_set.h" +#include "hash_table_def.h" +DEFINE_HASH_TABLE(str_set) +#if defined(STR_SET_RH) +#include "hash_table_impl_rh.h" +#else +#include "hash_table_impl.h" +#endif + +/* + * Simple default implementation of a hash set. The stored items are + * zero-terminated strings. The hash table does not manage the + * allocation of the strings, like it doesn't manage any stored items. + * However, it items are created with, say, strndup, a destructor can be + * provided to free each item when clearing the table. The remove + * operation also returns the removed item so it can be deallocated by + * callee. + * + * In general, the key and the item are different, but here they are the + * same. Normally the key would be referenced by the item. + */ +static inline int ht_match(const void *key, size_t len, str_set_item_t item) +{ + return strncmp(key, item, len) == 0; +} + +static inline const void *ht_key(str_set_item_t item) +{ + return (const void *)item; +} + +static inline size_t ht_key_len(str_set_item_t item) +{ + return strlen(item); +} |