ENH: support -case option for foamCleanTutorials, foamRunTutorials

- makes it easier to run/clean individual cases
This commit is contained in:
Mark Olesen
2020-03-25 09:58:52 +01:00
parent 11a4a659cb
commit 6849c008a1
2 changed files with 157 additions and 61 deletions

View File

@ -7,23 +7,10 @@
# \\/ M anipulation |
#------------------------------------------------------------------------------
# Copyright (C) 2011 OpenFOAM Foundation
# Copyright (C) 2019 OpenCFD Ltd.
# Copyright (C) 2019-2020 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/>.
# This file is part of OpenFOAM, distributed under GPL-3.0-or-later.
#
# Script
# foamCleanTutorials
@ -32,10 +19,6 @@
# Run either Allwclean, Allclean or default cleanCase in current directory
# and all its subdirectories.
#
# When an argument is provided, it is treated as a directory name.
# If an option (eg, -self) is provided, it suppresses calling
# Allwclean or Allclean (ie, to avoid recursion)
#
#------------------------------------------------------------------------------
. $WM_PROJECT_DIR/bin/tools/CleanFunctions # Tutorial clean functions
@ -45,29 +28,68 @@ then
thisScript="$PWD/$thisScript"
fi
# Simple option/argument parsing.
# By default use Allclean, Allwclean when present
#
# If an argument is supplied, treat as a change directory
#
# If an option (eg, -self) is provided,
# do not execute ./Allwclean or ./Allclean (to avoid recursion)
printHelp() {
cat <<USAGE
withAllclean=true
Usage: ${0##*/} [OPTION]
${0##*/} [OPTION] directory
options:
-0 use cleanCase0 instead of cleanCase
-case <dir> specify starting directory, default is cwd
-self avoid Allclean script (prevent infinite recursion)
-help print the usage
Recursively clean an OpenFOAM case directory.
By default uses Allclean, Allwclean when present.
USAGE
exit 0 # 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
}
#------------------------------------------------------------------------------
# Parse options
unset skipSelf clean0
if [ "$#" -gt 0 ]
then
case "$1" in
-h | -help*)
echo "${0##*/}: recursively clean an OpenFOAM case directory" 1>&2
exit 0
printHelp
;;
-self | -*)
unset withAllclean
-0)
clean0=true
;;
-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
}
;;
-self*)
skipSelf=true
;;
--)
shift
break
;;
*)
cd "$1" 2>/dev/null || {
echo "${0##*}: No such directory" 1>&2
echo "${0##*}: No such directory $1" 1>&2
exit 2
}
;;
@ -75,18 +97,34 @@ then
fi
if [ -n "$withAllclean" ] && [ -f Allwclean ]
unset exitCode
if [ -z "$skipSelf" ]
then
# Specialized script
./Allwclean
elif [ -n "$withAllclean" ] && [ -f Allclean ]
# Use specialized script(s)
if [ -f Allwclean ]
then
./Allwclean
exitCode="$?"
elif [ -f Allclean ]
then
./Allclean
exitCode="$?"
fi
fi
if [ -n "$exitCode" ]
then
# Specialized script
./Allclean
exit "$exitCode"
elif [ -d system ]
then
# Normal case
cleanCase
if [ "$clean0" = true ]
then
cleanCase0
else
cleanCase
fi
elif [ -d Make ]
then
# Normal application
@ -95,7 +133,7 @@ else
# Recurse into subdirectories
for caseName in *
do
( cd $caseName 2>/dev/null && $thisScript )
( cd $caseName 2>/dev/null && "$thisScript" )
done
fi

View File

@ -7,18 +7,17 @@
# \\/ M anipulation |
#------------------------------------------------------------------------------
# Copyright (C) 2011-2016 OpenFOAM Foundation
# Copyright (C) 2018-2019 OpenCFD Ltd.
# Copyright (C) 2018-2020 OpenCFD Ltd.
#------------------------------------------------------------------------------
# License
# This file is part of OpenFOAM, licensed under GNU General Public License
# <http://www.gnu.org/licenses/>.
# This file is part of OpenFOAM, distributed under GPL-3.0-or-later.
#
# Script
# foamRunTutorials
#
# Description
# Run either Allrun or blockMesh/application in current directory
# and all its subdirectories.
# Recursively run Allrun/Alltest or blockMesh+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.
@ -36,20 +35,67 @@ then
thisScript="$PWD/$thisScript"
fi
unset passArgs runTests skipFirst
printHelp() {
cat <<USAGE
Usage: ${0##*/} [OPTION]
options:
-case <dir> specify starting directory, default is cwd
-self | -skipFirst avoid Allrun, Alltest script (prevent infinite recursion)
-test prefer Alltest script, pass -test argument to scripts
-help print the usage
Recursively run Allrun/Alltest or blockMesh+application,
starting with the current directory or the specified -case directory.
USAGE
exit 0 # 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
}
#------------------------------------------------------------------------------
# Parse options
unset passArgs runTests skipSelf
while [ "$#" -gt 0 ]
do
case "$1" in
-t | -test)
-h | -help*)
printHelp
;;
-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
}
;;
-test)
passArgs="-test"
runTests=true
;;
# Avoid infinite recursion when invoked from an Allrun or Alltest script
-s | -skipFirst)
skipFirst=true
# Avoid infinite recursion when invoked from an Allrun/Alltest script
-self* | -skipFirst)
skipSelf=true
;;
--)
shift
break
;;
*)
break
@ -58,18 +104,30 @@ do
shift
done
if [ -z "$skipFirst" ] && [ -n "$runTests" ] && test -f Alltest
unset exitCode
if [ -z "$skipSelf" ]
then
# Run specialized Alltest script
./Alltest $passArgs $*
elif [ -z "$skipFirst" ] && test -f Allrun
# Use specialized script(s)
if [ "$runTests" = true ] && [ -f Alltest ]
then
./Alltest $passArgs $*
exitCode="$?"
elif [ -f Allrun ]
then
./Allrun $passArgs $*
exitCode="$?"
elif [ -f Allrun-optional ]
then
echo "Skipped optional case $PWD"
exitCode=0
fi
fi
if [ -n "$exitCode" ]
then
# Run specialized Allrun script
./Allrun $passArgs $*
elif [ -z "$skipFirst" ] && test -f Allrun-optional
then
# Has Allrun-optional script - skip this tutorial.
echo "Skipped optional case $PWD"
exit "$exitCode"
elif [ -d system ]
then
# Run normal case with blockMesh and the application
@ -79,7 +137,7 @@ else
# Loop over sub-directories and compile any applications
for caseName in *
do
if [ -d "$caseName" ] && [ -d "$caseName/Make" ]
if [ -d "$caseName/Make" ]
then
( compileApplication "$caseName" )
fi