X-Git-Url: https://pd.if.org/git/?p=nbds;a=blobdiff_plain;f=include%2Fstruct.h;h=9d12f73f120dc3beb466d72411050dd7f3400b09;hp=fa3f704631e0028fbc125cc16eb33a23815dbeb7;hb=2d93f3b29622488bde80b6cd18661fd7eb603eee;hpb=269f52d6f8cd031692c83afaa05c389115d05bd0 diff --git a/include/struct.h b/include/struct.h index fa3f704..9d12f73 100644 --- a/include/struct.h +++ b/include/struct.h @@ -3,4 +3,30 @@ #define DOES_NOT_EXIST 0 +#define EXPECT_DOES_NOT_EXIST ( 0) +#define EXPECT_EXISTS (-1) +#define EXPECT_WHATEVER (-2) + +typedef struct ht hashtable_t; +hashtable_t *ht_alloc (void); +uint64_t ht_compare_and_set (hashtable_t *ht, const char *key, uint32_t key_len, uint64_t expected_val, uint64_t val); +uint64_t ht_get (hashtable_t *ht, const char *key, uint32_t len); +uint64_t ht_remove (hashtable_t *ht, const char *key, uint32_t len); +uint64_t ht_count (hashtable_t *ht); +void ht_free (hashtable_t *ht); + +typedef struct ll list_t; +list_t * ll_alloc (void); +uint64_t ll_lookup (list_t *ll, const void *key_data, uint32_t key_len); +uint64_t ll_cas (list_t *ll, const void *key_data, uint32_t key_len, uint64_t expected_val, uint64_t new_val); +uint64_t ll_remove (list_t *ll, const void *key_data, uint32_t key_len); +void ll_print (list_t *ll); + +typedef struct sl skiplist_t; +skiplist_t * sl_alloc (void); +uint64_t sl_lookup (skiplist_t *sl, const void *key_data, uint32_t key_len); +uint64_t sl_cas (skiplist_t *sl, const void *key_data, uint32_t key_len, uint64_t expected_val, uint64_t new_val); +uint64_t sl_remove (skiplist_t *sl, const void *key_data, uint32_t key_len); +void sl_print (skiplist_t *sl); + #endif//STRUCT_H