Merge branch 'develop' of develop.openfoam.com:Development/OpenFOAM-plus into develop

This commit is contained in:
Andrew Heather
2016-12-18 21:54:38 +00:00
9 changed files with 364 additions and 60 deletions

View File

@ -1,5 +1,5 @@
#!/bin/sh #!/bin/sh
#---------------------------------*- sh -*------------------------------------- #------------------------------------------------------------------------------
# ========= | # ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox # \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration | # \\ / O peration |
@ -26,7 +26,7 @@
# foamConfigurePaths # foamConfigurePaths
# #
# Description # Description
# Adjust hardcoded installation paths and versions # Adjust hardcoded versions and installation paths (for bash, POSIX shell).
# #
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
usage() { usage() {
@ -35,47 +35,93 @@ usage() {
cat<<USAGE cat<<USAGE
usage: ${0##*/} usage: ${0##*/}
-foamInstall dir specify installation directory (e.g. /opt) -foamInstall dir specify installation directory (eg, /opt)
-projectName name specify project name (e.g. openfoam220) -foamVersion ver specify project version (eg, 1612)
-projectVersion ver specify project version (e.g. 2.2.0) -projectName name specify project directory name (eg, openfoam1612)
-archOption 32|64 specify architecture option -archOption 32|64 specify 'WM_ARCH_OPTION' architecture option
-label 32|64 specify label size -int32 | -int64 specify 'WM_LABEL_SIZE'
-SP | -DP specify 'WM_PRECISION_OPTION'
-system name specify 'system' compiler to be used -system name specify 'system' compiler to be used
-thirdParty name specify 'ThirdParty' compiler to be used -third name specify 'ThirdParty' compiler to be used
-boost ver specify 'boost_version'
-boost-path dir specify 'BOOST_ARCH_PATH'
-cgal ver specify 'cgal_version'
-cgal-path dir specify 'CGAL_ARCH_PATH'
-clang ver specify 'clang_version' for ThirdParty Clang
-cmake ver specify 'cmake_version'
-fftw ver specify 'fffw_version'
-fftw-path dir specify 'FFTW_ARCH_PATH'
-metis ver specify 'METIS_VERSION'
-metis-path dir specify 'METIS_ARCH_PATH'
-paraview ver specify 'ParaView_VERSION' (eg, 5.0.1)
-paraview-path dir specify 'ParaView_DIR' (eg, /opt/paraviewopenfoam3120)
-openmpi ver specify ThirdParty openmpi version for 'FOAM_MPI'
-openmpi-system activate system openmpi
-openmpi-third activate ThirdParty openmpi (using default version)
-scotch ver specify 'SCOTCH_VERSION' (eg, scotch_6.0.4)
-scotch-path dir specify 'SCOTCH_ARCH_PATH' (eg, /opt/OpenFOAM-scotch_6.0.4)
-vtk ver specify 'vtk_version' (eg, VTK-7.1.0)
-mesa ver specify 'mesa_version' (eg, mesa-13.0.1)
-sigfpe | -no-sigfpe activate/deactivate FOAM_SIGFPE handling
gmp-VERSION for ThirdParty gcc (gmp-system for system library)
mpfr-VERSION for ThirdParty gcc (mpfr-system for system library)
mpc-VERSION for ThirdParty gcc (mpc-system for system library)
-boost ver specify boost_version * Adjust hardcoded versions and installation paths (for bash, POSIX shell).
-boostArchPath dir specify BOOST_ARCH_PATH
-cgal ver specify cgal_version
-cgalArchPath dir specify CGAL_ARCH_PATH
-clang ver specify clang_version for ThirdParty Clang
-cmake ver specify cmake_version
-fftw ver specify fffw_version
-fftwArchPath dir specify FFTW_ARCH_PATH
-metis ver specify METIS_VERSION
-metisArchPath dir specify METIS_ARCH_PATH
-paraview ver specify ParaView_VERSION (e.g. 3.12.0)
-paraviewInstall dir specify ParaView_DIR (e.g. /opt/paraviewopenfoam3120)
-scotch ver specify SCOTCH_VERSION (e.g. 6.0.0)
-scotchArchPath dir specify SCOTCH_ARCH_PATH (e.g. /opt/OpenFOAM-scotch-6.0.0/)
* Adjust hardcoded installation paths and versions Equivalent options:
-foamInstall --foamInstall
-foamVersion --projectVersion
-projectName --projectName
-archOption --archOption
-third -ThirdParty
-paraview --paraviewVersion | -paraviewVersion
-paraview-path --paraviewInstall | -paraviewInstall
-scotch --scotchVersion | -scotchVersion
-scotch-path --scotchArchPath | -scotchArchPath
USAGE USAGE
exit 1 exit 1
} }
# Check that it appears to be an OpenFOAM installation
[ -f etc/bashrc -a -d etc/config.sh ] || \
usage "Please run from top-level directory of installation"
# Report error and exit # Report error and exit
die() die()
{ {
exec 1>&2 exec 1>&2
echo echo
echo "Error: see '${0##*/} -help' for usage" echo "Error encountered:"
while [ "$#" -ge 1 ]; do echo " $1"; shift; done while [ "$#" -ge 1 ]; do echo " $1"; shift; done
echo echo
echo "See '${0##*/} -help' for usage"
echo
exit 1 exit 1
} }
# Check if argument matches the expected input. Respects case.
# Uses sed for consistency with the replacement routines.
#
# _matches <arg> <matcher> [... <matcherN>]
#
_matches()
{
local input="$1"
shift
local result
for regexp
do
result=$(echo "$input" | sed -n -e "/^$regexp"'$/p')
test -n "$result" && return 0 # successful match
done
return 1
}
# Function to do replacement on file. Checks if any replacement has been done. # Function to do replacement on file. Checks if any replacement has been done.
# _inlineSed <file> <regexp> <replacement> <msg> # _inlineSed <file> <regexp> <replacement> <msg>
_inlineSed() _inlineSed()
@ -96,7 +142,7 @@ _inlineSed()
return 1 return 1
} }
echo "Okay: $msg in $file" echo " $msg ($file)"
return 0 return 0
} }
@ -122,16 +168,13 @@ replace()
$file \ $file \
"$key=.*" \ "$key=.*" \
"$key=$val" \ "$key=$val" \
"Replacing $key setting by '$val'" "Replaced $key setting by '$val'"
done done
} }
[ -f etc/bashrc ] || usage "Please run from top-level directory of installation"
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
unset adjusted unset adjusted optMpi
# Parse options # Parse options
while [ "$#" -gt 0 ] while [ "$#" -gt 0 ]
do do
@ -139,6 +182,9 @@ do
-h | -help | --help) -h | -help | --help)
usage usage
;; ;;
'')
# Discard empty arguments
;;
-foamInstall | --foamInstall) -foamInstall | --foamInstall)
# Replace FOAM_INST_DIR=... # Replace FOAM_INST_DIR=...
@ -148,7 +194,7 @@ do
etc/bashrc \ etc/bashrc \
'\(.*BASH_SOURCE.*\)' \ '\(.*BASH_SOURCE.*\)' \
'##\1' \ '##\1' \
"Removing default FOAM_INST_DIR setting" "Removed default FOAM_INST_DIR setting"
_inlineSed \ _inlineSed \
etc/bashrc \ etc/bashrc \
'^ *FOAM_INST_DIR=.*' \ '^ *FOAM_INST_DIR=.*' \
@ -167,13 +213,13 @@ do
etc/bashrc \ etc/bashrc \
'WM_PROJECT_DIR=.*' \ 'WM_PROJECT_DIR=.*' \
'WM_PROJECT_DIR=$WM_PROJECT_INST_DIR/'"$projectName" \ 'WM_PROJECT_DIR=$WM_PROJECT_INST_DIR/'"$projectName" \
"Replacing WM_PROJECT_DIR setting by $projectName" "Replaced WM_PROJECT_DIR setting by $projectName"
adjusted=true adjusted=true
shift shift
;; ;;
-projectVersion | --projectVersion) -foamVersion | --projectVersion)
# Replace WM_PROJECT_VERSION=... # Replace WM_PROJECT_VERSION=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/bashrc WM_PROJECT_VERSION "$2" replace etc/bashrc WM_PROJECT_VERSION "$2"
@ -184,24 +230,32 @@ do
-archOption | --archOption) -archOption | --archOption)
# Replace WM_ARCH_OPTION=... # Replace WM_ARCH_OPTION=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
archOption="$2" _matches "$2" 32 64 || die "'$1' option has bad value: '$2'"
current="$(sed -ne '/^[^#]/s/^.* WM_ARCH_OPTION=//p' etc/bashrc)"
if [ "$archOption" = "$current" ] optionValue="$2"
if [ "$optionValue" = "$(sed -ne '/^[^#]/s/^.* WM_ARCH_OPTION=//p' etc/bashrc)" ]
then then
echo "WM_ARCH_OPTION already set to $archOption" echo "WM_ARCH_OPTION already set to $optionValue"
: ${adjusted:=false}
else else
replace etc/bashrc WM_ARCH_OPTION "$2" replace etc/bashrc WM_ARCH_OPTION "$optionValue"
adjusted=true
fi fi
adjusted=true
shift shift
;; ;;
-label) -int32 | -int64)
# Replace WM_LABEL_SIZE=... # Replace WM_LABEL_SIZE=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" optionValue="${1#-int}"
replace etc/bashrc WM_LABEL_SIZE "$2" replace etc/bashrc WM_LABEL_SIZE "$optionValue"
adjusted=true
;;
-SP | -DP)
# Replace WM_PRECISION_OPTION=...
optionValue="${1#-}"
replace etc/bashrc WM_PRECISION_OPTION "$optionValue"
adjusted=true adjusted=true
shift
;; ;;
-system) -system)
@ -212,7 +266,7 @@ do
shift shift
;; ;;
-third[Pp]arty) -third | -ThirdParty)
# Replace WM_COMPILER_TYPE=... and WM_COMPILER=... # Replace WM_COMPILER_TYPE=... and WM_COMPILER=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/bashrc WM_COMPILER_TYPE ThirdParty WM_COMPILER "$2" replace etc/bashrc WM_COMPILER_TYPE ThirdParty WM_COMPILER "$2"
@ -220,7 +274,6 @@ do
shift shift
;; ;;
-boost) -boost)
# Replace boost_version=... # Replace boost_version=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
@ -229,7 +282,7 @@ do
shift shift
;; ;;
-boostArchPath) -boost-path)
# Replace BOOST_ARCH_PATH=... # Replace BOOST_ARCH_PATH=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/CGAL BOOST_ARCH_PATH "$2" replace etc/config.sh/CGAL BOOST_ARCH_PATH "$2"
@ -245,7 +298,7 @@ do
shift shift
;; ;;
-cgalArchPath) -cgal-path)
# Replace CGAL_ARCH_PATH=... # Replace CGAL_ARCH_PATH=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/CGAL CGAL_ARCH_PATH "$2" replace etc/config.sh/CGAL CGAL_ARCH_PATH "$2"
@ -261,7 +314,7 @@ do
shift shift
;; ;;
-fftwArchPath) -fftw-path)
# Replace FFTW_ARCH_PATH=... # Replace FFTW_ARCH_PATH=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/FFTW FFTW_ARCH_PATH "$2" replace etc/config.sh/FFTW FFTW_ARCH_PATH "$2"
@ -285,15 +338,50 @@ do
shift shift
;; ;;
-openmpi)
# Replace FOAM_MPI=openmpi-<digits>.. and set to use third-party
# The edit is slightly fragile, but works
expected="openmpi-[1-9][.0-9]*"
[ "$#" -ge 2 ] || die "'$1' option requires an argument"
optMpi="$2"
_matches "$optMpi" "$expected" || die "'$1' option has bad value: '$optMpi'"
_inlineSed etc/config.sh/mpi \
"FOAM_MPI=$expected" \
"FOAM_MPI=$optMpi" \
"Replaced 'FOAM_MPI=$expected' setting by 'FOAM_MPI=$optMpi'"
replace etc/bashrc WM_MPLIB OPENMPI
adjusted=true
shift
;;
-openmpi-system)
# Explicitly set WM_MPLIB=SYSTEMOPENMPI
replace etc/bashrc WM_MPLIB SYSTEMOPENMPI
optMpi=system
adjusted=true
;;
-openmpi-third)
# Explicitly set WM_MPLIB=OPENMPI, using default setting for openmpi
replace etc/bashrc WM_MPLIB OPENMPI
optMpi=third
adjusted=true
;;
-paraview | -paraviewVersion | --paraviewVersion) -paraview | -paraviewVersion | --paraviewVersion)
# Replace ParaView_VERSION=... # Replace ParaView_VERSION=...
expected="[5-9][.0-9]*"
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
_matches "$2" "$expected" || die "'$1' option has bad value: '$2'"
replace etc/config.sh/paraview ParaView_VERSION "$2" replace etc/config.sh/paraview ParaView_VERSION "$2"
adjusted=true adjusted=true
shift shift
;; ;;
-paraviewInstall | --paraviewInstall) -paraview-path | -paraviewInstall | --paraviewInstall)
# Replace ParaView_DIR=... # Replace ParaView_DIR=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/paraview ParaView_DIR "$2" replace etc/config.sh/paraview ParaView_DIR "$2"
@ -309,7 +397,7 @@ do
shift shift
;; ;;
-metisArchPath) -metis-path)
# Replace METIS_ARCH_PATH=... # Replace METIS_ARCH_PATH=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/metis METIS_ARCH_PATH "$2" replace etc/config.sh/metis METIS_ARCH_PATH "$2"
@ -325,7 +413,7 @@ do
shift shift
;; ;;
-scotchArchPath | --scotchArchPath) -scotch-path | -scotchArchPath | --scotchArchPath)
# Replace SCOTCH_ARCH_PATH=... # Replace SCOTCH_ARCH_PATH=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument" [ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/scotch SCOTCH_ARCH_PATH "$2" replace etc/config.sh/scotch SCOTCH_ARCH_PATH "$2"
@ -333,6 +421,56 @@ do
shift shift
;; ;;
-vtk)
# Replace vtk_version=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/vtk vtk_version "$2"
adjusted=true
shift
;;
-mesa)
# Replace mesa_version=...
[ "$#" -ge 2 ] || die "'$1' option requires an argument"
replace etc/config.sh/vtk mesa_version "$2"
adjusted=true
shift
;;
gmp-[4-9]* | gmp-system)
# gcc-related package
replace etc/config.sh/compiler gmp_version "$1"
adjusted=true
;;
mpfr-[2-9]* | mpfr-system)
# gcc-related package
replace etc/config.sh/compiler mpfr_version "$1"
adjusted=true
;;
mpc-[0-9]* | mpc-system)
# gcc-related package
replace etc/config.sh/compiler mpc_version "$1"
adjusted=true
;;
-sigfpe)
# Enable FOAM_SIGFPE handling
_inlineSed etc/bashrc \
"[a-z][a-z]* FOAM_SIGFPE.*" \
"export FOAM_SIGFPE=" \
"Activate FOAM_SIGFPE handling"
;;
-no-sigfpe)
# Disable FOAM_SIGFPE handling
_inlineSed etc/bashrc \
"[a-z][a-z]* FOAM_SIGFPE.*" \
"unset FOAM_SIGFPE" \
"Deactivate FOAM_SIGFPE handling"
;;
*) *)
die "unknown option/argument: '$1'" die "unknown option/argument: '$1'"
;; ;;
@ -340,12 +478,13 @@ do
shift shift
done done
[ -n "$adjusted" ] || die "Please specify at least one configure option" if [ "$adjusted" = false ]
then
# Set WM_MPLIB=SYSTEMOPENMPI always echo "Nothing adjusted"
replace etc/bashrc WM_MPLIB SYSTEMOPENMPI exit 0
elif [ -z "$adjusted" ]
## Set WM_COMPILER_TYPE=system always then
# replace etc/bashrc WM_COMPILER_TYPE system die "Please specify at least one configure option"
fi
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------

