[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
posix-modules: add options for specific platforms
From: |
Bruno Haible |
Subject: |
posix-modules: add options for specific platforms |
Date: |
Sun, 18 Dec 2016 13:17:15 +0100 |
User-agent: |
KMail/4.8.5 (Linux/3.8.0-44-generic; KDE/4.8.5; x86_64; ; ) |
This makes it easier to create a testdir that compiles on MSVC:
$ ./gnulib-tool --create-testdir --dir=/tmp/testdir-posix --with-tests
--single-configure \
--avoid=havelib-tests `./posix-modules --for-msvc`
2016-12-18 Bruno Haible <address@hidden>
posix-modules: Add options for specific platforms.
* posix-modules (func_usage): Document options --for-mingw, --for-msvc.
(exclude_for_mingw, exclude_for_msvc, exclude): New variables.
Invoke func_tmpdir. Filter out the excludes.
diff --git a/posix-modules b/posix-modules
index 4464e7e..b1a5eba 100755
--- a/posix-modules
+++ b/posix-modules
@@ -24,10 +24,15 @@ package=gnulib
func_usage ()
{
echo "\
-Usage: posix-modules
+Usage: posix-modules [option]
Lists the gnulib modules that implement POSIX interfaces.
+Options:
+
+ --for-mingw list only modules that work on mingw
+ --for-msvc list only modules that work on MSVC
+
Report bugs to <address@hidden>."
}
@@ -217,9 +222,27 @@ else
}
fi
+# Excludes for mingw.
+exclude_for_mingw=
+# <grp.h> does not exist.
+exclude_for_mingw="$exclude_for_mingw pt_chown grantpt posix_openpt-tests
posix_openpt"
+# The functions getuid, getgid, geteuid, getegid don't exist.
+exclude_for_mingw="$exclude_for_mingw euidaccess faccessat"
+exclude_for_mingw="$exclude_for_mingw fchownat-tests fchownat"
+
+# Excludes for MSVC.
+exclude_for_msvc="$exclude_for_mingw"
+
# Command-line option processing.
+exclude=
while test $# -gt 0; do
case "$1" in
+ --for-mingw | --for-ming | --for-min | --for-mi )
+ exclude="$exclude $exclude_for_mingw"
+ shift ;;
+ --for-msvc | --for-msv | --for-ms )
+ exclude="$exclude $exclude_for_msvc"
+ shift ;;
--help | --hel | --he | --h )
func_usage
exit $? ;;
@@ -238,6 +261,18 @@ while test $# -gt 0; do
done
func_gnulib_dir
+func_tmpdir
+trap 'exit_status=$?
+ if test "$signal" != 0; then
+ echo "caught signal $signal" >&2
+ fi
+ rm -rf "$tmp"
+ exit $exit_status' 0
+for signal in 1 2 3 13 15; do
+ trap '{ signal='$signal'; func_exit 1; }' $signal
+done
+signal=0
+
(
# Get the header modules.
LC_ALL=C grep -h '^Gnulib module: ' "$gnulib_dir"/doc/posix-headers/*.texi
2>/dev/null \
@@ -250,7 +285,16 @@ func_gnulib_dir
| { # Then filter out the words "---", "and", "or" and remove *-gnu modules.
tr ' ' '\012' | sed -e '/^---$/d' -e '/^and$/d' -e '/^or$/d' -e
'/-gnu$/d'
} \
- | LC_ALL=C sort | LC_ALL=C uniq
+ | LC_ALL=C sort | LC_ALL=C uniq \
+ | { # Then filter out the excludes.
+ if test -n "$exclude"; then
+ for m in $exclude; do echo $m; done | LC_ALL=C sort -u >
"$tmp"/excludes
+ LC_ALL=C join -v 1 - "$tmp"/excludes
+ rm -f "$tmp"/excludes
+ else
+ cat
+ fi
+ }
# Local Variables:
# indent-tabs-mode: nil
[Prev in Thread] |
Current Thread |
[Next in Thread] |
- posix-modules: add options for specific platforms,
Bruno Haible <=