2005-09-20 21:31:55 +08:00
|
|
|
\section case case - conditionally execute a block of commands
|
|
|
|
|
|
|
|
\subsection case-synopsis Synopsis
|
2006-09-19 22:52:03 +08:00
|
|
|
<tt>switch VALUE; [case [WILDCARD...]; [COMMANDS...]; ...] end</tt>
|
2005-09-20 21:31:55 +08:00
|
|
|
|
|
|
|
\subsection case-description Description
|
|
|
|
|
Help cleanup
Large list of changes, including formatting and typos for most commands.
More substantive changes have been made to alias, bind, block, break,
builtin, case, cd, commandline, count, else, emit, fish_config, funced,
function, functions, history, math, mimedb, nextd, not, popd, prevd,
pushd, pwd, random, read, set, set_color, switch, test, trap, type,
ulimit, umask, and while.
2013-05-12 15:56:01 +08:00
|
|
|
\c switch performs one of several blocks of commands, depending on whether
|
|
|
|
a specified value equals one of several wildcarded values. \c case is used
|
|
|
|
together with the \c switch statement in order to determine which block should
|
|
|
|
be executed.
|
2005-09-20 21:31:55 +08:00
|
|
|
|
Help cleanup
Large list of changes, including formatting and typos for most commands.
More substantive changes have been made to alias, bind, block, break,
builtin, case, cd, commandline, count, else, emit, fish_config, funced,
function, functions, history, math, mimedb, nextd, not, popd, prevd,
pushd, pwd, random, read, set, set_color, switch, test, trap, type,
ulimit, umask, and while.
2013-05-12 15:56:01 +08:00
|
|
|
Each \c case command is given one or more parameters. The first \c case
|
2006-04-21 16:35:29 +08:00
|
|
|
command with a parameter that matches the string specified in the
|
|
|
|
switch command will be evaluated. \c case parameters may contain
|
|
|
|
wildcards. These need to be escaped or quoted in order to avoid
|
|
|
|
regular wildcard expansion using filenames.
|
|
|
|
|
Help cleanup
Large list of changes, including formatting and typos for most commands.
More substantive changes have been made to alias, bind, block, break,
builtin, case, cd, commandline, count, else, emit, fish_config, funced,
function, functions, history, math, mimedb, nextd, not, popd, prevd,
pushd, pwd, random, read, set, set_color, switch, test, trap, type,
ulimit, umask, and while.
2013-05-12 15:56:01 +08:00
|
|
|
Note that fish does not fall through on case statements. Only the
|
|
|
|
first matching case is executed.
|
2006-04-21 16:35:29 +08:00
|
|
|
|
Help cleanup
Large list of changes, including formatting and typos for most commands.
More substantive changes have been made to alias, bind, block, break,
builtin, case, cd, commandline, count, else, emit, fish_config, funced,
function, functions, history, math, mimedb, nextd, not, popd, prevd,
pushd, pwd, random, read, set, set_color, switch, test, trap, type,
ulimit, umask, and while.
2013-05-12 15:56:01 +08:00
|
|
|
Note that command substitutions in a case statement will be
|
|
|
|
evaluated even if its body is not taken. All substitutions, including
|
|
|
|
command substitutions, must be performed before the value can be compared
|
|
|
|
against the parameter.
|
2006-04-21 16:35:29 +08:00
|
|
|
|
2005-09-20 21:31:55 +08:00
|
|
|
\subsection case-example Example
|
|
|
|
|
|
|
|
If the variable \$animal contains the name of an animal, the following
|
|
|
|
code would attempt to classify it:
|
|
|
|
|
|
|
|
<pre>
|
|
|
|
switch $animal
|
|
|
|
case cat
|
|
|
|
echo evil
|
|
|
|
case wolf dog human moose dolphin whale
|
|
|
|
echo mammal
|
2006-01-24 07:17:06 +08:00
|
|
|
case duck goose albatross
|
2005-09-20 21:31:55 +08:00
|
|
|
echo bird
|
|
|
|
case shark trout stingray
|
|
|
|
echo fish
|
Help cleanup
Large list of changes, including formatting and typos for most commands.
More substantive changes have been made to alias, bind, block, break,
builtin, case, cd, commandline, count, else, emit, fish_config, funced,
function, functions, history, math, mimedb, nextd, not, popd, prevd,
pushd, pwd, random, read, set, set_color, switch, test, trap, type,
ulimit, umask, and while.
2013-05-12 15:56:01 +08:00
|
|
|
# Note that the next case has a wildcard which is quoted
|
2006-04-21 16:35:29 +08:00
|
|
|
case '*'
|
|
|
|
echo I have no idea what a $animal is
|
2005-09-20 21:31:55 +08:00
|
|
|
end
|
|
|
|
</pre>
|
2006-09-19 22:52:03 +08:00
|
|
|
|
|
|
|
If the above code was run with \c \$animal set to \c whale, the output
|
|
|
|
would be \c mammal.
|
|
|
|
|