gnulib: add module sys_wait, for compilation on MinGW
Also, upgrade to gnulib 4af1990a0902f5914f582bade9d1aa843a291f5a. * lib/sys_wait.in.h, m4/sys_wait_h.m4: New files. * m4/sys_stat_h.m4, m4/stdlib_h.m4, m4/gnulib-comp.m4, m4/gnulib-cache.m4, lib/stdlib.in.h, lib/Makefile.am: Update.
This commit is contained in:
parent
d22fb0b61f
commit
7e79fcb4e3
8 changed files with 218 additions and 5 deletions
|
|
@ -21,7 +21,7 @@
|
|||
# the same distribution terms as the rest of that program.
|
||||
#
|
||||
# Generated by gnulib-tool.
|
||||
# Reproduce by: gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files --no-libtool --no-vc-files argp error gethrxtime mkstemp progname
|
||||
# Reproduce by: gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files --no-libtool --no-vc-files argp error gethrxtime mkstemp progname sys_wait
|
||||
|
||||
AUTOMAKE_OPTIONS = 1.5 gnits
|
||||
|
||||
|
|
@ -811,6 +811,7 @@ stdlib.h: stdlib.in.h $(top_builddir)/config.status $(CXXDEFS_H) \
|
|||
-e 's|@''REPLACE_MALLOC''@|$(REPLACE_MALLOC)|g' \
|
||||
-e 's|@''REPLACE_MBTOWC''@|$(REPLACE_MBTOWC)|g' \
|
||||
-e 's|@''REPLACE_MKSTEMP''@|$(REPLACE_MKSTEMP)|g' \
|
||||
-e 's|@''REPLACE_PTSNAME''@|$(REPLACE_PTSNAME)|g' \
|
||||
-e 's|@''REPLACE_PTSNAME_R''@|$(REPLACE_PTSNAME_R)|g' \
|
||||
-e 's|@''REPLACE_PUTENV''@|$(REPLACE_PUTENV)|g' \
|
||||
-e 's|@''REPLACE_RANDOM_R''@|$(REPLACE_RANDOM_R)|g' \
|
||||
|
|
@ -1138,6 +1139,34 @@ EXTRA_DIST += sys_types.in.h
|
|||
|
||||
## end gnulib module sys_types
|
||||
|
||||
## begin gnulib module sys_wait
|
||||
|
||||
BUILT_SOURCES += sys/wait.h
|
||||
|
||||
# We need the following in order to create <sys/wait.h> when the system
|
||||
# has one that is incomplete.
|
||||
sys/wait.h: sys_wait.in.h $(top_builddir)/config.status $(CXXDEFS_H) $(WARN_ON_USE_H)
|
||||
$(AM_V_at)$(MKDIR_P) sys
|
||||
$(AM_V_GEN)rm -f $@-t $@ && \
|
||||
{ echo '/* DO NOT EDIT! GENERATED AUTOMATICALLY! */'; \
|
||||
sed -e 's|@''GUARD_PREFIX''@|GL|g' \
|
||||
-e 's|@''INCLUDE_NEXT''@|$(INCLUDE_NEXT)|g' \
|
||||
-e 's|@''PRAGMA_SYSTEM_HEADER''@|@PRAGMA_SYSTEM_HEADER@|g' \
|
||||
-e 's|@''PRAGMA_COLUMNS''@|@PRAGMA_COLUMNS@|g' \
|
||||
-e 's|@''NEXT_SYS_WAIT_H''@|$(NEXT_SYS_WAIT_H)|g' \
|
||||
-e 's/@''GNULIB_WAITPID''@/$(GNULIB_WAITPID)/g' \
|
||||
-e '/definitions of _GL_FUNCDECL_RPL/r $(CXXDEFS_H)' \
|
||||
-e '/definition of _GL_WARN_ON_USE/r $(WARN_ON_USE_H)' \
|
||||
< $(srcdir)/sys_wait.in.h; \
|
||||
} > $@-t && \
|
||||
mv $@-t $@
|
||||
MOSTLYCLEANFILES += sys/wait.h sys/wait.h-t
|
||||
MOSTLYCLEANDIRS += sys
|
||||
|
||||
EXTRA_DIST += sys_wait.in.h
|
||||
|
||||
## end gnulib module sys_wait
|
||||
|
||||
## begin gnulib module sysexits
|
||||
|
||||
BUILT_SOURCES += $(SYSEXITS_H)
|
||||
|
|
|
|||
|
|
@ -457,10 +457,19 @@ _GL_WARN_ON_USE (posix_openpt, "posix_openpt is not portable - "
|
|||
#if @GNULIB_PTSNAME@
|
||||
/* Return the pathname of the pseudo-terminal slave associated with
|
||||
the master FD is open on, or NULL on errors. */
|
||||
# if !@HAVE_PTSNAME@
|
||||
# if @REPLACE_PTSNAME@
|
||||
# if !(defined __cplusplus && defined GNULIB_NAMESPACE)
|
||||
# undef ptsname
|
||||
# define ptsname rpl_ptsname
|
||||
# endif
|
||||
_GL_FUNCDECL_RPL (ptsname, char *, (int fd));
|
||||
_GL_CXXALIAS_RPL (ptsname, char *, (int fd));
|
||||
# else
|
||||
# if !@HAVE_PTSNAME@
|
||||
_GL_FUNCDECL_SYS (ptsname, char *, (int fd));
|
||||
# endif
|
||||
# endif
|
||||
_GL_CXXALIAS_SYS (ptsname, char *, (int fd));
|
||||
# endif
|
||||
_GL_CXXALIASWARN (ptsname);
|
||||
#elif defined GNULIB_POSIXCHECK
|
||||
# undef ptsname
|
||||
|
|
|
|||
129
lib/sys_wait.in.h
Normal file
129
lib/sys_wait.in.h
Normal file
|
|
@ -0,0 +1,129 @@
|
|||
/* A POSIX-like <sys/wait.h>.
|
||||
Copyright (C) 2001-2003, 2005-2012 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
|
||||
the Free Software Foundation; either version 3, or (at your option)
|
||||
any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU General Public License
|
||||
along with this program; if not, see <http://www.gnu.org/licenses/>. */
|
||||
|
||||
|
||||
#ifndef _@GUARD_PREFIX@_SYS_WAIT_H
|
||||
|
||||
#if __GNUC__ >= 3
|
||||
@PRAGMA_SYSTEM_HEADER@
|
||||
#endif
|
||||
@PRAGMA_COLUMNS@
|
||||
|
||||
/* The include_next requires a split double-inclusion guard. */
|
||||
#if !((defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__)
|
||||
# @INCLUDE_NEXT@ @NEXT_SYS_WAIT_H@
|
||||
#endif
|
||||
|
||||
#ifndef _@GUARD_PREFIX@_SYS_WAIT_H
|
||||
#define _@GUARD_PREFIX@_SYS_WAIT_H
|
||||
|
||||
/* Get pid_t. */
|
||||
#include <sys/types.h>
|
||||
|
||||
|
||||
/* The definitions of _GL_FUNCDECL_RPL etc. are copied here. */
|
||||
|
||||
/* The definition of _GL_WARN_ON_USE is copied here. */
|
||||
|
||||
|
||||
#if !((defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__)
|
||||
/* Unix API. */
|
||||
|
||||
/* The following macros apply to an argument x, that is a status of a process,
|
||||
as returned by waitpid().
|
||||
On nearly all systems, including Linux/x86, WEXITSTATUS are bits 15..8 and
|
||||
WTERMSIG are bits 7..0, while BeOS uses the opposite. Therefore programs
|
||||
have to use the abstract macros. */
|
||||
|
||||
/* For valid x, exactly one of WIFSIGNALED(x), WIFEXITED(x), WIFSTOPPED(x)
|
||||
is true. */
|
||||
# ifndef WIFSIGNALED
|
||||
# define WIFSIGNALED(x) (WTERMSIG (x) != 0 && WTERMSIG(x) != 0x7f)
|
||||
# endif
|
||||
# ifndef WIFEXITED
|
||||
# define WIFEXITED(x) (WTERMSIG (x) == 0)
|
||||
# endif
|
||||
# ifndef WIFSTOPPED
|
||||
# define WIFSTOPPED(x) (WTERMSIG (x) == 0x7f)
|
||||
# endif
|
||||
|
||||
/* The termination signal. Only to be accessed if WIFSIGNALED(x) is true. */
|
||||
# ifndef WTERMSIG
|
||||
# define WTERMSIG(x) ((x) & 0x7f)
|
||||
# endif
|
||||
|
||||
/* The exit status. Only to be accessed if WIFEXITED(x) is true. */
|
||||
# ifndef WEXITSTATUS
|
||||
# define WEXITSTATUS(x) (((x) >> 8) & 0xff)
|
||||
# endif
|
||||
|
||||
/* The stopping signal. Only to be accessed if WIFSTOPPED(x) is true. */
|
||||
# ifndef WSTOPSIG
|
||||
# define WSTOPSIG(x) (((x) >> 8) & 0x7f)
|
||||
# endif
|
||||
|
||||
/* True if the process dumped core. Not standardized by POSIX. */
|
||||
# ifndef WCOREDUMP
|
||||
# define WCOREDUMP(x) ((x) & 0x80)
|
||||
# endif
|
||||
|
||||
#else
|
||||
/* Native Windows API. */
|
||||
|
||||
# include <signal.h> /* for SIGTERM */
|
||||
|
||||
/* The following macros apply to an argument x, that is a status of a process,
|
||||
as returned by waitpid() or, equivalently, _cwait() or GetExitCodeProcess().
|
||||
This value is simply an 'int', not composed of bit fields. */
|
||||
|
||||
/* When an unhandled fatal signal terminates a process, the exit code is 3. */
|
||||
# define WIFSIGNALED(x) ((x) == 3)
|
||||
# define WIFEXITED(x) ((x) != 3)
|
||||
# define WIFSTOPPED(x) 0
|
||||
|
||||
/* The signal that terminated a process is not known posthum. */
|
||||
# define WTERMSIG(x) SIGTERM
|
||||
|
||||
# define WEXITSTATUS(x) (x)
|
||||
|
||||
/* There are no stopping signals. */
|
||||
# define WSTOPSIG(x) 0
|
||||
|
||||
/* There are no core dumps. */
|
||||
# define WCOREDUMP(x) 0
|
||||
|
||||
#endif
|
||||
|
||||
|
||||
/* Declarations of functions. */
|
||||
|
||||
#if @GNULIB_WAITPID@
|
||||
# if (defined _WIN32 || defined __WIN32__) && ! defined __CYGWIN__
|
||||
_GL_FUNCDECL_SYS (waitpid, pid_t, (pid_t pid, int *statusp, int options));
|
||||
# endif
|
||||
_GL_CXXALIAS_SYS (waitpid, pid_t, (pid_t pid, int *statusp, int options));
|
||||
_GL_CXXALIASWARN (waitpid);
|
||||
#elif defined GNULIB_POSIXCHECK
|
||||
# undef waitpid
|
||||
# if HAVE_RAW_DECL_WAITPID
|
||||
_GL_WARN_ON_USE (waitpid, "waitpid is unportable - "
|
||||
"use gnulib module sys_wait for portability");
|
||||
# endif
|
||||
#endif
|
||||
|
||||
|
||||
#endif /* _@GUARD_PREFIX@_SYS_WAIT_H */
|
||||
#endif /* _@GUARD_PREFIX@_SYS_WAIT_H */
|
||||
|
|
@ -27,7 +27,7 @@
|
|||
|
||||
|
||||
# Specification in the form of a command-line invocation:
|
||||
# gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files --no-libtool --no-vc-files argp error gethrxtime mkstemp progname
|
||||
# gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --doc-base=doc --tests-base=tests --aux-dir=tools --no-conditional-dependencies --no-libtool --macro-prefix=gl --no-vc-files --no-libtool --no-vc-files argp error gethrxtime mkstemp progname sys_wait
|
||||
|
||||
# Specification in the form of a few gnulib-tool.m4 macro invocations:
|
||||
gl_LOCAL_DIR([])
|
||||
|
|
@ -39,6 +39,7 @@ gl_MODULES([
|
|||
gethrxtime
|
||||
mkstemp
|
||||
progname
|
||||
sys_wait
|
||||
])
|
||||
gl_AVOID([])
|
||||
gl_SOURCE_BASE([lib])
|
||||
|
|
|
|||
|
|
@ -100,6 +100,7 @@ AC_DEFUN([gl_EARLY],
|
|||
# Code from module sys_stat:
|
||||
# Code from module sys_time:
|
||||
# Code from module sys_types:
|
||||
# Code from module sys_wait:
|
||||
# Code from module sysexits:
|
||||
# Code from module tempname:
|
||||
# Code from module time:
|
||||
|
|
@ -305,6 +306,8 @@ AC_DEFUN([gl_INIT],
|
|||
AC_PROG_MKDIR_P
|
||||
gl_SYS_TYPES_H
|
||||
AC_PROG_MKDIR_P
|
||||
gl_SYS_WAIT_H
|
||||
AC_PROG_MKDIR_P
|
||||
gl_SYSEXITS
|
||||
gl_FUNC_GEN_TEMPNAME
|
||||
gl_HEADER_TIME_H
|
||||
|
|
@ -540,6 +543,7 @@ AC_DEFUN([gl_FILE_LIST], [
|
|||
lib/sys_stat.in.h
|
||||
lib/sys_time.in.h
|
||||
lib/sys_types.in.h
|
||||
lib/sys_wait.in.h
|
||||
lib/sysexits.in.h
|
||||
lib/tempname.c
|
||||
lib/tempname.h
|
||||
|
|
@ -616,6 +620,7 @@ AC_DEFUN([gl_FILE_LIST], [
|
|||
m4/sys_stat_h.m4
|
||||
m4/sys_time_h.m4
|
||||
m4/sys_types_h.m4
|
||||
m4/sys_wait_h.m4
|
||||
m4/sysexits.m4
|
||||
m4/tempname.m4
|
||||
m4/time_h.m4
|
||||
|
|
|
|||
|
|
@ -102,6 +102,7 @@ AC_DEFUN([gl_STDLIB_H_DEFAULTS],
|
|||
REPLACE_MALLOC=0; AC_SUBST([REPLACE_MALLOC])
|
||||
REPLACE_MBTOWC=0; AC_SUBST([REPLACE_MBTOWC])
|
||||
REPLACE_MKSTEMP=0; AC_SUBST([REPLACE_MKSTEMP])
|
||||
REPLACE_PTSNAME=0; AC_SUBST([REPLACE_PTSNAME])
|
||||
REPLACE_PTSNAME_R=0; AC_SUBST([REPLACE_PTSNAME_R])
|
||||
REPLACE_PUTENV=0; AC_SUBST([REPLACE_PUTENV])
|
||||
REPLACE_RANDOM_R=0; AC_SUBST([REPLACE_RANDOM_R])
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
# sys_stat_h.m4 serial 28 -*- Autoconf -*-
|
||||
# sys_stat_h.m4 serial 27 -*- Autoconf -*-
|
||||
dnl Copyright (C) 2006-2012 Free Software Foundation, Inc.
|
||||
dnl This file is free software; the Free Software Foundation
|
||||
dnl gives unlimited permission to copy and/or distribute it,
|
||||
|
|
@ -11,6 +11,9 @@ AC_DEFUN([gl_HEADER_SYS_STAT_H],
|
|||
[
|
||||
AC_REQUIRE([gl_SYS_STAT_H_DEFAULTS])
|
||||
|
||||
dnl For the mkdir substitute.
|
||||
AC_REQUIRE([AC_C_INLINE])
|
||||
|
||||
dnl Check for broken stat macros.
|
||||
AC_REQUIRE([AC_HEADER_STAT])
|
||||
|
||||
|
|
|
|||
36
m4/sys_wait_h.m4
Normal file
36
m4/sys_wait_h.m4
Normal file
|
|
@ -0,0 +1,36 @@
|
|||
# sys_wait_h.m4 serial 6
|
||||
dnl Copyright (C) 2008-2012 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_SYS_WAIT_H],
|
||||
[
|
||||
AC_REQUIRE([gl_SYS_WAIT_H_DEFAULTS])
|
||||
|
||||
dnl <sys/wait.h> is always overridden, because of GNULIB_POSIXCHECK.
|
||||
gl_CHECK_NEXT_HEADERS([sys/wait.h])
|
||||
|
||||
dnl Ensure the type pid_t gets defined.
|
||||
AC_REQUIRE([AC_TYPE_PID_T])
|
||||
|
||||
dnl Check for declarations of anything we want to poison if the
|
||||
dnl corresponding gnulib module is not in use.
|
||||
gl_WARN_ON_USE_PREPARE([[#include <sys/wait.h>]],
|
||||
[waitpid])
|
||||
])
|
||||
|
||||
AC_DEFUN([gl_SYS_WAIT_MODULE_INDICATOR],
|
||||
[
|
||||
dnl Use AC_REQUIRE here, so that the default settings are expanded once only.
|
||||
AC_REQUIRE([gl_SYS_WAIT_H_DEFAULTS])
|
||||
gl_MODULE_INDICATOR_SET_VARIABLE([$1])
|
||||
dnl Define it also as a C macro, for the benefit of the unit tests.
|
||||
gl_MODULE_INDICATOR_FOR_TESTS([$1])
|
||||
])
|
||||
|
||||
AC_DEFUN([gl_SYS_WAIT_H_DEFAULTS],
|
||||
[
|
||||
GNULIB_WAITPID=0; AC_SUBST([GNULIB_WAITPID])
|
||||
dnl Assume proper GNU behavior unless another module says otherwise.
|
||||
])
|
||||
Loading…
Add table
Add a link
Reference in a new issue