table of contents
HASHKIT_GET_DISTRIBUTION_FUNCTION(3) | libmemcached-awesome | HASHKIT_GET_DISTRIBUTION_FUNCTION(3) |
NAME¶
hashkit_get_distribution_function - libhashkit Documentation
SYNOPSIS¶
- #include <libhashkit-1.0/hashkit.h>
- Compile and link with -lhashkit
- Param key
- the key to generate a hash of
- Param key_length
- the length of the key without any terminating zero byte
- Param context
- the custom hash function context set through hashkit_set_custom_function() or hashkit_set_custom_distribution_function()
- Returns
- the custom hash function should return a hash value for key as an unsigned 32bit integer
- enumerator HASHKIT_SUCCESS
- Operation succeeded.
- enumerator HASHKIT_FAILURE
- Operation failed.
- enumerator HASHKIT_MEMORY_ALLOCATION_FAILURE
- Memory allocation failed.
- enumerator HASHKIT_INVALID_HASH
- Invalid hashkit_hash_algorithm_t passed.
- enumerator HASHKIT_INVALID_ARGUMENT
- Invalid argument passed.
- enumerator HASHKIT_HASH_DEFAULT
- Default hash algorithm (one_at_a_time).
- enumerator HASHKIT_HASH_HSIEH
- Only available if libhashkit hash been built with HSIEH support.
- enumerator HASHKIT_HASH_MURMUR
- Only available if libhashkit has been built with MURMUR support.
- enumerator HASHKIT_HASH_MURMUR3
- Only available if libhashkit has been built with MURMUR support.
- enumerator HASHKIT_HASH_CUSTOM
- Use custom hashkit_hash_fn function set through hashkit_set_custom_function() or hashkit_set_custom_distribution_function().
- hash -- pointer to an initialized hashkit_st struct
- hash_algorithm -- valid hashkit_hash_algorithm_t constant
- Returns
- hashkit_return_t indicating success or failure
- hash -- pointer to initialized hashkit_st struct
- function -- hashkit_hash_fn function pointer to use as hash function for HASHKIT_HASH_CUSTOM
- context -- pointer to an opaque user managed context for the custom hash function
- Returns
- hashkit_return_t indicating success or failure
- Parameters
- hash -- pointer to an initialized hashkit_st struct
- Returns
- hashkit_hash_algorithm_t indicating the currently set hash algorithm to use
- hash -- pointer to an initialized hashkit_st struct
- hash_algorithm -- valid hashkit_hash_algrothm_t constant
- Returns
- hashkit_return_t indicating success or failure
- hash -- pointer to initialized hashkit_st struct
- function -- hashkit_hash_fn function pointer to use as distribution hash function for HASHKIT_HASH_CUSTOM
- context -- pointer to an opaque user managed context for the custom distribution hash function
- Parameters
- hash -- pointer to an initialized hashkit_st struct
- Returns
- hashkit_hash_algorithm_t indicating the currently set distribution hash algorithm to use
DESCRIPTION¶
These functions are used to set and retrieve the key and distribution hash functions.
RETURN VALUE¶
hashkit_set_function(), hashkit_set_custom_function() and the distribution equivalents return hashkit_return_t::HASHKIT_SUCCESS on success.
hashkit_get_function() and hashkit_get_distribution_function() return hashkit_hash_algorithm_t indicating the hash function used.
SEE ALSO¶
libhashkit(3) hashkit_create(3) hashkit_functions(3)
February 1, 2024 | 1.1 |