Created SC2145 (markdown)

koalaman
2014-06-07 13:43:32 -07:00
parent 78b014d19a
commit 1494c00aae

23
SC2145.md Normal file

@@ -0,0 +1,23 @@
## Argument mixes string and array. Use * or separate argument.
### Problematic code:
printf "Error: %s\n" "Bad parameters: $@"
### Correct code:
printf "Error: %s\n" "Bad parameters: $*"
### Rationale:
The behavior when concatenating a string and array is rarely intended. The preceeding string is prefixed to the first array element, while the succeeding string is appended to the last one. The middle array elements are unaffected.
E.g., with the parameters `foo`,`bar`,`baz`, `"--flag=$@"` is equivalent to the three arguments `"--flag=foo" "bar" "baz"`.
If the intention is to concatenate all the array elements into one argument, use `$*`. This concatenates based on `IFS`.
If the intention is to provide each array element as a separate argument, put the array expansion in its own argument.
### Contraindications
None.