1
0
Fork 0
Univerxel/deps/picoquic/picohash.h

74 lines
2.4 KiB
C

/*
* Author: Christian Huitema
* Copyright (c) 2017, Private Octopus, Inc.
* All rights reserved.
*
* Permission to use, copy, modify, and distribute this software for any
* purpose with or without fee is hereby granted, provided that the above
* copyright notice and this permission notice appear in all copies.
*
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
* WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
* DISCLAIMED. IN NO EVENT SHALL Private Octopus, Inc. BE LIABLE FOR ANY
* DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
* (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
* LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
* ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
* SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
/*
* Context hash.
* Retrieve an object based on a hash of a context ID, or alternatively based on
* source address and port number.
*/
#ifndef PICOHASH_H
#define PICOHASH_H
#include <stddef.h>
#include <stdint.h>
#ifdef __cplusplus
extern "C" {
#endif
typedef struct _picohash_item {
uint64_t hash;
struct _picohash_item* next_in_bin;
const void* key;
} picohash_item;
typedef struct picohash_table {
/* TODO: lock ! */
picohash_item** hash_bin;
size_t nb_bin;
size_t count;
uint64_t (*picohash_hash)(const void*);
int (*picohash_compare)(const void*, const void*);
} picohash_table;
picohash_table* picohash_create(size_t nb_bin,
uint64_t (*picohash_hash)(const void*),
int (*picohash_compute)(const void*, const void*));
picohash_item* picohash_retrieve(picohash_table* hash_table, const void* key);
int picohash_insert(picohash_table* hash_table, const void* key);
void picohash_delete_item(picohash_table* hash_table, picohash_item* item, int delete_key_too);
void picohash_delete_key(picohash_table* hash_table, void* key, int delete_key_too);
void picohash_delete(picohash_table* hash_table, int delete_key_too);
uint64_t picohash_hash_mix(uint64_t hash, uint64_t h2);
uint64_t picohash_bytes(const uint8_t* key, uint32_t length);
#ifdef __cplusplus
}
#endif
#endif /* PICOHASH_H */