STYLE: inconsistency in scotch, metis library locations

- avoid leaving any duplicate run-time libraries about that are
  not part of the LD_LIBRARY_PATH.

- incorrect ADIOS library path reported
This commit is contained in:
mark
2016-11-04 21:11:24 +01:00
parent 6b8eecffbd
commit 363691ff97
2 changed files with 66 additions and 56 deletions

View File

@ -52,6 +52,25 @@ wmakeCheckPwd "$WM_THIRD_PARTY_DIR" || {
[ -n "$WM_CXXFLAGS" ] && export CXXFLAGS="$WM_CXXFLAGS" [ -n "$WM_CXXFLAGS" ] && export CXXFLAGS="$WM_CXXFLAGS"
[ -n "$WM_LDFLAGS" ] && export LDFLAGS="$WM_LDFLAGS" [ -n "$WM_LDFLAGS" ] && export LDFLAGS="$WM_LDFLAGS"
warnBuildIssues()
{
echo
echo " ---------------------------------------------------"
echo " Optional component ($1) had build issues"
echo " OpenFOAM will nonetheless remain largely functional"
echo " ---------------------------------------------------"
echo
}
warnNotFound()
{
echo " Optional component ($1) was not found"
echo
}
#------------------------------------------------------------------------------
echo echo
echo ======================================== echo ========================================
echo Start ThirdParty Allwmake echo Start ThirdParty Allwmake
@ -216,6 +235,8 @@ elif [ -d "$SCOTCH_VERSION" ]
then then
( (
cd $SCOTCH_VERSION/src || exit 1 cd $SCOTCH_VERSION/src || exit 1
rm -rf $SCOTCH_ARCH_PATH
applyPatch $SCOTCH_VERSION .. # patch at parent-level applyPatch $SCOTCH_VERSION .. # patch at parent-level
prefixDIR=$SCOTCH_ARCH_PATH prefixDIR=$SCOTCH_ARCH_PATH
@ -248,15 +269,16 @@ then
# cleanup, could also remove Makefile.inc # cleanup, could also remove Makefile.inc
make realclean 2>/dev/null make realclean 2>/dev/null
) ) || warnBuildIssues SCOTCH
else else
echo " Optional component (SCOTCH) was not found" warnNotFound SCOTCH
fi fi
# build ptscotch if MPI (ThirdParty or system) is available # Build ptscotch if MPI (ThirdParty or system) is available
# and there is a scotch include available (ie, normal scotch was built) # and normal scotch was build (has include and library)
if [ "${FOAM_MPI:-dummy}" != dummy ] && \ if [ "${FOAM_MPI:-dummy}" != dummy ] && \
[ -f $SCOTCH_ARCH_PATH/include/scotch.h ] || \ [ -f $SCOTCH_ARCH_PATH/include/scotch.h \
-a -r $FOAM_EXT_LIBBIN/libscotch.so ] || \
{ {
echo echo
echo " WARNING: skipping pt-scotch - 'scotch.h' include file not found!" echo " WARNING: skipping pt-scotch - 'scotch.h' include file not found!"
@ -314,7 +336,7 @@ then
) )
fi fi
# verify existence of scotch include # verify existence of ptscotch include
[ -f $SCOTCH_ARCH_PATH/include/$FOAM_MPI/ptscotch.h ] || { [ -f $SCOTCH_ARCH_PATH/include/$FOAM_MPI/ptscotch.h ] || {
echo echo
echo " WARNING: required include file 'ptscotch.h' not found!" echo " WARNING: required include file 'ptscotch.h' not found!"
@ -334,8 +356,6 @@ if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/metis)
then then
. $settings . $settings
fi fi
if [ -d "$METIS_VERSION" ]
then
if [ -f $METIS_ARCH_PATH/include/metis.h \ if [ -f $METIS_ARCH_PATH/include/metis.h \
-a -r $FOAM_EXT_LIBBIN/libmetis.so ] -a -r $FOAM_EXT_LIBBIN/libmetis.so ]
@ -343,57 +363,46 @@ then
echo " metis header in $METIS_ARCH_PATH/include" echo " metis header in $METIS_ARCH_PATH/include"
echo " metis libs in $FOAM_EXT_LIBBIN" echo " metis libs in $FOAM_EXT_LIBBIN"
echo echo
else elif [ -d "$METIS_VERSION" ]
then
( (
set -x
cd $METIS_VERSION || exit 1 cd $METIS_VERSION || exit 1
rm -rf $METIS_ARCH_PATH
if [ "$WM_PRECISION_OPTION" = "DP" ] case "$WM_PRECISION_OPTION" in
then SP)
FLOAT_PRECISION=64 WM_SCALAR_SIZE=32
elif [ "$WM_PRECISION_OPTION" = "SP" ] ;;
then DP)
FLOAT_PRECISION=32 WM_SCALAR_SIZE=64
else ;;
*)
echo " Metis pre-configure error:" echo " Metis pre-configure error:"
echo " WM_PRECISION_OPTION is neither DP nor SP" echo " WM_PRECISION_OPTION neither DP nor SP"
exit 1 exit 1
fi esac
# Change user settings automatically # Change user settings automatically
sed -i -e 's=\(#define IDXTYPEWIDTH\).*=\1 '$WM_LABEL_SIZE'=' \ sed -i -e 's=\(#define IDXTYPEWIDTH\).*=\1 '$WM_LABEL_SIZE'=' \
-e 's=\(#define REALTYPEWIDTH\).*=\1 '$FLOAT_PRECISION'=' \ -e 's=\(#define REALTYPEWIDTH\).*=\1 '$WM_SCALAR_SIZE'=' \
include/metis.h include/metis.h
make config shared=1 prefix=$METIS_ARCH_PATH # No config option for the library location.
make -j $WM_NCOMPPROCS install # - build normally and use mv to relocate it
cp $METIS_ARCH_PATH/lib/libmetis.so $FOAM_EXT_LIBBIN
) make config shared=true prefix=$METIS_ARCH_PATH \
fi && make -j $WM_NCOMPPROCS install \
&& mv $METIS_ARCH_PATH/lib/libmetis.so $FOAM_EXT_LIBBIN
rmdir $METIS_ARCH_PATH/lib 2>/dev/null || true # failure is not critical
) || warnBuildIssues METIS
else else
echo " Optional component (METIS) was not found" warnNotFound METIS
fi fi
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
warnBuildIssues()
{
echo
echo " ---------------------------------------------------"
echo " Optional component ($1) had build issues"
echo " OpenFOAM will nonetheless remain largely functional"
echo " ---------------------------------------------------"
echo
}
warnNotFound()
{
echo " Optional component ($1) was not found"
echo
}
# CGAL is optional # CGAL is optional
echo echo
echo ======================================== echo ========================================

View File

@ -127,7 +127,8 @@ if [ -f $ADIOS_ARCH_PATH/include/adios.h \
-a -r $ADIOS_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/libadios_${FOAM_MPI}.a ] -a -r $ADIOS_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/libadios_${FOAM_MPI}.a ]
then then
echo " ADIOS header in $ADIOS_ARCH_PATH/include" echo " ADIOS header in $ADIOS_ARCH_PATH/include"
echo " ADIOS libs in $FOAM_EXT_LIBBIN" ### echo " ADIOS libs in $FOAM_EXT_LIBBIN" # dynamic
echo " ADIOS libs in $ADIOS_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH" # static
echo echo
else else
( (