Mercurial > emacs
comparison m4/getopt.m4 @ 64639:385af3e03206
Merge gnulib getopt implementation into Emacs.
* Makefile.in (AUTOCONF_INPUTS): New macro.
($(srcdir)/configure, $(srcdir)/src/stamp-h.in): Depend on it,
so that these files also depend on m4/getopt.m4.
* configure.in: Configure getopt by including m4/getopt.m4,
and configuring a getopt replacement if necessary.
* make-dist: Add m4 subdirectory. Unlink lib-src/getopt.h.
* m4/getopt.m4: New file.
* lib-src/Makefile.in (mostlyclean): Remove getopt.h, getopt.h-t.
(GETOPT_H): New macro, from gnulib.
(getopt.h): New rule, from gnulib.
(GETOPTOBJS): Now autoconfigured.
(GETOPTDEPS): getopt.h is now autoconfigured.
(getopt.o, getopt1.o): Depend on $(GETOPT_H), not ${srcdir}/getopt.h.
(getopt.o): Depend on ${srcdir}/gettext.h.
(movemail.o): Depend on $(GETOPT_H).
* lib-src/getopt.c, lib-src/getopt1.c: Sync from gnulib.
* lib-src/getopt_.h, lib-src/getopt_int.h, lib-src/gettext.h:
New files, from gnulib.
* lib-src/getopt.h: Removed (now is getopt_.h).
* nt/inc/gettext.h: Remove; no longer needed now that
lib-src/gettext.h exists.
* src/s/cygwin.h (C_SWITCH_SYSTEM): Remove, since gettext.h is
now part of lib-src.
author | Paul Eggert <eggert@twinsun.com> |
---|---|
date | Tue, 26 Jul 2005 21:43:13 +0000 |
parents | |
children | 6baf27bdd63b |
comparison
equal
deleted
inserted
replaced
64638:8cbdc86a4f55 | 64639:385af3e03206 |
---|---|
1 # getopt.m4 serial 10 | |
2 dnl Copyright (C) 2002, 2003, 2004, 2005 Free Software Foundation, Inc. | |
3 dnl This file is free software; the Free Software Foundation | |
4 dnl gives unlimited permission to copy and/or distribute it, | |
5 dnl with or without modifications, as long as this notice is preserved. | |
6 | |
7 # The getopt module assume you want GNU getopt, with getopt_long etc, | |
8 # rather than vanilla POSIX getopt. This means your your code should | |
9 # always include <getopt.h> for the getopt prototypes. | |
10 | |
11 AC_DEFUN([gl_GETOPT_SUBSTITUTE], | |
12 [ | |
13 AC_LIBOBJ([getopt]) | |
14 AC_LIBOBJ([getopt1]) | |
15 gl_GETOPT_SUBSTITUTE_HEADER | |
16 gl_PREREQ_GETOPT | |
17 ]) | |
18 | |
19 AC_DEFUN([gl_GETOPT_SUBSTITUTE_HEADER], | |
20 [ | |
21 GETOPT_H=getopt.h | |
22 AC_DEFINE([__GETOPT_PREFIX], [[rpl_]], | |
23 [Define to rpl_ if the getopt replacement functions and variables | |
24 should be used.]) | |
25 AC_SUBST([GETOPT_H]) | |
26 ]) | |
27 | |
28 AC_DEFUN([gl_GETOPT_CHECK_HEADERS], | |
29 [ | |
30 GETOPT_H= | |
31 AC_CHECK_HEADERS([getopt.h], [], [GETOPT_H=getopt.h]) | |
32 if test -z "$GETOPT_H"; then | |
33 AC_CHECK_FUNCS([getopt_long_only], [], [GETOPT_H=getopt.h]) | |
34 fi | |
35 | |
36 dnl BSD getopt_long uses an incompatible method to reset option processing, | |
37 dnl and (as of 2004-10-15) mishandles optional option-arguments. | |
38 if test -z "$GETOPT_H"; then | |
39 AC_CHECK_DECL([optreset], [GETOPT_H=getopt.h], [], [#include <getopt.h>]) | |
40 fi | |
41 | |
42 dnl Solaris 10 getopt doesn't handle `+' as a leading character in an | |
43 dnl option string (as of 2005-05-05). | |
44 if test -z "$GETOPT_H"; then | |
45 AC_CACHE_CHECK([for working GNU getopt function], [gl_cv_func_gnu_getopt], | |
46 [AC_RUN_IFELSE( | |
47 [AC_LANG_PROGRAM([#include <getopt.h>], | |
48 [[ | |
49 char *myargv[3]; | |
50 myargv[0] = "conftest"; | |
51 myargv[1] = "-+"; | |
52 myargv[2] = 0; | |
53 return getopt (2, myargv, "+a") != '?'; | |
54 ]])], | |
55 [gl_cv_func_gnu_getopt=yes], | |
56 [gl_cv_func_gnu_getopt=no], | |
57 [dnl cross compiling - pessimistically guess based on decls | |
58 dnl Solaris 10 getopt doesn't handle `+' as a leading character in an | |
59 dnl option string (as of 2005-05-05). | |
60 AC_CHECK_DECL([getopt_clip], | |
61 [gl_cv_func_gnu_getopt=no], [gl_cv_func_gnu_getopt=yes], | |
62 [#include <getopt.h>])])]) | |
63 if test "$gl_cv_func_gnu_getopt" = "no"; then | |
64 GETOPT_H=getopt.h | |
65 fi | |
66 fi | |
67 ]) | |
68 | |
69 AC_DEFUN([gl_GETOPT_IFELSE], | |
70 [ | |
71 AC_REQUIRE([gl_GETOPT_CHECK_HEADERS]) | |
72 AS_IF([test -n "$GETOPT_H"], [$1], [$2]) | |
73 ]) | |
74 | |
75 AC_DEFUN([gl_GETOPT], [gl_GETOPT_IFELSE([gl_GETOPT_SUBSTITUTE])]) | |
76 | |
77 # Prerequisites of lib/getopt*. | |
78 AC_DEFUN([gl_PREREQ_GETOPT], [:]) |