commit 45b0cbc71929930a874e1c09e0770aa64d0ae697
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Thu Apr 23 13:14:56 2020 -0500
Add C++ warnings treated as error for autotools builds.
commit 6debcddcc766601799d5bd661bd60946f951a07e
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Fri Jun 19 16:50:03 2020 -0500
Remove tests for develop branch from testh5cc.sh.in.
Add @H5_ECXXFLAGS@ to AM_CXXFLAGS.
commit fed497e7f207313b2a133d3b68c942b7d7104b90
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Fri Jun 12 15:06:39 2020 -0500
Merge pull request #2646 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:develop to develop
* commit '998c6470d78e14228695419c3b514c35ecf3d69e':
Remove unnecessary version conditions for Clang compilers.
commit 92e52ce5c211bd1d3991a3b8bb67287ac7b652aa
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Wed Jun 10 18:53:45 2020 -0500
Merge pull request #2639 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:develop to develop
* commit 'a33667faf226f5d8c9633bf537893e8fce1bf1f6':
Add c++ to --enable-sanitize-checks option.
commit 2e802534fb997b81fa98fdd1c7d97d4310898e0d
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Wed Jun 10 15:18:36 2020 -0500
Merge pull request #2633 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:develop to develop
* commit '20eab963899841c9a003baebead8e3bc07d9e127':
Remove duplicate entries in MANIFEST.
Make changes to CMake CompilerFlags.cmake files so extra flags are loaded for non-GNU compilers.
Update new clang files to not pick up clang as vendor for pgCC. Add new files to MANIFEST Temporary demotion of 2 -Werror warning flags that fail on macos 10.12 Remove Production flag unknown to Apple clang.
commit 96ef60a58a23847a7da89a891f2415055ec2ab60
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Mon Jun 8 16:24:49 2020 -0500
Merge pull request #2631 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:develop to develop
* commit 'b942a4d8a3e27317cac50ce37ff5302d477664d8':
Clean up code to get clang version in config/linux-gnulibc1
commit 8a7c687da568e8b50b38fa53da1ca63759be6ec4
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Mon Jun 8 11:42:37 2020 -0500
Merge pull request #2623 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:develop to develop
* commit 'c7626f79fdee4eee13925e240ef41e61f3367eab':
Add flags from config/clang-warnings/*general files to H5 C and CXX flags for all versions of Clang and Clang++ compilers. Switched from cut to awk in testcheck_version.sh.in to avoid dependence on tab vs. " " in version definitions in H5public.h.
Add files for adding warning flags for clang compilers in autotools configure.
commit db3ef7ff3c1ed79167cecef831501411cff8291f
Merge: 5a0f8d7 f9f1310
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Fri Jun 19 14:46:22 2020 -0500
Merge branch 'hdf5_1_12' of https://bitbucket.hdfgroup.org/scm/~lrknox/hdf5_lrk into hdf5_1_12
commit 5a0f8d7940ae57b445f545a0abd7e303ce6924ee
Author: Larry Knox <lrknox@hdfgroup.org>
Date: Wed Jun 10 20:15:41 2020 -0500
Merge pull request #2636 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:HDFFV-11000-update-testh5cc.sh.in-for-version to develop
* commit '5c0bd670d6e9919c463fbc05de99e2ba55b0761e':
Add tests for all version to H5_NO_DEPRECATED_SYMBOLS section and to section for current version, with and without default API version flags.
HDFFV-11000: update-testh5cc.sh.in to test sample versioned functions in HDF5 1.10, 1.12 and develop.
346 lines
9.0 KiB
Bash
346 lines
9.0 KiB
Bash
# -*- shell-script -*-
|
|
#
|
|
# Copyright by The HDF Group.
|
|
# Copyright by the Board of Trustees of the University of Illinois.
|
|
# All rights reserved.
|
|
#
|
|
# This file is part of HDF5. The full HDF5 copyright notice, including
|
|
# terms governing use, modification, and redistribution, is contained in
|
|
# the COPYING file, which can be found at the root of the source code
|
|
# distribution tree, or in https://support.hdfgroup.org/ftp/HDF5/releases.
|
|
# If you do not have access to either file, you may request a copy from
|
|
# help@hdfgroup.org.
|
|
|
|
|
|
# This file is part of the HDF5 build script. It is processed shortly
|
|
# after configure starts and defines, among other things, flags for
|
|
# the various compile modes.
|
|
#
|
|
# See BlankForm in this directory for details.
|
|
|
|
# The default compiler is `gcc'.
|
|
if test -z "$CC"; then
|
|
if test "X-$enable_parallel" = "X-yes"; then
|
|
# default to use mpicc which is the defacto MPI compiler name
|
|
CC=mpicc
|
|
CC_BASENAME=mpicc
|
|
else
|
|
CC=gcc
|
|
CC_BASENAME=gcc
|
|
fi
|
|
fi
|
|
|
|
# Figure out GNU C compiler flags
|
|
. $srcdir/config/gnu-flags
|
|
|
|
# Figure out PGI C compiler flags
|
|
. $srcdir/config/pgi-flags
|
|
|
|
# Figure out CCE C compiler flags
|
|
. $srcdir/config/cce-flags
|
|
|
|
# Figure out Intel C compiler flags
|
|
. $srcdir/config/intel-flags
|
|
|
|
# Figure out Clang C compiler flags
|
|
. $srcdir/config/clang-flags
|
|
|
|
# Use default Fortran 90 compiler according to what C compiler is used.
|
|
if test "X-" = "X-$FC"; then
|
|
case $CC_BASENAME in
|
|
gcc*)
|
|
FC=gfortran
|
|
FC_BASENAME=gfortran
|
|
;;
|
|
pgcc*)
|
|
FC=pgf90
|
|
FC_BASENAME=pgf90
|
|
;;
|
|
icc*)
|
|
FC=ifort
|
|
FC_BASENAME=ifort
|
|
;;
|
|
mpicc*)
|
|
FC=mpif90
|
|
FC_BASENAME=mpif90
|
|
;;
|
|
clang*)
|
|
# clang has no fortran compiler. Use gfortran.
|
|
FC=gfortran
|
|
FC_BASENAME=gfortran
|
|
;;
|
|
esac
|
|
else
|
|
case $FC in
|
|
# The PGI and Intel compilers are automatically detected below
|
|
ifc*|ifort*|pgf90*)
|
|
;;
|
|
|
|
*f95*)
|
|
# Figure out which compiler we are using: pgf90 or Absoft f95
|
|
RM='rm -f'
|
|
tmpfile=/tmp/cmpver.$$
|
|
$FC -V >$tmpfile
|
|
if test -s "$tmpfile"; then
|
|
if( grep -s 'Absoft' $tmpfile > /dev/null) then
|
|
FC_BASENAME=f95
|
|
fi
|
|
if( grep -s 'pgf90' $tmpfile > /dev/null) then
|
|
FC_BASENAME=pgf90
|
|
fi
|
|
fi
|
|
$RM $tmpfile
|
|
fc_version_info=`$FC -V | grep Absoft`
|
|
;;
|
|
# The NAG compiler
|
|
nagfor*|nagftn*)
|
|
RM='rm -f'
|
|
tmpfile=/tmp/cmpver.$$
|
|
$FC -V >& $tmpfile
|
|
if test -s "$tmpfile"; then
|
|
if( grep -s 'NAG Fortran' $tmpfile > /dev/null) then
|
|
FC_BASENAME=nagfor
|
|
fi
|
|
fi
|
|
fc_version_info=`grep "NAG Fortran" $tmpfile`
|
|
echo "compiler '$FC' is $fc_version_info"
|
|
$RM $tmpfile
|
|
;;
|
|
*)
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# Figure out GNU FC compiler flags
|
|
. $srcdir/config/gnu-fflags
|
|
|
|
# Figure out PGI FC compiler flags
|
|
. $srcdir/config/pgi-fflags
|
|
|
|
# Figure out CCE FC compiler flags
|
|
. $srcdir/config/cce-fflags
|
|
|
|
# Figure out Intel FC compiler flags
|
|
. $srcdir/config/intel-fflags
|
|
|
|
case $FC_BASENAME in
|
|
#
|
|
# Absoft compiler
|
|
#
|
|
f95)
|
|
# Set required flag for compiling C stubs
|
|
H5_CFLAGS="$H5_CFLAGS"
|
|
|
|
F9XSUFFIXFLAG=""
|
|
# We force compiler to use upper case for external names
|
|
# (just in case since this should be a default EIP)
|
|
H5_FCFLAGS="$H5_FCFLAGS"
|
|
FSEARCH_DIRS=""
|
|
|
|
# Production
|
|
PROD_FCFLAGS=
|
|
|
|
# Debug
|
|
DEBUG_FCFLAGS=
|
|
|
|
# Symbols
|
|
SYMBOLS_FCFLAGS="-g"
|
|
NO_SYMBOLS_FCFLAGS="-s"
|
|
|
|
# Profiling
|
|
PROFILE_FCFLAGS="-pg"
|
|
|
|
# Optimization
|
|
HIGH_OPT_FCFLAGS="-O"
|
|
DEBUG_OPT_FCFLAGS=
|
|
NO_OPT_FCFLAGS=
|
|
|
|
f9x_flags_set=yes
|
|
;;
|
|
#
|
|
# NAG compiler
|
|
#
|
|
nagfor)
|
|
|
|
F9XSUFFIXFLAG=""
|
|
# We force compiler to use upper case for external names
|
|
# (just in case since this should be a default EIP)
|
|
H5_FCFLAGS="$H5_FCFLAGS"
|
|
FSEARCH_DIRS=""
|
|
|
|
# Production
|
|
PROD_FCFLAGS=
|
|
|
|
# Debug
|
|
DEBUG_FCFLAGS="-C"
|
|
|
|
# Symbols
|
|
SYMBOLS_FCFLAGS="-g"
|
|
NO_SYMBOLS_FCFLAGS="-s"
|
|
|
|
# Profiling
|
|
PROFILE_FCFLAGS="-pg"
|
|
|
|
# Optimization
|
|
HIGH_OPT_FCFLAGS="-O"
|
|
DEBUG_OPT_FCFLAGS="-O0"
|
|
NO_OPT_FCFLAGS="-O0"
|
|
|
|
f9x_flags_set=yes
|
|
;;
|
|
|
|
esac
|
|
|
|
# The default C++ compiler
|
|
|
|
# The default compiler is `g++'.
|
|
if test -z "$CXX"; then
|
|
CXX=g++
|
|
CXX_BASENAME=g++
|
|
fi
|
|
|
|
# Figure out GNU CXX compiler flags
|
|
. $srcdir/config/gnu-cxxflags
|
|
|
|
# Figure out Clang CXX compiler flags
|
|
. $srcdir/config/clang-cxxflags
|
|
|
|
# compiler version strings
|
|
|
|
# check if the compiler_version_info is already set
|
|
if test -z "$cc_version_info"; then
|
|
|
|
case $CC in
|
|
# whatever matches *pgcc* will also match *gcc*, so this one must come first
|
|
*pgcc*)
|
|
cc_version_info=`$CC $CFLAGS $H5_CFLAGS -V 2>&1 | grep 'pgcc'`
|
|
;;
|
|
|
|
*gcc*)
|
|
cc_version_info=`$CC $CFLAGS $H5_CFLAGS --version 2>&1 | grep -v 'PathScale' |\
|
|
grep 'GCC' | sed 's/\(.*(GCC) [-a-z0-9\. ]*\).*/\1/'`
|
|
;;
|
|
# this must come before *icc* for the same reason
|
|
*mpicc*)
|
|
cc_version_info=`$CC $CCFLAGS $H5_CCFLAGS -v 2>&1 | grep 'version' |\
|
|
sed 's/^[a-z0-9]* for //' |\
|
|
sed 's/\"/\\\"/g' |\
|
|
sed 's/^\([a-z]* \)/ built with \1/1'`
|
|
cc_version_info=`echo $cc_version_info`
|
|
;;
|
|
|
|
*icc*)
|
|
cc_version_info=`$CC $CCFLAGS $H5_CCFLAGS -V 2>&1 | grep 'Version' |\
|
|
sed 's/\(Intel.* Compiler\).*\( Version [a-z0-9\.]*\).*\( Build [0-9]*\)/\1\2\3/'`
|
|
;;
|
|
|
|
*clang*)
|
|
cc_version_info="`$CC $CFLAGS $H5_CFLAGS --version 2>&1 |\
|
|
grep 'clang version' | sed 's/.*clang version \([-a-z0-9\.]*\).*/\1/'`"
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get cc_version_info for $CC"
|
|
;;
|
|
esac
|
|
|
|
fi
|
|
|
|
# get fortran version info
|
|
# check if the compiler_version_info is already set
|
|
if test -z "$fc_version_info"; then
|
|
case $FC in
|
|
*gfortran*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS --version 2>&1 |\
|
|
grep 'GCC' | sed 's/\(.*(GCC) [-a-z0-9\. ]*\).*/\1/'`
|
|
;;
|
|
|
|
*mpif90*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS -v 2>&1 | grep 'version' |\
|
|
sed 's/^[a-z0-9]* for //' |\
|
|
sed 's/\"/\\\"/g' |\
|
|
sed 's/^\([a-z]* \)/ built with \1/1'`
|
|
fc_version_info=`echo $fc_version_info`
|
|
;;
|
|
|
|
*ifc*|*ifort*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS -V 2>&1 | grep 'Version' |\
|
|
sed 's/\(Intel.* Compiler\).*\( Version [a-z0-9\.]*\).*\( Build [0-9]*\)/\1\2\3/'`
|
|
;;
|
|
|
|
*f95*)
|
|
# Figure out which compiler we are using: pgf90 or Absoft f95
|
|
RM='rm -f'
|
|
tmpfile=/tmp/cmpver.$$
|
|
$FC -V >$tmpfile
|
|
if test -s "$tmpfile"; then
|
|
if( grep -s 'Absoft' $tmpfile > /dev/null) then
|
|
FC_BASENAME=f95
|
|
fi
|
|
fi
|
|
$RM $tmpfile
|
|
fc_version_info=`$FC -V | grep Absoft`
|
|
;;
|
|
|
|
*g95*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS --version 2>&1 |\
|
|
grep 'GCC'`
|
|
;;
|
|
|
|
*pgf90*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS -V 2>&1 | grep 'pgf90'`
|
|
;;
|
|
*nagfor*|*nagftn*)
|
|
RM='rm -f'
|
|
tmpfile=/tmp/cmpver.$$
|
|
$FC -V >& $tmpfile
|
|
if test -s "$tmpfile"; then
|
|
if( grep -s 'NAG Fortran' $tmpfile > /dev/null) then
|
|
FC_BASENAME=nagfor
|
|
fi
|
|
fi
|
|
fc_version_info=`grep "NAG Fortran" $tmpfile`
|
|
$RM $tmpfile
|
|
echo "compiler '$FC' is $fc_version_info"
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get fc_version_info for $FC"
|
|
;;
|
|
esac
|
|
fi
|
|
|
|
# get c++ version info
|
|
# check if the compiler_version_info is already set
|
|
if test -z "$cxx_version_info"; then
|
|
case $CXX in
|
|
*g++*)
|
|
cxx_version_info=`$CXX $CXXFLAGS $H5_CXXFLAGS --version 2>&1 |\
|
|
grep 'GCC' | sed 's/\(.*(GCC) [-a-z0-9\. ]*\).*/\1/'`
|
|
;;
|
|
*icpc*)
|
|
cxx_version_info=`$CXX $CXXFLAGS $H5_CXXFLAGS -V 2>&1 | grep 'Version' |\
|
|
sed 's/\(Intel.* Compiler\).*\( Version [a-z0-9\.]*\).*\( Build [0-9]*\)/\1\2\3/'`
|
|
;;
|
|
*pgCC*)
|
|
cxx_version_info=`$CXX $CXXFLAGS $H5_CXXFLAGS -V 2>&1 | grep 'pgCC'`
|
|
;;
|
|
|
|
*mpicxx*)
|
|
cxx_version_info=`$CXX $CXXFLAGS $H5_CXXFLAGS -v 2>&1 | grep 'version' |\
|
|
sed 's/^[a-z0-9]* for //' |\
|
|
sed 's/^\([a-z]* \)/ built with \1/1'`
|
|
cxx_version_info=`echo $cxx_version_info`
|
|
;;
|
|
|
|
*clang++*)
|
|
cxx_version_info="`$CXX $CXXFLAGS $H5_CXXFLAGS --version 2>&1 |\
|
|
grep 'clang version' | sed 's/.*clang version \([-a-z0-9\.]*\).*/\1/'`"
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get cxx_version_info for $CXX"
|
|
;;
|
|
esac
|
|
fi
|