3b2c863f1c
* It was not self containing, as it used size_t without defining it. * It was not C++ safe. * It used the restrict keyword that is not recognized in GCC2. This fixes bug #2262. * It did not contain parameter names as demanded by our coding style. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@25818 a95241bf-73f2-0310-859d-f6bbb57e9c96
57 lines
1.3 KiB
C
57 lines
1.3 KiB
C
/*
|
|
* Copyright 2008, Haiku, Inc. All Rights Reserved.
|
|
* Distributed under the terms of the MIT License.
|
|
*/
|
|
#ifndef _SEARCH_H_
|
|
#define _SEARCH_H_
|
|
|
|
|
|
#include <sys/types.h>
|
|
|
|
|
|
typedef enum {
|
|
FIND,
|
|
ENTER
|
|
} ACTION;
|
|
|
|
typedef struct entry {
|
|
char *keyr;
|
|
void *data;
|
|
} ENTRY;
|
|
|
|
typedef enum {
|
|
preorder,
|
|
postorder,
|
|
endorder,
|
|
leaf
|
|
} VISIT;
|
|
|
|
|
|
#ifdef __cplusplus
|
|
extern "C" {
|
|
#endif
|
|
|
|
extern int hcreate(size_t elementCount);
|
|
extern void hdestroy(void);
|
|
extern ENTRY *hsearch(ENTRY iteam, ACTION action);
|
|
extern void insque(void *element, void *insertAfter);
|
|
extern void *lfind(const void *key, const void *base, size_t *_elementCount,
|
|
size_t width, int (*compareFunction)(const void *, const void *));
|
|
extern void *lsearch(const void *key, void *base, size_t *_elementCount,
|
|
size_t width, int (*compareFunction)(const void *, const void *));
|
|
extern void remque(void *element);
|
|
extern void *tdelete(const void *key, void **_root,
|
|
int (*compare)(const void *, const void *));
|
|
extern void *tfind(const void *key, void *const *root,
|
|
int (*compare)(const void *, const void *));
|
|
extern void *tsearch(const void *key, void **_root,
|
|
int (*compare)(const void *, const void *));
|
|
extern void twalk(const void *root,
|
|
void (*action)(const void *, VISIT, int ));
|
|
|
|
#ifdef __cplusplus
|
|
}
|
|
#endif
|
|
|
|
#endif /* _SEARCH_H_ */
|