Skip to content
Snippets Groups Projects
paraFoam 3.07 KiB
Newer Older
#!/bin/sh
#------------------------------------------------------------------------------
# =========                 |
# \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
#  \\    /   O peration     |
#   \\  /    A nd           | Copyright (C) 1991-2007 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 2 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, write to the Free Software Foundation,
#     Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
#
# Script
#     paraFoam
#
# Description
#     start paraview with the OpenFOAM libraries
#
#------------------------------------------------------------------------------
Script=${0##*/}

usage() {
    while [ "$#" -ge 1 ]; do echo "$1"; shift; done
    cat<<USAGE

usage: $Script [-case dir]

* start paraview $ParaView_VERSION with the OpenFOAM libraries

USAGE
    exit 1
}

# parse options
if [ "$#" -gt 0 ]; then
    case "$1" in
    -h | -help)
        usage
        ;;
    -case)
        shift
        caseDir=$1
        [ "$#" -ge 1 ] || usage "'-case' option requires an argument"
        cd "$caseDir" 2>/dev/null || usage "directory does not exist:  '$caseDir'"
        ;;
    *)
        usage "unknown option/argument: '$*'"
        ;;
    esac
fi

# get a sensible caseName
caseName=${PWD##*/}

# parent directory for normal or parallel results
case "$caseName" in
    processor*) parentDir=".." ;;
    *)          parentDir="."  ;;
esac

# check existence of essential files
for check in system/controlDict system/fvSchemes system/fvSolution
do
    [ -s "$parentDir/$check" ] || usage "file does not exist:  '$parentDir/$check'"
done

OpenFoamExt="foam"
# OpenFoamExt="OpenFOAM"

if [ "$ParaView_VERSION" = "3" ]; then

    # check existence of essential files
    for check in system/controlDict system/fvSchemes system/fvSolution
    do
        [ -s "$parentDir/$check" ] || usage "file does not exist:  '$parentDir/$check'"
    done

    touch $caseName.$OpenFoamExt
    paraview --data=$caseName.$OpenFoamExt
    rm $caseName.$OpenFoamExt 2>/dev/null

else

    # since we are now in the cwd, FOAM_ROOT/FOAM_CASE is '$PWD'
    sed -e s%FOAM_ROOT/FOAM_CASE%$PWD%g \
        -e s%FOAM_CASE%$caseName%g $WM_PROJECT_DIR/bin/paraFoam.pvs > paraFoam.pvs

    touch $caseName.$OpenFoamExt
    paraview paraFoam.pvs
    rm paraFoam.pvs $caseName.$OpenFoamExt 2>/dev/null

fi

#------------------------------------------------------------------------------