diff options
author | Bruno Haible <bruno@clisp.org> | 2007-03-25 02:45:24 +0000 |
---|---|---|
committer | Bruno Haible <bruno@clisp.org> | 2007-03-25 02:45:24 +0000 |
commit | f6cc762af9137f7dc92b9ad5ef97c8a05f7e129b (patch) | |
tree | 7b93c905ad72716f7b825800ca9eff1fbe87e8e1 | |
parent | cdaeb6bb213d6042df46e0b3584718ede9f18511 (diff) | |
download | gnulib-f6cc762af9137f7dc92b9ad5ef97c8a05f7e129b.tar.gz |
New module 'search'.
-rw-r--r-- | ChangeLog | 14 | ||||
-rw-r--r-- | NEWS | 3 | ||||
-rw-r--r-- | lib/search_.h (renamed from lib/tsearch.h) | 49 | ||||
-rw-r--r-- | lib/tsearch.c | 8 | ||||
-rw-r--r-- | m4/search_h.m4 | 34 | ||||
-rw-r--r-- | m4/tsearch.m4 | 9 | ||||
-rw-r--r-- | modules/search | 40 | ||||
-rw-r--r-- | modules/tsearch | 5 |
8 files changed, 145 insertions, 17 deletions
@@ -1,5 +1,19 @@ 2007-03-24 Bruno Haible <bruno@clisp.org> + * modules/search: New file. + * lib/search_.h: New file, incorporating lib/tsearch.h. + * m4/search_h.m4: New file. + * lib/tsearch.h: Remove file. + * lib/tsearch.c: Include search.h instead of tsearch.h. + * m4/tsearch.m4 (gl_FUNC_TSEARCH): Require gl_SEARCH_H_DEFAULTS. Set + HAVE_TSEARCH. + * modules/tsearch (Files): Remove lib/tsearch.h. + (Depends-on): Add search. + (configure.ac): Invoke gl_SEARCH_MODULE_INDICATOR. + (Include): Change tsearch.h into search.h. + +2007-03-24 Bruno Haible <bruno@clisp.org> + * modules/fpucw: New file. * lib/fpucw.h: New file. * lib/frexp.c: Include fpucw.h. @@ -6,6 +6,9 @@ User visible incompatible changes Date Modules Changes +2007-03-24 tsearch The include file is changed from "tsearch.h" to + <search.h>. + 2007-03-24 utf8-ucs4 The include file is changed from "utf8-ucs4.h" to "unistr.h". utf8-ucs4-unsafe The include file is changed from diff --git a/lib/tsearch.h b/lib/search_.h index a42b0c86d6..233cc63db0 100644 --- a/lib/tsearch.h +++ b/lib/search_.h @@ -1,5 +1,6 @@ -/* Binary tree data structure. - Copyright (C) 2006 Free Software Foundation, Inc. +/* A GNU-like <search.h>. + + Copyright (C) 2007 Free Software Foundation, Inc. This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -15,20 +16,25 @@ along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. */ -#ifndef _TSEARCH_H -#define _TSEARCH_H +#ifndef _GL_SEARCH_H +#define _GL_SEARCH_H + +#if @HAVE_SEARCH_H@ +# include @ABSOLUTE_SEARCH_H@ +#endif -#if HAVE_TSEARCH -/* Get tseach(), tfind(), tdelete(), twalk() declarations. */ -#include <search.h> +/* The definition of GL_LINK_WARNING is copied here. */ -#else #ifdef __cplusplus extern "C" { #endif + +#if @GNULIB_TSEARCH@ +# if !@HAVE_TSEARCH@ + /* See <http://www.opengroup.org/susv3xbd/search.h.html>, <http://www.opengroup.org/susv3xsh/tsearch.html> for details. */ @@ -73,10 +79,33 @@ extern void * tdelete (const void *key, void **vrootp, extern void twalk (const void *vroot, void (*action) (const void *, VISIT, int)); +# endif +#elif defined GNULIB_POSIXCHECK +# undef tsearch +# define tsearch(k,v,c) \ + (GL_LINK_WARNING ("tsearch is unportable - " \ + "use gnulib module tsearch for portability"), \ + tsearch (k, v, c)) +# undef tfind +# define tfind(k,v,c) \ + (GL_LINK_WARNING ("tfind is unportable - " \ + "use gnulib module tsearch for portability"), \ + tfind (k, v, c)) +# undef tdelete +# define tdelete(k,v,c) \ + (GL_LINK_WARNING ("tdelete is unportable - " \ + "use gnulib module tsearch for portability"), \ + tdelete (k, v, c)) +# undef twalk +# define twalk(v,a) \ + (GL_LINK_WARNING ("twalk is unportable - " \ + "use gnulib module tsearch for portability"), \ + twalk (v, a)) +#endif + + #ifdef __cplusplus } #endif #endif - -#endif /* _TSEARCH_H */ diff --git a/lib/tsearch.c b/lib/tsearch.c index 6a9d2e06ac..cc63a11e72 100644 --- a/lib/tsearch.c +++ b/lib/tsearch.c @@ -1,4 +1,4 @@ -/* Copyright (C) 1995, 1996, 1997, 2000, 2006 Free Software Foundation, Inc. +/* Copyright (C) 1995-1997, 2000, 2006-2007 Free Software Foundation, Inc. Contributed by Bernd Schmidt <crux@Pool.Informatik.RWTH-Aachen.DE>, 1997. NOTE: The canonical source of this file is maintained with the GNU C @@ -88,7 +88,11 @@ #include <config.h> /* Specification. */ -#include "tsearch.h" +#ifdef IN_LIBINTL +# include "tsearch.h" +#else +# include <search.h> +#endif #include <stdlib.h> diff --git a/m4/search_h.m4 b/m4/search_h.m4 new file mode 100644 index 0000000000..d894ed0235 --- /dev/null +++ b/m4/search_h.m4 @@ -0,0 +1,34 @@ +# search_h.m4 serial 1 +dnl Copyright (C) 2007 Free Software Foundation, Inc. +dnl This file is free software; the Free Software Foundation +dnl gives unlimited permission to copy and/or distribute it, +dnl with or without modifications, as long as this notice is preserved. + +AC_DEFUN([gl_SEARCH_H], +[ + AC_REQUIRE([gl_SEARCH_H_DEFAULTS]) + AC_CHECK_HEADERS_ONCE([search.h]) + if test $ac_cv_header_search_h = yes; then + HAVE_SEARCH_H=1 + gl_ABSOLUTE_HEADER([search.h]) + ABSOLUTE_SEARCH_H=\"$gl_cv_absolute_search_h\" + else + HAVE_SEARCH_H=0 + fi + AC_SUBST([HAVE_SEARCH_H]) + AC_SUBST([ABSOLUTE_SEARCH_H]) +]) + +AC_DEFUN([gl_SEARCH_MODULE_INDICATOR], +[ + dnl Use AC_REQUIRE here, so that the default settings are expanded once only. + AC_REQUIRE([gl_SEARCH_H_DEFAULTS]) + GNULIB_[]m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./-],[ABCDEFGHIJKLMNOPQRSTUVWXYZ___])=1 +]) + +AC_DEFUN([gl_SEARCH_H_DEFAULTS], +[ + GNULIB_TSEARCH=0; AC_SUBST([GNULIB_TSEARCH]) + dnl Assume proper GNU behavior unless another module says otherwise. + HAVE_TSEARCH=1; AC_SUBST([HAVE_TSEARCH]) +]) diff --git a/m4/tsearch.m4 b/m4/tsearch.m4 index e279fc049f..2a458f8755 100644 --- a/m4/tsearch.m4 +++ b/m4/tsearch.m4 @@ -1,13 +1,16 @@ -# tsearch.m4 serial 1 -dnl Copyright (C) 2006 Free Software Foundation, Inc. +# tsearch.m4 serial 2 +dnl Copyright (C) 2006-2007 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. AC_DEFUN([gl_FUNC_TSEARCH], [ - AC_REPLACE_FUNCS(tsearch) + AC_REQUIRE([gl_SEARCH_H_DEFAULTS]) + AC_CHECK_FUNCS([tsearch]) if test $ac_cv_func_tsearch = no; then + HAVE_TSEARCH=0 + AC_LIBOBJ([tsearch]) gl_PREREQ_TSEARCH fi ]) diff --git a/modules/search b/modules/search new file mode 100644 index 0000000000..f58fc59a51 --- /dev/null +++ b/modules/search @@ -0,0 +1,40 @@ +Description: +A GNU-like <search.h>. + +Files: +lib/search_.h +m4/search_h.m4 + +Depends-on: +absolute-header +link-warning + +configure.ac: +gl_SEARCH_H + +Makefile.am: +BUILT_SOURCES += search.h + +# We need the following in order to create <search.h> when the system +# doesn't have one that works with the given compiler. +search.h: search_.h + rm -f $@-t $@ + { echo '/* DO NOT EDIT! GENERATED AUTOMATICALLY! */' && \ + sed -e 's|@''HAVE_SEARCH_H''@|$(HAVE_SEARCH_H)|g' \ + -e 's|@''ABSOLUTE_SEARCH_H''@|$(ABSOLUTE_SEARCH_H)|g' \ + -e 's|@''GNULIB_TSEARCH''@|$(GNULIB_TSEARCH)|g' \ + -e 's|@''HAVE_TSEARCH''@|$(HAVE_TSEARCH)|g' \ + -e '/definition of GL_LINK_WARNING/r $(LINK_WARNING_H)' \ + < $(srcdir)/search_.h; \ + } > $@-t + mv $@-t $@ +MOSTLYCLEANFILES += search.h search.h-t + +Include: +#include <search.h> + +License: +LGPL + +Maintainer: +all diff --git a/modules/tsearch b/modules/tsearch index c78d350bc4..ad1bbefe0d 100644 --- a/modules/tsearch +++ b/modules/tsearch @@ -2,19 +2,20 @@ Description: Binary tree data structure. Files: -lib/tsearch.h lib/tsearch.c m4/tsearch.m4 Depends-on: +search configure.ac: gl_FUNC_TSEARCH +gl_SEARCH_MODULE_INDICATOR([tsearch]) Makefile.am: Include: -"tsearch.h" +<search.h> License: LGPL |