Skip to content
Snippets Groups Projects
  • Mark OLESEN's avatar
    ENH: more succinct output from command-line errors. · 5947f9a3
    Mark OLESEN authored
    - unknown options or missing option values now emit a shorter message
      without the entire usage. This makes it easier to identify the errors
      and is better aligned with the behaviour of GNU system tools.
    
      ====
         $ simpleFoam -case
         Using: OpenFOAM-plus (see www.OpenFOAM.com)
         Build: plus-01234
    
         Error: option '-case' requires an argument
    
         See 'simpleFoam -help' for usage
      ====
    
    - provide for reduced (-help) and full (-help-full) usage information.
      In many cases the reduced usage provided sufficient and easier
      to find the information.
    
    - make -srcDoc an alias for -doc-source
    
    - no warnings about option aliases for future dates.
    5947f9a3
foamExec 4.41 KiB
#!/bin/bash
#------------------------------------------------------------------------------
# =========                 |
# \\      /  F ield         | OpenFOAM: The Open Source CFD Toolbox
#  \\    /   O peration     |
#   \\  /    A nd           | Copyright (C) 2011-2016 OpenFOAM Foundation
#    \\/     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 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
#     foamExec
#
# Description
#     Usage: foamExec [-version=foamVersion] <foamCommand> ...
#
#     Runs the <foamVersion> version of executable <foamCommand>
#     with the rest of the arguments.
#
#     Can also be used for parallel runs. For example,
#     \code
#         mpirun -np <nProcs> \
#             foamExec -version=VERSION <foamCommand> ... -parallel
#     \endcode
#
# Note
#     This script must exist in $FOAM_INST_DIR/OpenFOAM-<VERSION>/bin/
#     or $FOAM_INST_DIR/openfoam<VERSION>/bin/ (for the debian version)
#
#     foamEtcFile must be found in the same directory as this script
#
# See also
#    foamEtcFile
#
#------------------------------------------------------------------------------
usage() {
    exec 1>&2
    while [ "$#" -ge 1 ]; do echo "$1"; shift; done
    cat<<USAGE

Usage: ${0##*/} [OPTION] <application> ...

options:
  -mode=MODE        Any combination of u(user), g(group), o(other)
  -prefix=DIR       Specify an alternative installation prefix
                    pass through to foamEtcFile and set as FOAM_INST_DIR
  -version=VER      Specify alternative OpenFOAM version (eg, 3.0, 1612, ...)
                    pass through to foamEtcFile
  -help             Print the usage

Run a particular OpenFOAM version of <APPLICATION>

USAGE
    exit 1
}

#-------------------------------------------------------------------------------
binDir="${0%/*}"                # The bin dir
projectDir="${binDir%/bin}"     # The project dir
prefixDir="${projectDir%/*}"    # The prefix dir (same as $WM_PROJECT_INST_DIR)

## projectDirName="${projectDir##*/}"      # The project directory name

version="${WM_PROJECT_VERSION:-unknown}"

unset etcOpts
# parse options
while [ "$#" -gt 0 ]
do
    case "$1" in
    -h | -help*)
        usage
        ;;
    -mode=*)
        etcOpts="$etcOpts $1"       # pass-thru to foamEtcFile
        ;;
    -prefix=/*)
        etcOpts="$etcOpts $1"       # pass-thru to foamEtcFile
        prefixDir="${1#*=}"
        ;;
    -version=*)
        etcOpts="$etcOpts $1"       # pass-thru to foamEtcFile
        version="${1#*=}"
        ;;
    -m | -mode)
        [ "$#" -ge 2 ] || usage "'$1' option requires an argument"
        etcOpts="$etcOpts $1 $2"    # pass-thru to foamEtcFile
        shift
        ;;
    -p | -prefix)
        [ "$#" -ge 2 ] || usage "'$1' option requires an argument"
        etcOpts="$etcOpts $1 $2"    # pass-thru to foamEtcFile
        prefixDir="$2"
        shift
        ;;
    -v | -version)
        [ "$#" -ge 2 ] || usage "'$1' option requires an argument"
        etcOpts="$etcOpts $1 $2"    # pass-thru to foamEtcFile
        version="$2"
        shift
        ;;
    --)
        shift
        break
        ;;
    -*)
        usage "invalid option '$1'"
        ;;
    *)
        break
        ;;
    esac
    shift
done

#
# Find and source OpenFOAM settings (bashrc)
# placed in function to preserve command-line arguments
#
sourceRc()
{
    rcFile="$($binDir/foamEtcFile $etcOpts bashrc)" || {
        echo "Error : bashrc file could not be found for OpenFOAM-$version" 1>&2
        exit 1
    }

    # set to consistent value before sourcing the bashrc
    export FOAM_INST_DIR="$prefixDir"

    . $rcFile $FOAM_SETTINGS
}


[ "$#" -ge 1 ] || usage "no application specified"

sourceRc
exec "$@"

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