X-Git-Url: http://git.shadowcat.co.uk/gitweb/gitweb.cgi?a=blobdiff_plain;f=cflags.SH;h=6c26025379a25aa4d2f480ebf88f87af00ffddb5;hb=33b5f13c2468a991d2b495f02a62b59163be82af;hp=3ee7c5f0c64d6bc2a1dc73a60fa3d2e761132f65;hpb=75550b4e442842ecb6730cd1ec1d17d1900bcbeb;p=p5sagit%2Fp5-mst-13.2.git diff --git a/cflags.SH b/cflags.SH index 3ee7c5f..6c26025 100755 --- a/cflags.SH +++ b/cflags.SH @@ -123,22 +123,52 @@ for file do *) ;; esac -# Add -Wall for the core and core modules iff gcc and not already -Wall +# Add -Wall for the core modules iff gcc and not already -Wall warn='' case "$gccversion" in '') ;; +Intel*) ;; *) case "$ccflags" in *-Wall*) ;; -# Can't add -ansi here because it will fail e.g. in Solaris. + *) warn="$warn -Wall" ;; + esac + case "$gccansipedantic" in + define) + case "$gccversion" in + [12]*) ;; # gcc versions 1 (gasp!) and 2 are not good for this. + *) case "$osname" in + # Add -ansi -pedantic only for known platforms. + aix|dec_osf|freebsd|hpux|irix|linux) + ansipedantic="-ansi -pedantic" ;; + solaris) +# Can't add -ansi for Solaris. # Off_t/off_t is a struct in Solaris with largefiles, and with -ansi # that struct cannot be compared with a flat integer, such as a STRLEN. # The -ansi will also cause a lot of noise in Solaris because of: # /usr/include/sys/resource.h:148: warning: `struct rlimit64' declared inside parameter list - *) warn='-Wall' ;; + ansipedantic="-pedantic" ;; + esac + for i in $ansipedantic + do + case "$ccflags" in + *$i*) ;; + *) warn="$warn $i" ;; + esac + done + case "$warn$ccflags" in + *-pedantic*) warn="$warn -DPERL_GCC_PEDANTIC" ;; + esac + ;; + esac + ;; esac ;; esac +if test -f .patch; then + ccflags="-DPERL_PATCHNUM=`cat .patch` $ccflags" +fi + : Can we perhaps use $ansi2knr here echo "$cc -c -DPERL_CORE $ccflags $optimize $warn" eval "$also "'"$cc -DPERL_CORE -c $ccflags $optimize $warn"'