1
0
Fork 0
mirror of git://git.code.sf.net/p/zsh/code synced 2025-01-01 05:16:05 +01:00
zsh/Test/V06parameter.ztst
2017-02-26 06:11:19 +00:00

97 lines
1.9 KiB
Text

%prep
setopt chaselinks
cd .
unsetopt chaselinks
mydir=$PWD
%test
print 'print In sourced file
print $LINENO + $functrace + ${funcsourcetrace}
' >sourcedfile
print -r -- 'print Started functrace.zsh
module_path=(./Modules)
print $LINENO + $functrace + ${funcsourcetrace}
:
fn() {
print Inside function $0
print $LINENO + $functrace + ${funcsourcetrace}
}
:
fn
:
fpath=(. $fpath)
:
echo '\''print Inside $0
print $LINENO + $functrace + ${funcsourcetrace}
'\'' >autofn
:
autoload autofn
:
autofn
autofn
. ./sourcedfile' >functrace.zsh
$ZTST_testdir/../Src/zsh +Z -f ./functrace.zsh
0q:Function tracing
>Started functrace.zsh
>3 + +
>Inside function fn
>2 + ./functrace.zsh:10 + ./functrace.zsh:5
>Inside autofn
>2 + ./functrace.zsh:20 + $mydir/autofn:0
>Inside autofn
>2 + ./functrace.zsh:21 + $mydir/autofn:0
>In sourced file
>2 + ./functrace.zsh:22 + ./sourcedfile:0
print -r -- 'module_path=(./Modules)
debug_hook() { print $funcfiletrace[1] $functrace[1]; }
set -o DEBUG_BEFORE_CMD
trap "debug_hook" DEBUG
fn() {
a=1
eval "b=2"
c=3
}
fn
w=5
eval "x=6
y=7"
z=8' >rocky3.zsh
$ZTST_testdir/../Src/zsh +Z -f ./rocky3.zsh
0:Eval tracing
>./rocky3.zsh:5 ./rocky3.zsh:5
>./rocky3.zsh:10 ./rocky3.zsh:10
>./rocky3.zsh:6 fn:1
>./rocky3.zsh:7 fn:2
>./rocky3.zsh:7 (eval):1
>./rocky3.zsh:8 fn:3
>./rocky3.zsh:11 ./rocky3.zsh:11
>./rocky3.zsh:12 ./rocky3.zsh:12
>./rocky3.zsh:12 (eval):1
>./rocky3.zsh:13 (eval):2
>./rocky3.zsh:14 ./rocky3.zsh:14
(
fpath=($PWD)
print "print I have been autoloaded" >myfunc
autoload $PWD/myfunc
print ${functions_source[myfunc]}
myfunc
print ${functions_source[myfunc]}
)
0q: $functions_source
>$mydir/myfunc
>I have been autoloaded
>$mydir/myfunc
functions+=(a 'echo foo'); a
functions+=(a 'echo bar'); a
0:$functions can be appended to twice
>foo
>bar
%clean
rm -f autofn functrace.zsh rocky3.zsh sourcedfile myfunc