ENH: wmake have_* script changes

- use local 'prefix' variable for easier override and more consistency
This commit is contained in:
Mark Olesen
2019-01-10 20:14:46 +01:00
parent abf6d57ae8
commit fcf4c5fb22
15 changed files with 458 additions and 481 deletions

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,59 +54,53 @@ echo_adios2()
# -> HAVE_ADIOS2, ADIOS2_INC_DIR, ADIOS2_LIB_DIR # -> HAVE_ADIOS2, ADIOS2_INC_DIR, ADIOS2_LIB_DIR
have_adios2() have_adios2()
{ {
local header library static label settings warn local prefix header library static settings warn
# warn="==> skip adios2" # warn="==> skip adios2"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/ADIOS2) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/ADIOS2)
[ -n "$warn" ] && echo "$warn (no config.sh/ADIOS2 settings)"
return 1
}
. $settings
if isNone "$ADIOS2_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
[ -n "$warn" ] && echo "$warn (no config.sh/ADIOS2 settings)"
return 2
fi fi
# Location
prefix="$ADIOS2_ARCH_PATH"
# Header/library names # Header/library names
header="adios2.h" header="adios2.h"
library="libadios2$extLibso" library="libadios2$extLibso"
# ----------------------------------
if hasAbsdir "$ADIOS2_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $ADIOS2_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$ADIOS2_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$ADIOS2_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$ADIOS2_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -116,14 +110,15 @@ have_adios2()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
header="${header%/*}" # Strip one-level (include/adios2/...) header="${header%/*}" # Strip one-level (include/adios2/...)
# OK
export HAVE_ADIOS2=true export HAVE_ADIOS2=true
export ADIOS2_ARCH_PATH export ADIOS2_ARCH_PATH="$prefix"
export ADIOS2_INC_DIR="${header%/*}" # Basename export ADIOS2_INC_DIR="${header%/*}" # Basename
export ADIOS2_LIB_DIR="${library%/*}" # Basename export ADIOS2_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,54 +54,46 @@ echo_boost()
# -> HAVE_BOOST, BOOST_INC_DIR, BOOST_LIB_DIR # -> HAVE_BOOST, BOOST_INC_DIR, BOOST_LIB_DIR
have_boost() have_boost()
{ {
local header library static label settings warn local prefix header library static settings warn
# warn="==> skip boost" # warn="==> skip boost"
# Basic setup/checks # Setup - from the current environment
if isNone "$BOOST_ARCH_PATH"
then
[ -n "$warn" ] && echo "$warn (not available)"
return 1
fi
# Location
prefix="$BOOST_ARCH_PATH"
# Header/library names # Header/library names
header="boost/version.hpp" header="boost/version.hpp"
library="libboost_system$extLibso" library="libboost_system$extLibso"
# ----------------------------------
if hasAbsdir "$BOOST_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $BOOST_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$BOOST_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$BOOST_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$BOOST_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -111,14 +103,16 @@ have_boost()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
header="${header%/*}" # Strip one-level (include/boost/...)
header="${header%/*}" # Strip one-level (include/boost/...)
# OK
export HAVE_BOOST=true export HAVE_BOOST=true
export BOOST_ARCH_PATH export BOOST_ARCH_PATH="$prefix"
export BOOST_INC_DIR="${header%/*}" # Basename export BOOST_INC_DIR="${header%/*}" # Basename
export BOOST_LIB_DIR="${library%/*}" # Basename export BOOST_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -53,42 +53,44 @@ echo_ccmio()
# -> HAVE_CCMIO, CCMIO_INC_DIR, CCMIO_LIB_DIR # -> HAVE_CCMIO, CCMIO_INC_DIR, CCMIO_LIB_DIR
have_ccmio() have_ccmio()
{ {
local header library static label settings warn good local prefix header library static settings warn
warn="==> skip ccmio" warn="==> skip ccmio"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/ccmio) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/ccmio)
[ -n "$warn" ] && echo "$warn (no config.sh/ccmio settings)"
return 1
}
. $settings
if isNone "$CCMIO_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
[ -n "$warn" ] && echo "$warn (no config.sh/ccmio settings)"
return 2
fi fi
# Location
prefix="$CCMIO_ARCH_PATH"
# Header/library names. # Header/library names.
# Link with static libccmio only (fewer issues) # Link with static libccmio only (fewer issues)
#
header="libccmio/ccmio.h" header="libccmio/ccmio.h"
static="libccmio$extLiba" static="libccmio$extLiba"
# ----------------------------------
if hasAbsdir "$CCMIO_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $CCMIO_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$CCMIO_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$CCMIO_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
) )
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -98,16 +100,17 @@ have_ccmio()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
header="${header%/*}" # Strip one-level (include/libccmio/...)
# The libccmio uses int32_t. # The libccmio uses int32_t.
# The OpenFOAM adapter thus requires additional work for 64-bit labels. # The OpenFOAM adapter thus requires additional work for 64-bit labels.
# The OpenFOAM adapter was originally only designed for 'double' # The OpenFOAM adapter was originally only designed for 'double'
local good
if [ "$WM_LABEL_SIZE" = 32 ] if [ "$WM_LABEL_SIZE" = 32 ]
then then
if [ "$WM_PRECISION_OPTION" = DP ] if [ "$WM_PRECISION_OPTION" = DP ]
@ -124,8 +127,12 @@ have_ccmio()
return 1 return 1
fi fi
header="${header%/*}" # Strip one-level (include/libccmio/...)
# OK
export HAVE_CCMIO=true export HAVE_CCMIO=true
export CCMIO_ARCH_PATH export CCMIO_ARCH_PATH="$prefix"
export CCMIO_INC_DIR="${header%/*}" # Basename export CCMIO_INC_DIR="${header%/*}" # Basename
export CCMIO_LIB_DIR="${library%/*}" # Basename export CCMIO_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,54 +54,46 @@ echo_cgal()
# -> HAVE_CGAL, CGAL_INC_DIR, CGAL_LIB_DIR # -> HAVE_CGAL, CGAL_INC_DIR, CGAL_LIB_DIR
have_cgal() have_cgal()
{ {
local header library static label settings warn local prefix header library static settings warn
# warn="==> skip cgal" # warn="==> skip cgal"
# Basic setup/checks # Setup - from the current environment
if isNone "$CGAL_ARCH_PATH"
then
[ -n "$warn" ] && echo "$warn (not available)"
return 1
fi
# Location
prefix="$CGAL_ARCH_PATH"
# Header/library names # Header/library names
header="CGAL/version.h" header="CGAL/version.h"
library="libCGAL$extLibso" library="libCGAL$extLibso"
# ----------------------------------
if hasAbsdir "$CGAL_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $CGAL_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$CGAL_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$CGAL_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$CGAL_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -111,14 +103,15 @@ have_cgal()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
header="${header%/*}" # Strip one-level (include/CGAL/...) header="${header%/*}" # Strip one-level (include/CGAL/...)
# OK
export HAVE_CGAL=true export HAVE_CGAL=true
export CGAL_ARCH_PATH export CGAL_ARCH_PATH="$prefix"
export CGAL_INC_DIR="${header%/*}" # Basename export CGAL_INC_DIR="${header%/*}" # Basename
export CGAL_LIB_DIR="${library%/*}" # Basename export CGAL_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,57 +54,49 @@ echo_fftw()
# -> HAVE_FFTW, FFTW_INC_DIR, FFTW_LIB_DIR # -> HAVE_FFTW, FFTW_INC_DIR, FFTW_LIB_DIR
have_fftw() have_fftw()
{ {
local header library static label settings warn local prefix header library static settings warn
# warn="==> skip fftw" # warn="==> skip fftw"
# Basic setup/checks # Setup - from the current environment
if isNone "$FFTW_ARCH_PATH"
then
[ -n "$warn" ] && echo "$warn (not available)"
return 1
fi
# Location
prefix="$FFTW_ARCH_PATH"
# Header/library names # Header/library names
header="fftw3.h" header="fftw3.h"
library="libfftw3$extLibso" library="libfftw3$extLibso"
static="libfftw3$extLiba" static="libfftw3$extLiba"
# ----------------------------------
if hasAbsdir "$FFTW_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $FFTW_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$FFTW_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$FFTW_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$FFTW_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$FFTW_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$FFTW_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -114,12 +106,13 @@ have_fftw()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
# OK
export HAVE_FFTW=true export HAVE_FFTW=true
export FFTW_ARCH_PATH export FFTW_ARCH_PATH="$prefix"
export FFTW_INC_DIR="${header%/*}" # Basename export FFTW_INC_DIR="${header%/*}" # Basename
export FFTW_LIB_DIR="${library%/*}" # Basename export FFTW_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,62 +54,56 @@ echo_hypre()
# -> HAVE_HYPRE, HYPRE_INC_DIR, HYPRE_LIB_DIR # -> HAVE_HYPRE, HYPRE_INC_DIR, HYPRE_LIB_DIR
have_hypre() have_hypre()
{ {
local header library static label settings warn local prefix header library static settings warn
warn="==> skip hypre" warn="==> skip hypre"
# Basic setup/checks. Prefer current environment value? (TDB) # Setup - prefer current environment value? (TDB)
if [ ! -d "$HYPRE_ARCH_PATH" ] if [ ! -d "$HYPRE_ARCH_PATH" ]
then then
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/hypre) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/hypre)
then
. "$settings"
else
[ -n "$warn" ] && echo "$warn (no config.sh/hypre settings)" [ -n "$warn" ] && echo "$warn (no config.sh/hypre settings)"
return 1 return 2
} fi
. $settings
fi
if isNone "$HYPRE_ARCH_PATH"
then
[ -n "$warn" ] && echo "$warn (not available)"
return 1
fi fi
# Location
prefix="$HYPRE_ARCH_PATH"
# Header/library names # Header/library names
header="HYPRE.h" header="HYPRE.h"
library="libHYPRE$extLibso" library="libHYPRE$extLibso"
# ----------------------------------
if hasAbsdir "$HYPRE_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $HYPRE_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$HYPRE_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$HYPRE_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$HYPRE_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -119,12 +113,14 @@ have_hypre()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
# OK
export HAVE_HYPRE=true export HAVE_HYPRE=true
export HYPRE_ARCH_PATH export HYPRE_ARCH_PATH="$prefix"
export HYPRE_INC_DIR="${header%/*}" # Basename export HYPRE_INC_DIR="${header%/*}" # Basename
export HYPRE_LIB_DIR="${library%/*}" # Basename export HYPRE_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -55,61 +55,56 @@ echo_kahip()
# -> HAVE_KAHIP, KAHIP_ARCH_PATH, KAHIP_INC_DIR, KAHIP_LIB_DIR # -> HAVE_KAHIP, KAHIP_ARCH_PATH, KAHIP_INC_DIR, KAHIP_LIB_DIR
have_kahip() have_kahip()
{ {
local header library static label settings warn local prefix header library static settings warn
warn="==> skip kahip" warn="==> skip kahip"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/kahip) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/kahip)
[ -n "$warn" ] && echo "$warn (no config.sh/kahip settings)"
return 1
}
. $settings
if isNone "$KAHIP_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
else
[ -n "$warn" ] && echo "$warn (no config.sh/kahip settings)"
return 1 return 1
fi fi
# Location
prefix="$KAHIP_ARCH_PATH"
# Header/library names # Header/library names
header="kaHIP_interface.h" header="kaHIP_interface.h"
library="libkahip$extLibso" library="libkahip$extLibso"
static="libkahip$extLiba" static="libkahip$extLiba"
if hasAbsdir "$KAHIP_ARCH_PATH" # ----------------------------------
if isNone "$prefix"
then then
header=$(findFirstFile $KAHIP_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$KAHIP_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$KAHIP_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$KAHIP_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$KAHIP_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$KAHIP_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -119,7 +114,7 @@ have_kahip()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
@ -127,9 +122,9 @@ have_kahip()
# kahip itself is 32-bit int, but our interface itself handles some # kahip itself is 32-bit int, but our interface itself handles some
# 64-bit conversion (mesh size). # 64-bit conversion (mesh size).
echo "kahip (label=32) - $KAHIP_ARCH_PATH" echo "kahip (label=32) - $prefix"
export HAVE_KAHIP=true export HAVE_KAHIP=true
export KAHIP_ARCH_PATH export KAHIP_ARCH_PATH="$prefix"
export KAHIP_INC_DIR="${header%/*}" # Basename export KAHIP_INC_DIR="${header%/*}" # Basename
export KAHIP_LIB_DIR="${library%/*}" # Basename export KAHIP_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -55,62 +55,56 @@ echo_metis()
# -> HAVE_METIS, METIS_ARCH_PATH, METIS_INC_DIR, METIS_LIB_DIR # -> HAVE_METIS, METIS_ARCH_PATH, METIS_INC_DIR, METIS_LIB_DIR
have_metis() have_metis()
{ {
local header library static label settings warn local prefix header library static settings warn
warn="==> skip metis" warn="==> skip metis"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/metis) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/metis)
[ -n "$warn" ] && echo "$warn (no config.sh/metis settings)"
return 1
}
. $settings
if isNone "$METIS_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
[ -n "$warn" ] && echo "$warn (no config.sh/metis settings)"
return 2
fi fi
# Location
prefix="$METIS_ARCH_PATH"
# Header/library names # Header/library names
header="metis.h" header="metis.h"
library="libmetis$extLibso" library="libmetis$extLibso"
static="libmetis$extLiba" static="libmetis$extLiba"
# ----------------------------------
if hasAbsdir "$METIS_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $METIS_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$METIS_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$METIS_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$METIS_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$METIS_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$METIS_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -120,31 +114,38 @@ have_metis()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
local good label
# Ensure consistent sizes between OpenFOAM and metis header # Ensure consistent sizes between OpenFOAM and metis header
# Extract IDXTYPEWIDTH from metis.h: regex as per ThirdParty Allwmake # Extract IDXTYPEWIDTH from metis.h: regex as per ThirdParty Allwmake
label=$(sed -ne 's/^.*#define *IDXTYPEWIDTH *\([1-9][0-9]\).*/\1/p' $header) label=$(sed -ne \
: ${label:=unknown} 's/^.*#define *IDXTYPEWIDTH *\([1-9][0-9]\).*/\1/p' \
"$header")
: "${label:=unknown}"
if [ "$WM_LABEL_SIZE" = "$label" ] if [ "$WM_LABEL_SIZE" = "$label" ]
then then
echo "Metis (label=$label) - $METIS_ARCH_PATH" good=true
export HAVE_METIS=true
export METIS_ARCH_PATH
export METIS_INC_DIR="${header%/*}" # Basename
export METIS_LIB_DIR="${library%/*}" # Basename
else else
if [ -n "$warn" ] if [ -n "$warn" ]
then then
echo "$warn (label=$WM_LABEL_SIZE, metis.h has '$label')" echo "$warn (label=$WM_LABEL_SIZE, ${header##*/} has '$label')"
fi fi
no_metis no_metis
return 1 return 1
fi fi
# OK
echo "metis (label=$label) - $prefix"
export HAVE_METIS=true
export METIS_ARCH_PATH="$prefix"
export METIS_INC_DIR="${header%/*}" # Basename
export METIS_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -55,62 +55,56 @@ echo_mgridgen()
# -> HAVE_MGRIDGEN, MGRIDGEN_ARCH_PATH, MGRIDGEN_INC_DIR, MGRIDGEN_LIB_DIR # -> HAVE_MGRIDGEN, MGRIDGEN_ARCH_PATH, MGRIDGEN_INC_DIR, MGRIDGEN_LIB_DIR
have_mgridgen() have_mgridgen()
{ {
local header library static label scalar settings warn good local prefix header library static settings warn
warn="==> skip mgridgen" warn="==> skip mgridgen"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/mgridgen) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/mgridgen)
#silent# [ -n "$warn" ] && echo "$warn (no config.sh/mgridgen settings)"
return 1
}
. $settings
if isNone "$MGRIDGEN_ARCH_PATH"
then then
#silent# [ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
#silent# [ -n "$warn" ] && echo "$warn (no config.sh/mgridgen settings)"
return 2
fi fi
# Location
prefix="$MGRIDGEN_ARCH_PATH"
# Header/library names # Header/library names
header="mgridgen.h" header="mgridgen.h"
library="libMGridGen$extLibso" library="libMGridGen$extLibso"
static="libmgrid$extLiba" static="libmgrid$extLiba"
# ----------------------------------
if hasAbsdir "$MGRIDGEN_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $MGRIDGEN_ARCH_PATH/include/$header) #silent# [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$MGRIDGEN_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$MGRIDGEN_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$MGRIDGEN_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$MGRIDGEN_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$MGRIDGEN_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -120,10 +114,11 @@ have_mgridgen()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
#silent# [ -n "$warn" ] && echo "$warn (missing library)" #silent# [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
local good label scalar
# Ensure consistent sizes with OpenFOAM and mgridgen header # Ensure consistent sizes with OpenFOAM and mgridgen header
# Extract typedef for idxtype, realtype # Extract typedef for idxtype, realtype
@ -134,20 +129,20 @@ have_mgridgen()
's/^.*typedef *\([^ ]*\) *realtype.*/\1/ip' \ 's/^.*typedef *\([^ ]*\) *realtype.*/\1/ip' \
"$header") "$header")
: ${label:=unknown} : "${label:=unknown}"
: ${scalar:=unknown} : "${scalar:=unknown}"
case "$WM_LABEL_SIZE:$label" in case "$WM_LABEL_SIZE:$label" in
(32:int32_t | 32:int | 64:int64_t | 64:long) (32:int32_t | 32:int | 64:int64_t | 64:long)
good=true good=true
;; ;;
*) (*)
if [ -n "$warn" ] if [ -n "$warn" ]
then then
echo "$warn (label='$WM_LABEL_SIZE', mgridgen.h has '$label')" echo "$warn (label='$WM_LABEL_SIZE', ${header##*/} has '$label')"
fi fi
no_mgridgen
return 1 return 1
;; ;;
esac esac
@ -156,21 +151,23 @@ have_mgridgen()
good=true good=true
;; ;;
*) (*)
if [ -n "$warn" ] if [ -n "$warn" ]
then then
echo "$warn (scalar='$WM_PRECISION_OPTION', mgridgen.h has '$scalar')" echo "$warn (scalar='$WM_PRECISION_OPTION', ${header##*/} has '$scalar')"
fi fi
no_mgridgen
return 1 return 1
;; ;;
esac esac
# OK # OK
echo "mgridgen (label=$label, scalar=$scalar) - $MGRIDGEN_ARCH_PATH" echo "mgridgen (label=$label, scalar=$scalar) - $prefix"
export HAVE_MGRIDGEN=true export HAVE_MGRIDGEN=true
export MGRIDGEN_ARCH_PATH MGRIDGEN_VERSION export MGRIDGEN_ARCH_PATH="$prefix"
export MGRIDGEN_INC_DIR="${header%/*}" # Basename export MGRIDGEN_INC_DIR="${header%/*}" # Basename
export MGRIDGEN_LIB_DIR="${library%/*}" # Basename export MGRIDGEN_LIB_DIR="${library%/*}" # Basename
export MGRIDGEN_VERSION
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,62 +54,56 @@ echo_petsc()
# -> HAVE_PETSC, PETSC_INC_DIR, PETSC_LIB_DIR # -> HAVE_PETSC, PETSC_INC_DIR, PETSC_LIB_DIR
have_petsc() have_petsc()
{ {
local header library static label settings warn local prefix header library static settings warn
warn="==> skip petsc" warn="==> skip petsc"
# Basic setup/checks. Prefer current environment value? (TDB) # Setup - prefer current environment value? (TDB)
if [ ! -d "$PETSC_ARCH_PATH" ] if [ ! -d "$PETSC_ARCH_PATH" ]
then then
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/petsc) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/petsc)
then
. "$settings"
else
[ -n "$warn" ] && echo "$warn (no config.sh/petsc settings)" [ -n "$warn" ] && echo "$warn (no config.sh/petsc settings)"
return 1 return 2
} fi
. $settings
fi
if isNone "$PETSC_ARCH_PATH"
then
[ -n "$warn" ] && echo "$warn (not available)"
return 1
fi fi
# Location
prefix="$PETSC_ARCH_PATH"
# Header/library names # Header/library names
header="petsc.h" header="petsc.h"
library="libpetsc$extLibso" library="libpetsc$extLibso"
# ----------------------------------
if hasAbsdir "$PETSC_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $PETSC_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$PETSC_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$PETSC_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$PETSC_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -119,12 +113,15 @@ have_petsc()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
# TODO: check size of petsc integer vs label
# OK
export HAVE_PETSC=true export HAVE_PETSC=true
export PETSC_ARCH_PATH export PETSC_ARCH_PATH="$prefix"
export PETSC_INC_DIR="${header%/*}" # Basename export PETSC_INC_DIR="${header%/*}" # Basename
export PETSC_LIB_DIR="${library%/*}" # Basename export PETSC_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -52,32 +52,43 @@ echo_readline()
# -> HAVE_LIBREADLINE, READLINE_INC_DIR, READLINE_LIB_DIR # -> HAVE_LIBREADLINE, READLINE_INC_DIR, READLINE_LIB_DIR
have_readline() have_readline()
{ {
local header library static settings warn local prefix header library static settings warn
# warn="==> skip readline" # warn="==> skip readline"
# Location
prefix=system
# Header/library names # Header/library names
header="readline/readline.h" header="readline/readline.h"
library="libreadline$extLibso" library="libreadline$extLibso"
# System only? # ----------------------------------
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) if isNone "$prefix"
then
[ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
case "$header" in
/usr/local/*)
library=$(findFirstFile \ library=$(findFirstFile \
/usr/local/lib/$library \ "$prefix/lib/$library" \
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
;; elif isSystem "$prefix"
then
prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
*)
library=$(findFirstFile \ library=$(findFirstFile \
/usr/lib/$library \ "$prefix/lib/$library" \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
;; else
esac unset prefix header library
fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -87,12 +98,13 @@ have_readline()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
header="${header%/*}" # Strip one-level (include/readline/...) header="${header%/*}" # Strip one-level (include/readline/...)
# OK
export HAVE_LIBREADLINE=true export HAVE_LIBREADLINE=true
export READLINE_INC_DIR="${header%/*}" # Basename export READLINE_INC_DIR="${header%/*}" # Basename
export READLINE_LIB_DIR="${library%/*}" # Basename export READLINE_LIB_DIR="${library%/*}" # Basename

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -55,67 +55,64 @@ echo_scotch()
# -> HAVE_SCOTCH, SCOTCH_ARCH_PATH, SCOTCH_INC_DIR, SCOTCH_LIB_DIR # -> HAVE_SCOTCH, SCOTCH_ARCH_PATH, SCOTCH_INC_DIR, SCOTCH_LIB_DIR
have_scotch() have_scotch()
{ {
local header library static label settings warn local prefix header library static settings warn
warn="==> skip scotch" warn="==> skip scotch"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/scotch) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/scotch)
[ -n "$warn" ] && echo "$warn (no config.sh/scotch settings)"
return 1
}
. $settings
if isNone "$SCOTCH_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
[ -n "$warn" ] && echo "$warn (no config.sh/scotch settings)"
return 2
fi fi
# Location
prefix="$SCOTCH_ARCH_PATH"
# Header/library names # Header/library names
header="scotch.h" header="scotch.h"
library="libscotch$extLibso" library="libscotch$extLibso"
static="libscotch$extLiba" static="libscotch$extLiba"
# ----------------------------------
if hasAbsdir "$SCOTCH_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $SCOTCH_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$SCOTCH_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$SCOTCH_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$SCOTCH_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$SCOTCH_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$SCOTCH_ARCH_PATH"
elif isSystem "$prefix"
then then
prefix=/usr
header=$(findFirstFile \ header=$(findFirstFile \
/usr/local/include/$header \ "/usr/local/include/scotch/$header" \
/usr/local/include/scotch/$header \ "/usr/local/include/$header" \
/usr/include/$header \ "/usr/include/scotch/$header" \
/usr/include/scotch/$header \ "/usr/include/$header" \
) )
case "$header" in case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
/usr/local/*)
library=$(findFirstFile \
/usr/local/lib/$library \
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*) library=$(findFirstFile \
library=$(findFirstFile \ "$prefix/lib/$library" \
/usr/lib/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \ )
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -125,17 +122,18 @@ have_scotch()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
local good label
# Ensure consistent sizes between OpenFOAM and scotch header # Ensure consistent sizes between OpenFOAM and scotch header
# extract 'typedef int64_t SCOTCH_Num' or equivalent # extract 'typedef int64_t SCOTCH_Num' or equivalent
label=$(sed -ne \ label=$(sed -ne \
's/^.*typedef *\([^ ]*\) *SCOTCH_Num.*/\1/p' \ 's/^.*typedef *\([^ ]*\) *SCOTCH_Num.*/\1/p' \
"$header") "$header")
: ${label:=unknown} # Failsafe value : "${label:=unknown}"
# No SCOTCH_VERSION set? Try to obtain from header # No SCOTCH_VERSION set? Try to obtain from header
@ -152,27 +150,30 @@ have_scotch()
IFS="." IFS="."
[ "$#" -gt 0 ] && echo "scotch-$*" [ "$#" -gt 0 ] && echo "scotch-$*"
) )
: ${SCOTCH_VERSION:=scotch} # Failsafe value : "${SCOTCH_VERSION:=scotch}" # Failsafe value
case "$WM_LABEL_SIZE:$label" in case "$WM_LABEL_SIZE:$label" in
(32:int32_t | 32:int | 64:int64_t | 64:long) (32:int32_t | 32:int | 64:int64_t | 64:long)
echo "Scotch (label=$label) - $SCOTCH_ARCH_PATH" good=true
export HAVE_SCOTCH=true
export SCOTCH_ARCH_PATH SCOTCH_VERSION
export SCOTCH_INC_DIR="${header%/*}" # Basename
export SCOTCH_LIB_DIR="${library%/*}" # Basename
;; ;;
*) (*)
if [ -n "$warn" ] if [ -n "$warn" ]
then then
echo "$warn (label='$WM_LABEL_SIZE', scotch.h has '$label')" echo "$warn (label='$WM_LABEL_SIZE', ${header##*/} has '$label')"
fi fi
no_scotch no_scotch
return 1 return 1
;; ;;
esac esac
# OK
echo "scotch (label=$label) - $prefix"
export HAVE_SCOTCH=true
export SCOTCH_ARCH_PATH="$prefix"
export SCOTCH_INC_DIR="${header%/*}" # Basename
export SCOTCH_LIB_DIR="${library%/*}" # Basename
export SCOTCH_VERSION
} }