View File

@ -170,6 +170,7 @@ _foamSource $WM_PROJECT_DIR/etc/config.sh/aliases
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/mpi` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/mpi`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/paraview` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/paraview`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/vtk`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/ensight` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/ensight`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/gperftools` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.sh/gperftools`

View File

@ -124,6 +124,7 @@ unsetenv ParaView_INCLUDE_DIR
unsetenv ParaView_MAJOR unsetenv ParaView_MAJOR
unsetenv ParaView_VERSION unsetenv ParaView_VERSION
unsetenv PV_PLUGIN_PATH unsetenv PV_PLUGIN_PATH
unsetenv VTK_DIR
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# unset other ThirdParty environment variables # unset other ThirdParty environment variables
@ -136,6 +137,7 @@ unsetenv FFTW_ARCH_PATH
unsetenv GPERFTOOLS_ARCH_PATH unsetenv GPERFTOOLS_ARCH_PATH
unsetenv GMP_ARCH_PATH unsetenv GMP_ARCH_PATH
unsetenv MPFR_ARCH_PATH unsetenv MPFR_ARCH_PATH
unsetenv MESA_ARCH_PATH
unsetenv METIS_ARCH_PATH unsetenv METIS_ARCH_PATH
unsetenv SCOTCH_ARCH_PATH unsetenv SCOTCH_ARCH_PATH

67
etc/config.csh/vtk Normal file
View File

@ -0,0 +1,67 @@
#----------------------------------*-sh-*--------------------------------------
# ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration |
# \\ / A nd | Copyright (C) 2016 OpenCFD Ltd.
# \\/ M anipulation |
#------------------------------------------------------------------------------
# License
# This file is part of OpenFOAM.
#
# OpenFOAM is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# for more details.
#
# You should have received a copy of the GNU General Public License
# along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
#
# File
# etc/config.csh/vtk
#
# Description
# Setup file for VTK (and MESA)
# Sourced from OpenFOAM-<VERSION>/etc/cshrc
#
# The library path is not adjusted with the paths specified here do not exist
#
# Note
# When building OpenFOAM, any changes made here MUST be made in the
# equivalent config.sh version too, since that is the one which will
# be used during the build process.
#
#------------------------------------------------------------------------------
set vtk_version=VTK-7.1.0
set mesa_version=mesa-13.0.1
setenv VTK_DIR $WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$vtk_version
setenv MESA_ARCH_PATH $WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$mesa_version
#------------------------------------------------------------------------------
if ($?FOAM_VERBOSE && $?prompt) then
echo "Using vtk ($vtk_version) -> $VTK_ARCH_PATH"
echo "Using mesa ($mesa_version) -> $MESA_ARCH_PATH"
endif
# Set paths if binaries are present
if ( -r $VTK_DIR ) then
_foamAddLib $VTK_DIR/lib$WM_COMPILER_LIB_ARCH
else
unset VTK_DIR
endif
if ( -r $MESA_ARCH_PATH ) then
_foamAddLib $MESA_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH
else
unset MESA_ARCH_PATH
endif
unset vtk_version mesa_version
#------------------------------------------------------------------------------

View File

@ -119,7 +119,7 @@ then
export ParaView_DIR=$WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$pvName export ParaView_DIR=$WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$pvName
# Set paths if binaries or source are present # Set paths if binaries are present
if [ -r $ParaView_DIR ] if [ -r $ParaView_DIR ]
then then
pvLibDir=$ParaView_DIR/lib/$pvMajor pvLibDir=$ParaView_DIR/lib/$pvMajor

View File

@ -120,6 +120,7 @@ unset ParaView_INCLUDE_DIR
unset ParaView_MAJOR unset ParaView_MAJOR
unset ParaView_VERSION unset ParaView_VERSION
unset PV_PLUGIN_PATH unset PV_PLUGIN_PATH
unset VTK_DIR
#------------------------------------------------------------------------------ #------------------------------------------------------------------------------
# unset other ThirdParty environment variables # unset other ThirdParty environment variables
@ -132,6 +133,7 @@ unset FFTW_ARCH_PATH
unset GPERFTOOLS_ARCH_PATH unset GPERFTOOLS_ARCH_PATH
unset GMP_ARCH_PATH unset GMP_ARCH_PATH
unset MPFR_ARCH_PATH unset MPFR_ARCH_PATH
unset MESA_ARCH_PATH
unset METIS_ARCH_PATH unset METIS_ARCH_PATH
unset SCOTCH_ARCH_PATH unset SCOTCH_ARCH_PATH

72
etc/config.sh/vtk Normal file
View File

@ -0,0 +1,72 @@
#----------------------------------*-sh-*--------------------------------------
# ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration |
# \\ / A nd | Copyright (C) 2016 OpenCFD Ltd.
# \\/ M anipulation |
#------------------------------------------------------------------------------
# License
# This file is part of OpenFOAM.
#
# OpenFOAM is free software: you can redistribute it and/or modify it
# under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# OpenFOAM is distributed in the hope that it will be useful, but WITHOUT
# ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
# FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
# for more details.
#
# You should have received a copy of the GNU General Public License
# along with OpenFOAM. If not, see <http://www.gnu.org/licenses/>.
#
# File
# etc/config.sh/vtk
#
# Description
# Setup file for VTK (and MESA)
# Sourced from OpenFOAM-<VERSION>/etc/bashrc
#
# The library path is not adjusted with the paths specified here do not exist
#
# Note
# When _foamAddLib is unset
# - the vtk_version, mesa_version variables are retained.
#------------------------------------------------------------------------------
vtk_version=VTK-7.1.0
mesa_version=mesa-13.0.1
export VTK_DIR=$WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$vtk_version
export MESA_ARCH_PATH=$WM_THIRD_PARTY_DIR/platforms/$WM_ARCH$WM_COMPILER/$mesa_version
#------------------------------------------------------------------------------
if [ "$FOAM_VERBOSE" -a "$PS1" ]
then
echo "Using vtk ($vtk_version) -> $VTK_ARCH_PATH" 1>&2
echo "Using mesa ($mesa_version) -> $MESA_ARCH_PATH" 1>&2
fi
if type _foamAddLib > /dev/null 2>&1 # normal sourcing
then
# Set paths if binaries are present
if [ -r $VTK_DIR ]
then
_foamAddLib $VTK_DIR/lib$WM_COMPILER_LIB_ARCH
else
unset VTK_DIR
fi
if [ -r $MESA_ARCH_PATH ]
then
_foamAddLib $MESA_ARCH_PATH/lib$WM_COMPILER_LIB_ARCH
else
unset MESA_ARCH_PATH
fi
unset vtk_version mesa_version
fi
#------------------------------------------------------------------------------

View File

@ -215,6 +215,7 @@ _foamSource $WM_PROJECT_DIR/etc/config.csh/aliases
# ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ # ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/mpi` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/mpi`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/paraview` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/paraview`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/vtk`
_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/ensight` _foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/ensight`
##_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/ADIOS` ##_foamSource `$WM_PROJECT_DIR/bin/foamEtcFile config.csh/ADIOS`

