Newer
Older
#!/bin/sh
#------------------------------------------------------------------------------
# ========= |
# \\ / F ield | OpenFOAM: The Open Source CFD Toolbox
# \\ / O peration |
# \\ / A nd | Copyright (C) 2011-2016 OpenFOAM Foundation
Mark Olesen
committed
# \\/ M anipulation | Copyright (C) 2016 OpenCFD Ltd.
#-------------------------------------------------------------------------------
# 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/>.
#
# Script
# paraFoam
#
# Description
# start paraview with the OpenFOAM libraries
#
# combining -block or -builtin options with the -region option yields
# undefined behaviour
#------------------------------------------------------------------------------
usage() {
while [ "$#" -ge 1 ]; do echo "$1"; shift; done
cat<<USAGE
Usage: ${0##*/} [OPTION] [PARAVIEW_OPTION]
-block use blockMesh reader (uses .blockMesh extension)
-case <dir> specify alternative case directory, default is the cwd
-region <name> specify alternative mesh region
-touch only create the file (eg, .blockMesh, .OpenFOAM, etc)
-touchAll create .blockMesh, .OpenFOAM files (and for all regions)
Mark Olesen
committed
-vtk | -builtin use VTK builtin OpenFOAM reader (uses .foam extension)
-help print the usage
Mark Olesen
committed
Paraview options start with a double dashes.
Mark Olesen
committed
* start paraview with the OpenFOAM libraries
Mark Olesen
committed
paraview=$(command -v paraview)
# We want to do nice exit when running paraview to give paraview opportunity
# to clean up
unset FOAM_ABORT
unset regionName optTouch
# Hack: change all locale to 'C' i.e. using '.' for decimal point. This is
# only needed temporarily until paraview is locale aware. (git version is
# already 2010-07)
export LC_ALL=C
Mark Olesen
committed
# Reader extension and plugin
extension=OpenFOAM
Mark Olesen
committed
plugin=PVFoamReader
# Parse options
case "$1" in
-h | -help)
usage
;;
extension=blockMesh
Mark Olesen
committed
plugin=PVblockMeshReader
shift
;;
Mark Olesen
committed
-builtin | -vtk)
extension=foam
Mark Olesen
committed
unset plugin
-case)
[ "$#" -ge 2 ] || usage "'$1' option requires an argument"
cd "$2" 2>/dev/null || usage "directory does not exist: '$2'"
shift 2
;;
-region)
[ "$#" -ge 2 ] || usage "'$1' option requires an argument"
regionName=$2
shift 2
;;
-touch)
optTouch=true
Mark Olesen
committed
unset plugin
shift
;;
-touchAll)
optTouch=all
Mark Olesen
committed
unset plugin
shift
;;
--)
break # Stop here, treat balance as paraview options
;;
--*)
break # Stop here, treat this and balance as paraview options
Mark Olesen
committed
usage "unknown option/argument: '$1'"
Mark Olesen
committed
# If a reader module is needed, check that it exists
[ -z "$plugin" -o -f $PV_PLUGIN_PATH/lib${plugin}_SM.so ] || {
cat<< BUILDREADER 1>&2
Mark Olesen
committed
ERROR: ParaView reader module library ($plugin) does not exist
Please build the reader module before continuing:
Mark Olesen
committed
cd \$FOAM_UTILITIES/postProcessing/graphics/PVReaders
./Allwclean
./Allwmake
Mark Olesen
committed
# Fallback to native reader, if possible
if [ "$extension" = OpenFOAM ]
then
extension=foam
echo "Using the native VTK/OpenFOAM reader instead" 1>&2
else
exit 1
fi
}
# Check for --data=... argument
hasDataArg()
{
hasData=false
while [ "$#" -gt 0 ]
do
case "$1" in
(--data=*)
hasData=true
break
;;
esac
shift
done
}
hasDataArg $@
# Get a sensible caseName from the directory name
caseFile="$caseName.$extension"
fvControls="system"
if [ ! -d constant/$regionName ]
then
Mark Olesen
committed
echo "FATAL ERROR: Region $regionName does not exist" 1>&2
exit 1
else
caseFile="$caseName{$regionName}.$extension"
fvControls="$fvControls/$regionName"
fi
case "${optTouch:-false}" in
all)
extension=OpenFOAM
if [ -f system/blockMeshDict -o -f constant/polyMesh/blockMeshDict ]
then
touch "$caseName.blockMesh"
Mark Olesen
committed
echo "Created '$caseName.blockMesh'" 1>&2
fi
touch "$caseName.$extension"
Mark Olesen
committed
echo "Created '$caseName.$extension'" 1>&2
# Discover probable regions
for region in constant/*
do
if [ -d $region -a -d $region/polyMesh ]
then
regionName=${region##*/}
touch "$caseName{$regionName}.$extension"
Mark Olesen
committed
echo "Created '$caseName{$regionName}.$extension'" 1>&2
fi
done
exit 0
;;
true)
touch "$caseFile"
Mark Olesen
committed
echo "Created '$caseFile'" 1>&2
# Parent directory for normal or parallel results
processor*) parentDir=".." ;;
*) parentDir="." ;;
if [ "${hasData:-false}" = true ]
then
# Has --data=.., send directly to paraview
exec paraview "$@"
else
# Check existence of essential files
warn="WARN file does not exist:"
case $extension in
blockMesh)
Mark Olesen
committed
blockMeshDict=system/blockMeshDict
if [ -f constant/polyMesh/blockMeshDict ]
then
Mark Olesen
committed
blockMeshDict=constant/polyMesh/blockMeshDict
fi
for check in \
system/controlDict \
Mark Olesen
committed
$blockMeshDict \
;
do
[ -s "$parentDir/$check" ] || {
[ -n "$warn" ] && echo "$warn" 1>&2
echo " $parentDir/$check" 1>&2
unset warn
}
done
;;
Mark Olesen
committed
OpenFOAM)
for check in \
system/controlDict \
$fvControls/fvSchemes \
$fvControls/fvSolution \
;
do
[ -s "$parentDir/$check" ] || {
[ -n "$warn" ] && echo "$warn" 1>&2
echo " $parentDir/$check" 1>&2
unset warn
}
done
;;
[ -n "$warn" ] || {
echo "Cannot locate OpenFOAM-format case files"
echo -n "Would you like to open ParaView anyway <Y|n>:"
read open
[ "$open" = "" ] || echo $open | grep -iqE "^y" && paraview
exit
}
# Only create/remove caseFile if it didn't already exist
[ -e $caseFile ] || {
trap "rm -f $caseFile 2>/dev/null; exit 0" EXIT TERM INT
touch "$caseFile"
Mark Olesen
committed
echo "Created temporary '$caseFile'" 1>&2
# For now filter out any ld.so errors. Caused by non-system compiler?
paraview --data="$caseFile" "$@" 2>&1 \
| fgrep -v 'Inconsistency detected by ld.so'
#------------------------------------------------------------------------------