View File

@ -2,7 +2,7 @@
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
# \\ / A nd | Copyright (C) 2018 OpenCFD Ltd. # \\ / A nd | Copyright (C) 2018-2019 OpenCFD Ltd.
# \\/ M anipulation | # \\/ M anipulation |
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# License # License
@ -54,62 +54,56 @@ echo_zoltan()
# -> HAVE_ZOLTAN, ZOLTAN_INC_DIR, ZOLTAN_LIB_DIR # -> HAVE_ZOLTAN, ZOLTAN_INC_DIR, ZOLTAN_LIB_DIR
have_zoltan() have_zoltan()
{ {
local header library static label settings warn local prefix header library static settings warn
# warn="==> skip zoltan" # warn="==> skip zoltan"
# Basic setup/checks # Setup
settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/zoltan) || { if settings=$($WM_PROJECT_DIR/bin/foamEtcFile config.sh/zoltan)
[ -n "$warn" ] && echo "$warn (no config.sh/zoltan settings)"
return 1
}
. $settings
if isNone "$ZOLTAN_ARCH_PATH"
then then
[ -n "$warn" ] && echo "$warn (not available)" . "$settings"
return 1 else
[ -n "$warn" ] && echo "$warn (no config.sh/zoltan settings)"
return 2
fi fi
# Location
prefix="$ZOLTAN_ARCH_PATH"
# Header/library names # Header/library names
header="zoltan.h" header="zoltan.h"
library="libzoltan$extLibso" library="libzoltan$extLibso"
static="libzoltan$extLiba" static="libzoltan$extLiba"
# ----------------------------------
if hasAbsdir "$ZOLTAN_ARCH_PATH" if isNone "$prefix"
then then
header=$(findFirstFile $ZOLTAN_ARCH_PATH/include/$header) [ -n "$warn" ] && echo "$warn (disabled)"
return 1
elif hasAbsdir "$prefix"
then
header=$(findFirstFile "$prefix/include/$header")
library=$(findFirstFile \ library=$(findFirstFile \
"$(thirdExtLib $library)" \ "$(thirdExtLib $library)" \
$ZOLTAN_ARCH_PATH/lib/$static \ "$prefix/lib/$static" \
$ZOLTAN_ARCH_PATH/lib/$library \ "$prefix/lib/$library" \
$ZOLTAN_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$static \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$static" \
$ZOLTAN_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH/$library \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
) )
elif isSystem "$ZOLTAN_ARCH_PATH" elif isSystem "$prefix"
then then
header=$(findFirstFile /usr/local/include/$header /usr/include/$header) prefix=/usr
header=$(findFirstFile "/usr/local/include/$header" "/usr/include/$header")
case "$header" in (/usr/local/*) prefix=/usr/local ;; esac
case "$header" in library=$(findFirstFile \
/usr/local/*) "$prefix/lib/$library" \
library=$(findFirstFile \ "$prefix/lib$WM_COMPILER_LIB_ARCH/$library" \
/usr/local/lib/$library \ )
/usr/local/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
*)
library=$(findFirstFile \
/usr/lib/$library \
/usr/lib$WM_COMPILER_LIB_ARCH/$library \
)
;;
esac
else else
unset header library unset prefix header library
fi fi
# ----------------------------------
# Header found? # Header found?
[ -n "$header" ] || { [ -n "$header" ] || {
@ -119,12 +113,13 @@ have_zoltan()
# Library found? # Library found?
[ -n "$library" ] || { [ -n "$library" ] || {
[ -n "$warn" ] && echo "$warn (missing library)" [ -n "$warn" ] && echo "$warn (no library)"
return 2 return 2
} }
# OK
export HAVE_ZOLTAN=true export HAVE_ZOLTAN=true
export ZOLTAN_ARCH_PATH export ZOLTAN_ARCH_PATH="$prefix"
export ZOLTAN_INC_DIR="${header%/*}" # Basename export ZOLTAN_INC_DIR="${header%/*}" # Basename
export ZOLTAN_LIB_DIR="${library%/*}" # Basename export ZOLTAN_LIB_DIR="${library%/*}" # Basename
} }

View File

@ -180,6 +180,7 @@ have_pvplugin_support()
return 2 return 2
} }
# OK
export HAVE_PVPLUGIN_SUPPORT=true export HAVE_PVPLUGIN_SUPPORT=true
export FOAM_PV_PLUGIN_LIBBIN="$targetDir" export FOAM_PV_PLUGIN_LIBBIN="$targetDir"
export PARAVIEW_API="$pv_api" export PARAVIEW_API="$pv_api"

View File

@ -71,16 +71,16 @@ then
} }
# True if '$1' is an empty string or matches "*-none". # True if '$1' is an empty string, "none" or ends in "-none"
# Eg, # Eg,
# if isNone "$KAHIP_ARCH_PATH" ... # if isNone "$BOOST_ARCH_PATH" ...
isNone() isNone()
{ {
test -z "$1" -o "${1##*-}" = none test -z "$1" -o "${1##*-}" = none
} }
# True if '$1' matches "*-system" # True if '$1' is "system" or ends in "-system"
# Eg, # Eg,
# if isSystem "$BOOST_ARCH_PATH" # if isSystem "$BOOST_ARCH_PATH"
isSystem() isSystem()