Skip to content
Lucas Larson edited this page Aug 28, 2021 · 9 revisions

expr is antiquated. Consider rewriting this using $((..)), ${} or [[ ]].

Problematic code:

i=$(expr 1 + 2)
l=$(expr length "$var")

Correct code:

i=$((1+2))
l=${#var}

Rationale:

To quote POSIX:

The expr utility has a rather difficult syntax [...] In many cases, the arithmetic and string features provided as part of the shell command language are easier to use than their equivalents in expr. Newly written scripts should avoid expr in favor of the new features within the shell.

Exceptions

sh doesn't have a great replacement for the : operator (regex match). ShellCheck tries not to warn when using expr with :, but e.g. op=:; expr string "$op" regex will still trigger it.

Other than that, all uses of expr can be rewritten to use modern shell features instead.

Bash has [[ string =~ regex ]], so not even expr .. : .. is necessary.

ShellCheck

Each individual ShellCheck warning has its own wiki page like SC1000. Use GitHub Wiki's "Pages" feature above to find a specific one, or see Checks.

Clone this wiki locally