source: trunk/src/emx/include/search.h@ 1470

Last change on this file since 1470 was 959, checked in by bird, 22 years ago

_SIZE_T

  • Property cvs2svn:cvs-rev set to 1.2
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 1.5 KB
Line 
1/*-
2 * Written by J.T. Conklin <jtc@netbsd.org>
3 * Public domain.
4 *
5 * $NetBSD: search.h,v 1.12 1999/02/22 10:34:28 christos Exp $
6 * $FreeBSD: src/include/search.h,v 1.10 2002/10/16 14:29:23 robert Exp $
7 */
8
9/** @file
10 * FreeBSD 5.1
11 * @changed bird: _SIZE_T
12 */
13
14#ifndef _SEARCH_H_
15#define _SEARCH_H_
16
17#include <sys/cdefs.h>
18#include <sys/_types.h>
19
20#if !defined(_SIZE_T_DECLARED) && !defined(_SIZE_T) /* bird: emx */
21typedef __size_t size_t;
22#define _SIZE_T_DECLARED
23#define _SIZE_T /* bird: emx */
24#endif
25
26typedef struct entry {
27 char *key;
28 void *data;
29} ENTRY;
30
31typedef enum {
32 FIND, ENTER
33} ACTION;
34
35typedef enum {
36 preorder,
37 postorder,
38 endorder,
39 leaf
40} VISIT;
41
42#ifdef _SEARCH_PRIVATE
43typedef struct node {
44 char *key;
45 struct node *llink, *rlink;
46} node_t;
47
48struct que_elem {
49 struct que_elem *next;
50 struct que_elem *prev;
51};
52#endif
53
54__BEGIN_DECLS
55int hcreate(size_t);
56void hdestroy(void);
57ENTRY *hsearch(ENTRY, ACTION);
58void insque(void *, void *);
59void *lfind(const void *, const void *, size_t *, size_t,
60 int (*)(const void *, const void *));
61void *lsearch(const void *, void *, size_t *, size_t,
62 int (*)(const void *, const void *));
63void remque(void *);
64void *tdelete(const void * __restrict, void ** __restrict,
65 int (*)(const void *, const void *));
66void *tfind(const void *, void * const *,
67 int (*)(const void *, const void *));
68void *tsearch(const void *, void **, int (*)(const void *, const void *));
69void twalk(const void *, void (*)(const void *, VISIT, int));
70__END_DECLS
71
72#endif /* !_SEARCH_H_ */
Note: See TracBrowser for help on using the repository browser.