View File

@ -3,7 +3,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) 2011-2016 OpenFOAM Foundation \\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
\\/ M anipulation | \\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
------------------------------------------------------------------------------- -------------------------------------------------------------------------------
License License
This file is part of OpenFOAM. This file is part of OpenFOAM.
@ -29,11 +29,30 @@ Description
#include "IOobject.H" #include "IOobject.H"
#include "objectRegistry.H" #include "objectRegistry.H"
#include "endian.H"
#include "label.H"
#include "scalar.H"
// * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * // // * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * //
bool Foam::IOobject::writeHeader(Ostream& os, const word& type) const bool Foam::IOobject::writeHeader(Ostream& os, const word& type) const
{ {
static std::string archHint;
// Hint about machine endian, OpenFOAM label and scalar sizes
if (archHint.empty())
{
#ifdef WM_LITTLE_ENDIAN
archHint.append("LSB;");
#elif defined (WM_BIG_ENDIAN)
archHint.append("MSB;");
#endif
archHint.append("label=");
archHint.append(std::to_string(8*sizeof(label)));
archHint.append(";scalar=");
archHint.append(std::to_string(8*sizeof(scalar)));
}
if (!os.good()) if (!os.good())
{ {
InfoInFunction InfoInFunction
@ -47,6 +66,7 @@ bool Foam::IOobject::writeHeader(Ostream& os, const word& type) const
<< "FoamFile\n{\n" << "FoamFile\n{\n"
<< " version " << os.version() << ";\n" << " version " << os.version() << ";\n"
<< " format " << os.format() << ";\n" << " format " << os.format() << ";\n"
<< " arch " << archHint << ";\n"
<< " class " << type << ";\n"; << " class " << type << ";\n";
if (note().size()) if (note().size())