xref: /illumos-gate/usr/src/head/search.h (revision b4203d75)
17c478bd9Sstevel@tonic-gate /*
27c478bd9Sstevel@tonic-gate  * CDDL HEADER START
37c478bd9Sstevel@tonic-gate  *
47c478bd9Sstevel@tonic-gate  * The contents of this file are subject to the terms of the
57c478bd9Sstevel@tonic-gate  * Common Development and Distribution License, Version 1.0 only
67c478bd9Sstevel@tonic-gate  * (the "License").  You may not use this file except in compliance
77c478bd9Sstevel@tonic-gate  * with the License.
87c478bd9Sstevel@tonic-gate  *
97c478bd9Sstevel@tonic-gate  * You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
107c478bd9Sstevel@tonic-gate  * or http://www.opensolaris.org/os/licensing.
117c478bd9Sstevel@tonic-gate  * See the License for the specific language governing permissions
127c478bd9Sstevel@tonic-gate  * and limitations under the License.
137c478bd9Sstevel@tonic-gate  *
147c478bd9Sstevel@tonic-gate  * When distributing Covered Code, include this CDDL HEADER in each
157c478bd9Sstevel@tonic-gate  * file and include the License file at usr/src/OPENSOLARIS.LICENSE.
167c478bd9Sstevel@tonic-gate  * If applicable, add the following below this CDDL HEADER, with the
177c478bd9Sstevel@tonic-gate  * fields enclosed by brackets "[]" replaced with your own identifying
187c478bd9Sstevel@tonic-gate  * information: Portions Copyright [yyyy] [name of copyright owner]
197c478bd9Sstevel@tonic-gate  *
207c478bd9Sstevel@tonic-gate  * CDDL HEADER END
217c478bd9Sstevel@tonic-gate  */
227c478bd9Sstevel@tonic-gate /*	Copyright (c) 1988 AT&T	*/
23*b4203d75SMarcel Telka /*	  All Rights Reserved	*/
247c478bd9Sstevel@tonic-gate 
257c478bd9Sstevel@tonic-gate /*
26ba3594baSGarrett D'Amore  * Copyright 2014 Garrett D'Amore <garrett@damore.org>
27ba3594baSGarrett D'Amore  *
287c478bd9Sstevel@tonic-gate  * Copyright 2003 Sun Microsystems, Inc.  All rights reserved.
297c478bd9Sstevel@tonic-gate  * Use is subject to license terms.
307c478bd9Sstevel@tonic-gate  */
317c478bd9Sstevel@tonic-gate 
327c478bd9Sstevel@tonic-gate #ifndef _SEARCH_H
337c478bd9Sstevel@tonic-gate #define	_SEARCH_H
347c478bd9Sstevel@tonic-gate 
357c478bd9Sstevel@tonic-gate #include <sys/feature_tests.h>
367c478bd9Sstevel@tonic-gate #include <sys/types.h>
377c478bd9Sstevel@tonic-gate 
387c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
397c478bd9Sstevel@tonic-gate extern "C" {
407c478bd9Sstevel@tonic-gate #endif
417c478bd9Sstevel@tonic-gate 
427c478bd9Sstevel@tonic-gate /* HSEARCH(3C) */
437c478bd9Sstevel@tonic-gate typedef enum { FIND, ENTER } ACTION;
447c478bd9Sstevel@tonic-gate 
457c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || !defined(_XOPEN_SOURCE)
467c478bd9Sstevel@tonic-gate struct qelem {
477c478bd9Sstevel@tonic-gate 	struct qelem	*q_forw;
487c478bd9Sstevel@tonic-gate 	struct qelem	*q_back;
497c478bd9Sstevel@tonic-gate };
507c478bd9Sstevel@tonic-gate #endif /* defined(__EXTENSIONS__) || !defined(_XOPEN_SOURCE) */
517c478bd9Sstevel@tonic-gate 
527c478bd9Sstevel@tonic-gate typedef struct entry { char *key, *data; } ENTRY;
537c478bd9Sstevel@tonic-gate 
547c478bd9Sstevel@tonic-gate int hcreate(size_t);
557c478bd9Sstevel@tonic-gate void hdestroy(void);
567c478bd9Sstevel@tonic-gate ENTRY *hsearch(ENTRY, ACTION);
577c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || !defined(_XOPEN_SOURCE) || defined(_XPG4_2)
587c478bd9Sstevel@tonic-gate void insque(void *, void *);
597c478bd9Sstevel@tonic-gate void remque(void *);
607c478bd9Sstevel@tonic-gate #endif
617c478bd9Sstevel@tonic-gate 
627c478bd9Sstevel@tonic-gate 
637c478bd9Sstevel@tonic-gate /* TSEARCH(3C) */
647c478bd9Sstevel@tonic-gate typedef enum { preorder, postorder, endorder, leaf } VISIT;
657c478bd9Sstevel@tonic-gate 
667c478bd9Sstevel@tonic-gate void *tdelete(const void *_RESTRICT_KYWD, void **_RESTRICT_KYWD,
677c478bd9Sstevel@tonic-gate 	int (*)(const void *, const void *));
687c478bd9Sstevel@tonic-gate void *tfind(const void *, void *const *, int (*)(const void *, const void *));
697c478bd9Sstevel@tonic-gate void *tsearch(const void *, void **, int (*)(const void *, const void *));
707c478bd9Sstevel@tonic-gate void twalk(const void *, void (*)(const void *, VISIT, int));
717c478bd9Sstevel@tonic-gate 
727c478bd9Sstevel@tonic-gate 
737c478bd9Sstevel@tonic-gate #if defined(__EXTENSIONS__) || !defined(_XOPEN_SOURCE)
747c478bd9Sstevel@tonic-gate /* BSEARCH(3C) */
757c478bd9Sstevel@tonic-gate void *bsearch(const void *, const void *, size_t, size_t,
767c478bd9Sstevel@tonic-gate 	    int (*)(const void *, const void *));
777c478bd9Sstevel@tonic-gate #endif /* defined(__EXTENSIONS__) || !defined(_XOPEN_SOURCE) */
787c478bd9Sstevel@tonic-gate 
797c478bd9Sstevel@tonic-gate /* LSEARCH(3C) */
807c478bd9Sstevel@tonic-gate void *lfind(const void *, const void *, size_t *, size_t,
817c478bd9Sstevel@tonic-gate 	    int (*)(const void *, const void *));
827c478bd9Sstevel@tonic-gate void *lsearch(const void *, void *, size_t *, size_t,
837c478bd9Sstevel@tonic-gate 	    int (*)(const void *, const void *));
847c478bd9Sstevel@tonic-gate 
857c478bd9Sstevel@tonic-gate #ifdef	__cplusplus
867c478bd9Sstevel@tonic-gate }
877c478bd9Sstevel@tonic-gate #endif
887c478bd9Sstevel@tonic-gate 
897c478bd9Sstevel@tonic-gate #endif	/* _SEARCH_H */
90