mirror of
https://github.com/HDFGroup/hdf5.git
synced 2025-01-18 15:15:56 +08:00
89fbe00dec
* commit '54957d37f5aa73912763dbb6e308555e863c43f4': Commit copyright header change for src/H5PLpkg.c which was added after running script to make changes. Add new files in release_docs to MANIFEST. Cimmit changes to Makefile.in(s) and H5PL.c that resulted from running autogen.sh. Merge pull request #407 in HDFFV/hdf5 from ~LRKNOX/hdf5_lrk:hdf5_1_10_1 to hdf5_1_10_1 Change copyright headers to replace url referring to file to be removed and replace it with new url for COPYING file.
207 lines
4.9 KiB
Bash
207 lines
4.9 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 `sunpro cc'
|
|
if test "X-" = "X-$CC"; then
|
|
CC=cc
|
|
CC_BASENAME=cc
|
|
fi
|
|
|
|
# Try gcc compiler flags
|
|
. $srcdir/config/gnu-flags
|
|
|
|
# Try solaris native compiler flags
|
|
if test "X-" = "X-$cc_flags_set"; then
|
|
H5_CFLAGS="$H5_CFLAGS -erroff=%none -DBSD_COMP"
|
|
|
|
# Production
|
|
# NDEBUG is handled explicitly by the configure script
|
|
PROD_CFLAGS=
|
|
|
|
# Debug
|
|
# NDEBUG is handled explicitly by the configure script
|
|
# -g is hanled by the symbols flags
|
|
DEBUG_CFLAGS=
|
|
|
|
# Symbols
|
|
NO_SYMBOLS_CFLAGS="-s"
|
|
SYMBOLS_CFLAGS="-g"
|
|
|
|
# Profile
|
|
PROFILE_CFLAGS="-xpg"
|
|
|
|
# Optimization
|
|
# -g produces rather slow code. "-g -O" produces much faster code with some
|
|
# loss of debugger functions such as not able to print local variables.
|
|
HIGH_OPT_CFLAGS="-O"
|
|
DEBUG_OPT_CFLAGS="-O"
|
|
NO_OPT_CFLAGS=
|
|
|
|
cc_flags_set=yes
|
|
# Special linking flag is needed to build with Fortran on Solaris 5.9
|
|
system_version="`uname -r`"
|
|
case "$system_version" in
|
|
5.9*)
|
|
# Need the xopenmp flag to build the Fortran library
|
|
if test X-$enable_fortran = X-yes; then
|
|
AM_LDFLAGS="$AM_LDFLAGS -xopenmp=stubs"
|
|
fi
|
|
;;
|
|
esac
|
|
|
|
fi
|
|
|
|
LIBS="$LIBS"
|
|
|
|
# The default Fortran 90 compiler
|
|
|
|
if test "X-" = "X-$FC"; then
|
|
FC=f90
|
|
fi
|
|
|
|
if test "X-" = "X-$f9x_flags_set"; then
|
|
F9XSUFFIXFLAG=""
|
|
FSEARCH_DIRS=""
|
|
|
|
H5_FCFLAGS="$H5_FCFLAGS"
|
|
|
|
# TODO: Revisit these flags.
|
|
|
|
# Production
|
|
# NDEBUG is handled explicitly by the configure script
|
|
PROD_FCFLAGS=
|
|
|
|
# Debug
|
|
# NDEBUG is handled explicitly by the configure script
|
|
# -g is hanled by the symbols flags
|
|
DEBUG_FCFLAGS=
|
|
|
|
# Symbols
|
|
NO_SYMBOLS_FCFLAGS=
|
|
SYMBOLS_FCFLAGS="-g"
|
|
|
|
# Profile
|
|
PROFILE_FCFLAGS=
|
|
|
|
# Optimization
|
|
# -g produces rather slow code. "-g -O" produces much faster code with some
|
|
# loss of debugger functions such as not able to print local variables.
|
|
HIGH_OPT_FCFLAGS="-O2"
|
|
DEBUG_OPT_FCFLAGS="-O"
|
|
NO_OPT_FCFLAGS=
|
|
|
|
f9x_flags_set=yes
|
|
fi
|
|
|
|
# The default C++ compiler
|
|
|
|
# The default compiler is `sunpro cc'
|
|
if test -z "$CXX"; then
|
|
CXX=CC
|
|
CXX_BASENAME=CC
|
|
fi
|
|
|
|
# Try gcc compiler flags
|
|
#. $srcdir/config/gnu-flags
|
|
|
|
cxx_version="`$CXX -V 2>&1 |grep 'WorkShop' |\
|
|
sed 's/.*WorkShop.*C++ \([0-9\.]*\).*/\1/'`"
|
|
|
|
cxx_vers_major=`echo $cxx_version | cut -f1 -d.`
|
|
cxx_vers_minor=`echo $cxx_version | cut -f2 -d.`
|
|
cxx_vers_patch=`echo $cxx_version | cut -f3 -d.`
|
|
|
|
# Specify the "-features=tmplife" if the compiler can handle this...
|
|
if test -n "$cxx_version"; then
|
|
if test $cxx_vers_major -ge 5 -a $cxx_vers_minor -ge 3 -o $cxx_vers_major -gt 5; then
|
|
H5_CXXFLAGS="$H5_CXXFLAGS -features=tmplife"
|
|
fi
|
|
fi
|
|
|
|
# Try solaris native compiler flags
|
|
if test -z "$cxx_flags_set"; then
|
|
H5_CXXFLAGS="$H5_CXXFLAGS -instances=static"
|
|
H5_CPPFLAGS="$H5_CPPFLAGS -LANG:std"
|
|
|
|
# Production
|
|
# NDEBUG is handled explicitly by the configure script
|
|
PROD_CXXFLAGS=
|
|
|
|
# Debug
|
|
# NDEBUG is handled explicitly by the configure script
|
|
# -g is hanled by the symbols flags
|
|
DEBUG_CXXFLAGS=
|
|
|
|
# Symbols
|
|
NO_SYMBOLS_CXXFLAGS="-s"
|
|
SYMBOLS_CXXFLAGS="-g"
|
|
|
|
# Profile
|
|
PROFILE_CXXFLAGS="-xpg"
|
|
|
|
# Optimization
|
|
# -g produces rather slow code. "-g -O" produces much faster code with some
|
|
# loss of debugger functions such as not able to print local variables.
|
|
HIGH_OPT_CXXFLAGS="-O"
|
|
DEBUG_OPT_CXXFLAGS="-O"
|
|
NO_OPT_CXXFLAGS=
|
|
|
|
cxx_flags_set=yes
|
|
fi
|
|
|
|
# compiler version strings
|
|
case $CC in
|
|
*cc*)
|
|
cc_version_info=`$CC $CFLAGS $H5_CFLAGS -V 2>&1 | grep 'Sun' |\
|
|
sed 's/.*\(Sun .*\)/\1 /'`
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get cc_version_info for $CC"
|
|
;;
|
|
esac
|
|
echo "C compiler '$CC' is $cc_version_info"
|
|
|
|
case $FC in
|
|
# The PGI and Intel compilers are automatically detected below
|
|
*f90*)
|
|
fc_version_info=`$FC $FCFLAGS $H5_FCFLAGS -V 2>&1 | grep 'Sun' |\
|
|
sed 's/.*\(Sun .*\)/\1 /'`
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get fc_version_info for $FC"
|
|
;;
|
|
esac
|
|
echo "Fortran compiler '$FC' is $fc_version_info"
|
|
|
|
# get c++ version info
|
|
case $CXX in
|
|
*CC*)
|
|
cxx_version_info=`$CXX $CXXFLAGS $H5_CXXFLAGS -V 2>&1 | grep 'Sun' |\
|
|
sed 's/.*\(Sun .*\)/\1 /'`
|
|
;;
|
|
|
|
*)
|
|
echo "No match to get cxx_version_info for $CXX"
|
|
;;
|
|
esac
|
|
|