Project

General

Profile

« Previous | Next » 

Revision 8884

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). **

View differences:

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