Revision 8884
Added by Aaron Marcuse-Kubitza over 11 years ago
lib/util.sh: renamed echo_func_ () back to echo_func () and instead add an unalias statement before the if statement containing the function definition. this is necessary because if statements are "compound commands", which have aliases expanded when their definition is read (i.e. at the beginning of the if statement, for the entire if statement), not when they are executed, and any aliases for function names in them need to be unaliased before the if statement containing the function definition. this is necessary even if the if statement is not executed, because the expansion of such aliases will cause syntax errors in the parsing of the if statement itself.
- note that this is preferable to the previous approach, because it causes bash to automatically fall back to the function in contexts where the alias is not usable (e.g. dynamic command names). **
lib/util.sh | ||
---|---|---|
54 | 54 |
echo "$path" |
55 | 55 |
} |
56 | 56 |
|
57 |
echo_func_ () |
|
57 |
fi # allow unalias to take effect |
|
58 |
unalias echo_func |
|
59 |
if self_being_included; then |
|
60 |
|
|
61 |
echo_func () |
|
58 | 62 |
{ |
59 | 63 |
local script="$(canon_rel_path "${BASH_SOURCE[1]}")" |
60 | 64 |
echo_cmd "$script:${BASH_LINENO[0]}" "${FUNCNAME[1]}" "$@" |
61 | 65 |
} |
62 |
alias echo_func='echo_func_ "$@"' # usage: func () { echo_func; ...; }
|
|
66 |
alias echo_func='"echo_func" "$@"' # usage: func () { echo_func; ...; }
|
|
63 | 67 |
|
64 | 68 |
echo_stdin () # usage: input|echo_stdin|cmd |
65 | 69 |
{ |
Also available in: Unified diff