SC2054 – ShellCheck Wiki

See this page on GitHub

Sitemap


Use spaces, not commas, to separate array elements.

Problematic code:

flags=("-l", "-d", "--sort=size")
ls "${flags[@]}"

Correct code:

flags=("-l" "-d" "--sort=size")
ls "${flags[@]}"

Rationale:

You appear to have used commas to separate array elements in an array assignment. Other languages require this, but bash instead treats the commas as literal strings.

In the problematic code, the first element is -l, with the trailing comma, and the executed command ends up being ls -l, -d, --sort=size.

In the correct code, the trailing commas have been removed, and the command will be ls -l -d --sort=size as expected.

Exceptions:

None (if you actually want a trailing comma in your strings, move them inside the quotes).


ShellCheck is a static analysis tool for shell scripts. This page is part of its documentation.