File:  [DVB] / dietlibc / include / search.h
Revision 1.1: download - view: text, annotated - select for diffs
Sun Oct 12 21:38:40 2014 UTC (9 years, 7 months ago) by leitner
Branches: MAIN
CVS tags: HEAD
  add implementation of hsearch and friends

#ifndef SEARCH_H
#define SEARCH_H

#include <sys/cdefs.h>
#include <stddef.h>
#include <stdint.h>

typedef enum { FIND, ENTER } ACTION;
typedef struct entry { char* key; void* data; } ENTRY;

extern ENTRY* hsearch(ENTRY item, ACTION action) __THROW;
extern int hcreate(size_t count) __THROW;
extern void hdestroy(void) __THROW;

#ifdef _GNU_SOURCE
/* This is the internal structure of the hash table buckets.
 * Do not use it or your program will be dietlibc-only!
 * It's here so it's possible to write traversal code. */
struct bucket {
  struct bucket* next;
  struct entry e;
  size_t hv;
};
#else
struct bucket;
#endif

struct hsearch_data {
  struct bucket** table;
  size_t size, filled;
  unsigned char key[16];
};

extern int hsearch_r(ENTRY item, ACTION action, ENTRY** retval, struct hsearch_data* htab) __THROW;
extern int hcreate_r(size_t count, struct hsearch_data* htab) __THROW;
extern void hdestroy_r(struct hsearch_data* htab) __THROW;

extern uint64_t siphash24(const unsigned char key[16], const unsigned char *in, size_t len) __THROW;

#endif

LinuxTV legacy CVS <linuxtv.org/cvs>