Skip to content
Vidar Holen edited this page Nov 19, 2020 · 3 revisions

In POSIX sh, $'..' is undefined.

Problematic code:

#!/bin/sh
IFS=$' \t\n'

Correct code:

#!/bin/sh
# Note: \n can not be last, or it will be stripped by $()
IFS=$(printf ' \n\t')

or

#!/bin/sh
# Trailing linefeed added literally
IFS="$(printf ' \t')
"

or

#!/bin/bash
# Bash supports this
IFS=$' \t\n'

Rationale:

You are using the interpolated string Bashism $'..' in a script that declares itself as POSIX sh (e.g. via #!/bin/sh).

To ensure the script runs correctly on other systems, either switch to Bash, or rewrite it in a POSIX compatible way.

This can generally done via printf as in the example. Be careful about strings with trailing linefeeds, as a $(command substitution) will strip them.

Exceptions:

None.

Related resources:

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