Skip to content
Snippets Groups Projects
RunFunctions 5.13 KiB
Newer Older
#---------------------------------*- sh -*-------------------------------------
# =========                 |
# \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
#  \\    /   O peration     |
#   \\  /    A nd           | Copyright (C) 2011-2016 OpenFOAM Foundation
#    \\/     M anipulation  | Copyright (C) 2015-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
#     RunFunctions
#
# Description
#     Miscellaneous functions for running tutorial cases
#------------------------------------------------------------------------------

isTest()
{
    for i in "$@"; do
        if [ "$i" = "-test" ]
        then
            return 0
        fi
    done
    return 1
}

getNumberOfProcessors()
{
    then
        expandDictionary $1 | sed -ne 's/^numberOfSubdomains\s*\(.*\);/\1/p'
    fi
    sed -ne 's/^ *application\s*\([a-zA-Z]*\)\s*;.*$/\1/p' system/controlDict
    APP_RUN=
    LOG_IGNORE=false
    LOG_APPEND=false
    # Parse options and executable
    while [ $# -gt 0 ] && [ -z "$APP_RUN" ]; do
        key="$1"
        case "$key" in
                LOG_IGNORE=true
                LOG_APPEND=true
                ;;
            *)
                APP_RUN="$key"
                APP_NAME="${key##*/}"
                LOG_SUFFIX="${APP_NAME}${LOG_SUFFIX}"
    if [ -f log.$LOG_SUFFIX ] && [ "$LOG_IGNORE" = "false" ]
        echo "$APP_NAME already run on $PWD:" \
             "remove log file 'log.$LOG_SUFFIX' to re-run"
    else
        echo "Running $APP_RUN on $PWD"
        if [ "$LOG_APPEND" = "true" ]; then
            $APP_RUN "$@" >> log.$LOG_SUFFIX 2>&1
            $APP_RUN "$@" > log.$LOG_SUFFIX 2>&1
    # Store any parsed additional arguments e.g. decomposeParDict
    APP_PARARGS=
    LOG_IGNORE=false
    LOG_APPEND=false
    # Check the default decomposeParDict if available
    nProcs=$(getNumberOfProcessors "system/decomposeParDict")
    # Parse options and executable
    while [ $# -gt 0 ] && [ -z "$APP_RUN" ] ; do
                LOG_IGNORE=true
                LOG_APPEND=true
                ;;
            -decomposeParDict)
                nProcs=$(getNumberOfProcessors "$2")
                APP_PARARGS="$APP_PARARGS -decomposeParDict $2"
                shift
                ;;
            *)
                APP_RUN="$key"
                APP_NAME="${key##*/}"
                LOG_SUFFIX="${APP_NAME}${LOG_SUFFIX}"
    if [ -f log.$SUFFIX ] && [ "$LOG_IGNORE" = "false" ]
        echo "$APP_NAME already run on $PWD:" \
             "remove log file 'log.$LOG_SUFFIX' to re-run"
    else
        echo "Running $APP_RUN in parallel on $PWD using $nProcs processes"
        if [ "$LOG_APPEND" = "true" ]; then
            ( mpirun -np $nProcs $APP_RUN $APP_PARARGS -parallel "$@" < /dev/null >> log.$LOG_SUFFIX 2>&1 )
            ( mpirun -np $nProcs $APP_RUN $APP_PARARGS -parallel "$@" < /dev/null > log.$LOG_SUFFIX 2>&1 )
{
    echo "Compiling $1 application"
    wmake $1
}

        echo "Case already cloned: remove case directory $2 to clone"
    else
        echo "Cloning $2 case from $1"
        mkdir $2
        cpfiles="0 system constant"
        for f in $cpfiles
        do
# Overwrite 0/ with the contents of 0.org/ if it exists
restore0Dir()
{
    echo "Restore 0/ from 0.org/"
    if [ -d 0.org ]
    then
        \rm -rf 0
        \cp -r 0.org 0 > /dev/null 2>&1
    else
        echo "    Warning: no 0.org/ found"
    fi
}

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