From 4efeffc1d583597e4f52985b9747269e47b754e2 Mon Sep 17 00:00:00 2001 From: Ulrich Drepper Date: Sun, 26 Feb 2012 13:17:27 -0500 Subject: Fix up POSIX testing in conformtest --- conform/Makefile | 2 +- conform/conformtest.pl | 68 ++++++++++++++++++++----------------------- conform/data/aio.h-data | 4 +-- conform/data/fcntl.h-data | 11 +++++-- conform/data/glob.h-data | 4 +++ conform/data/grp.h-data | 4 +++ conform/data/pthread.h-data | 10 +++---- conform/data/pwd.h-data | 5 ++++ conform/data/signal.h-data | 7 ++++- conform/data/spawn.h-data | 2 +- conform/data/stdio.h-data | 18 ++++++------ conform/data/stdlib.h-data | 2 +- conform/data/stropts.h-data | 2 +- conform/data/sys/mman.h-data | 4 +++ conform/data/sys/stat.h-data | 38 ++++++++++++++++-------- conform/data/sys/types.h-data | 8 +++++ conform/data/sys/wait.h-data | 13 ++++++++- conform/data/time.h-data | 6 +++- conform/data/unistd.h-data | 23 +++++++++++++-- conform/data/utime.h-data | 4 +++ 20 files changed, 159 insertions(+), 76 deletions(-) (limited to 'conform') diff --git a/conform/Makefile b/conform/Makefile index 5d88732..d7d939e 100644 --- a/conform/Makefile +++ b/conform/Makefile @@ -30,7 +30,7 @@ tests: $(objpfx)run-conformtest.out $(objpfx)run-conformtest.out: run-conformtest.sh conformtest.pl \ $(wildcard data/*.h-data) \ $(wildcard data/*/*.h-data) - $(SHELL) -e $< $(objpfx) $(PERL) '$(CC)' \ + -$(SHELL) -e $< $(objpfx) $(PERL) '$(CC)' \ '-I../include $(+sysdep-includes) $(sysincludes) -I..' generated = $(wildcard $(objpfx)conform-*.out) diff --git a/conform/conformtest.pl b/conform/conformtest.pl index f90a418..fd45a8d 100644 --- a/conform/conformtest.pl +++ b/conform/conformtest.pl @@ -32,27 +32,10 @@ if (@headers == ()) { "arpa/inet.h", "aio.h"); } -if ($standard ne "ISO" && $standard ne "ISO99" && $standard ne "ISO11" - && $standard ne "POSIX" && $standard ne "XPG3" && $standard ne "XPG4" - && $standard ne "UNIX98" && $standard ne "XOPEN2K" && $standard ne "XOPEN2K8" - && $standard ne "POSIX2008") { - die "unknown standard \"$standard\""; -} - -# These are the ISO C99 keywords. -@keywords = ('auto', 'break', 'case', 'char', 'const', 'continue', 'default', - 'do', 'double', 'else', 'enum', 'extern', 'float', 'for', 'goto', - 'if', 'inline', 'int', 'long', 'register', 'restrict', 'return', - 'short', 'signed', 'sizeof', 'static', 'struct', 'switch', - 'typedef', 'union', 'unsigned', 'void', 'volatile', 'while'); - -# These are symbols which are known to pollute the namespace. -@knownproblems = ('unix', 'linux', 'i386'); - $CFLAGS{"ISO"} = "-ansi"; $CFLAGS{"ISO99"} = "-std=c99"; $CFLAGS{"ISO11"} = "-std=c1x -D_ISOC11_SOURCE"; -$CFLAGS{"POSIX"} = "-D_POSIX_C_SOURCE=199912"; +$CFLAGS{"POSIX"} = "-D_POSIX_C_SOURCE=199912 -ansi"; $CFLAGS{"XPG3"} = "-D_XOPEN_SOURCE"; $CFLAGS{"XPG4"} = "-D_XOPEN_SOURCE_EXTENDED"; $CFLAGS{"UNIX98"} = "-D_XOPEN_SOURCE=500"; @@ -62,27 +45,40 @@ $CFLAGS{"POSIX2008"} = "-D_POSIX_C_SOURCE=200809L"; $CFLAGS = "$flags -fno-builtin '-D__attribute__(x)=' $CFLAGS{$standard} -D_ISOMAC"; -if ($standard ne "XOPEN2K8" && $standard ne "POSIX2008") { - # Some headers need a bit more attention. At least with XPG7 - # all headers should be self-contained. - $mustprepend{'inttypes.h'} = "#include \n"; - $mustprepend{'glob.h'} = "#include \n"; - $mustprepend{'grp.h'} = "#include \n"; - $mustprepend{'regex.h'} = "#include \n"; - $mustprepend{'pwd.h'} = "#include \n"; - $mustprepend{'sched.h'} = "#include \n"; - $mustprepend{'signal.h'} = "#include \n#include \n"; - $mustprepend{'stdio.h'} = "#include \n"; - $mustprepend{'sys/stat.h'} = "#include \n"; - $mustprepend{'wchar.h'} = "#include \n"; - $mustprepend{'wordexp.h'} = "#include \n"; -} +# Check standard name for validity. +die "unknown standard \"$standard\"" if ($CFLAGS{$standard} eq ""); + +# if ($standard ne "XOPEN2K8" && $standard ne "POSIX2008") { +# # Some headers need a bit more attention. At least with XPG7 +# # all headers should be self-contained. +# $mustprepend{'inttypes.h'} = "#include \n"; +# $mustprepend{'glob.h'} = "#include \n"; +# $mustprepend{'grp.h'} = "#include \n"; +# $mustprepend{'regex.h'} = "#include \n"; +# $mustprepend{'pwd.h'} = "#include \n"; +# $mustprepend{'sched.h'} = "#include \n"; +# $mustprepend{'signal.h'} = "#include \n#include \n"; +# $mustprepend{'stdio.h'} = "#include \n"; +# $mustprepend{'sys/stat.h'} = "#include \n"; +# $mustprepend{'wchar.h'} = "#include \n"; +# $mustprepend{'wordexp.h'} = "#include \n"; +# } + +# These are the ISO C99 keywords. +@keywords = ('auto', 'break', 'case', 'char', 'const', 'continue', 'default', + 'do', 'double', 'else', 'enum', 'extern', 'float', 'for', 'goto', + 'if', 'inline', 'int', 'long', 'register', 'restrict', 'return', + 'short', 'signed', 'sizeof', 'static', 'struct', 'switch', + 'typedef', 'union', 'unsigned', 'void', 'volatile', 'while'); # Make a hash table from this information. while ($#keywords >= 0) { $iskeyword{pop (@keywords)} = 1; } +# These are symbols which are known to pollute the namespace. +@knownproblems = ('unix', 'linux', 'i386'); + # Make a hash table from the known problems. while ($#knownproblems >= 0) { $isknown{pop (@knownproblems)} = 1; @@ -436,7 +432,7 @@ while ($#headers >= 0) { "Member \"$member\" does not have the correct type.", $res, 0); } - } elsif (/^optional-constant *([a-zA-Z0-9_]*) ([>=<]+) ([A-Za-z0-9_-]*)/) { + } elsif (/^optional-constant *([a-zA-Z0-9_]*) ([>== 0) { $res = runtest ($fnamebase, "Testing for value of constant $const", "Constant \"$const\" has not the right value.", $res); } - } elsif (/^constant *([a-zA-Z0-9_]*) *([>=<]+) ([A-Za-z0-9_-]*)/) { + } elsif (/^constant *([a-zA-Z0-9_]*) *([>== 0) { compiletest ($fnamebase, "Test availability of macro $macro", "NOT PRESENT", $missing, 1); - } elsif (/^macro *([a-zA-Z0-9_]*) *([>=<]+) ([A-Za-z0-9_]*)/) { + } elsif (/^macro *([a-zA-Z0-9_]*) *([>=