Skip to content
Snippets Groups Projects
foamRunTutorials 4.71 KiB
Newer Older
#!/bin/sh
#------------------------------------------------------------------------------
# =========                 |
# \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
#  \\    /   O peration     |
OpenFOAM bot's avatar
OpenFOAM bot committed
#   \\  /    A nd           | www.openfoam.com
#    \\/     M anipulation  |
#------------------------------------------------------------------------------
OpenFOAM bot's avatar
OpenFOAM bot committed
#     Copyright (C) 2011-2016 OpenFOAM Foundation
#     Copyright (C) 2018-2021 OpenCFD Ltd.
#------------------------------------------------------------------------------
# License
#     This file is part of OpenFOAM, distributed under GPL-3.0-or-later.
#
# Script
#     foamRunTutorials
#
# Description
#     Recursively run Allrun/Alltest or blockMesh and application,
#     starting with the current directory or the specified -case directory.
#     For tutorials that are known to run poorly, an Allrun-optional
#     placeholder can be used instead of the usual Allrun script.
#     When this is detected, the case will be skipped.
#
#------------------------------------------------------------------------------
. ${WM_PROJECT_DIR:?}/bin/tools/RunFunctions    # Tutorial run functions
# Normally use standard "make"
thisScript="$0"
if [ "/${thisScript#/}" != "$thisScript" ]
then
    thisScript="$PWD/$thisScript"
fi

printHelp() {
    cat <<USAGE

Usage: ${0##*/} [OPTION]
options:
  -case=DIR     Specify starting directory, default is cwd
  -serial       Prefer Allrun-serial if available
  -parallel     Prefer Allrun-parallel if available
  -test         Prefer Alltest script, pass -test argument to scripts
  -self         Avoid initial Allrun, Alltest scripts
                (prevent infinite recursion)
  -help         Print the usage
Recursively run Allrun/Alltest (or blockMesh + application)
starting from the current directory or the specified -case directory.

Equivalent options:
  | -case=DIR  | -case DIR |
   exit 0  # A clean exit
}

# Report error and exit
die()
{
    exec 1>&2
    echo
    echo "Error encountered:"
    while [ "$#" -ge 1 ]; do echo "    $1"; shift; done
    echo
    echo "See '${0##*/} -help' for usage"
    echo
    exit 1
}

#------------------------------------------------------------------------------
unset passArgs runTests runType skipSelf
    (- | --)
        shift
        break   # Stop option parsing
        ;;
    (-h* | -help* | --help*)

    ## Prefer serial or parallel
    -serial | -parallel)
        runType="${1#*-}"
        ;;

    -test)
        passArgs="-test"
        runTests=true
        ;;

    ## long-option (internal dispatch form)
    --run=serial | --run=parallel)
        runType="${1#*=}"
        ;;
    --run=*)
        echo "$0: unknown setting: $1" 1>&2
        ;;

    -case=*)
        caseName="${1#*=}"
        cd "$caseName" 2>/dev/null || {
            echo "${0##*}: No such directory $caseName" 1>&2
            exit 2
        }
        ;;
    -case)
        [ "$#" -ge 2 ] || die "'$1' option requires an argument"
        shift
        cd "$1" 2>/dev/null || {
            echo "${0##*}: No such directory $1" 1>&2
            exit 2
        }
        ;;
    # Avoid infinite recursion when invoked from an Allrun/Alltest script
    -self* | -skipFirst)
        skipSelf=true
        ;;
# Use specialized script(s), but not on self
then
    # Use specialized script(s)
    if [ "$runTests" = true ] && [ -f Alltest ]
    then
        ./Alltest $passArgs $*
    elif [ -f Allrun-optional ]
    then
        echo "Skipped optional case $PWD"
        exit 0
    fi

    # Prefer -serial or -parallel when available?
    if [ -n "$runType" ]
    then
        if [ -f ./"Allrun-${runType}" ]
        then
            ./"Allrun-${runType}" $passArgs $*
            exit "$?"
        fi
    fi
    if [ -f ./Allrun ]
    then
        ./Allrun $passArgs $*
        exit "$?"
if [ -d system ]
then
    # Run normal case with blockMesh and the application
    runApplication blockMesh
    runApplication $(getApplication)
else
    # Loop over sub-directories and compile any applications
        then
            ( compileApplication "$caseName" )

    subdirs=$(for d in *; do [ -d "$d" ] && echo "$d"; done | xargs)
    # Run all cases which have not already been run
    "$make" -k -f "${WM_PROJECT_DIR:?}"/bin/tools/MakefileDirs \
          FOAM_TARGETS="$subdirs" \
          FOAM_APP="$thisScript" \
          FOAM_ARGS="$passArgs ${runType:+--run=$runType} $*"
fi

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