From 6513a23fbe0f93cbfa5bacafb7ebdd2765791563 Mon Sep 17 00:00:00 2001 From: Tanaka Akira Date: Tue, 29 Feb 2000 15:51:21 +0000 Subject: Initial revision --- Test/53completion.ztst | 136 +++++++++++++++++++++++++++++++++++++++++++++++++ Test/comptest | 94 ++++++++++++++++++++++++++++++++++ 2 files changed, 230 insertions(+) create mode 100644 Test/53completion.ztst create mode 100644 Test/comptest (limited to 'Test') diff --git a/Test/53completion.ztst b/Test/53completion.ztst new file mode 100644 index 000000000..00f1c9218 --- /dev/null +++ b/Test/53completion.ztst @@ -0,0 +1,136 @@ +# Tests for completion system. + +%prep + + comptest () { $ZTST_testdir/../Src/zsh -f $ZTST_srcdir/comptest -z $ZTST_testdir/../Src/zsh -d $ZTST_testdir/compdump.tmp "$@" } + + mkdir comp.tmp + cd comp.tmp + + mkdir dir1 + mkdir dir2 + touch file1 + touch file2 + +%test + + comptest $': \t\t\t\t\t\t\t' +0:directories and files +>line: {: }{} +>DESCRIPTION:{file} +>DI:{dir1} +>DI:{dir2} +>FI:{file1} +>FI:{file2} +>line: {: dir1/}{} +>line: {: dir2/}{} +>line: {: file1}{} +>line: {: file2}{} +>line: {: dir1/}{} +>line: {: dir2/}{} + + comptest -c '_users () { compadd user1 user2 }' $': ~\t\t\t\t\t' +0:tilde +>line: {: ~user}{} +>line: {: ~user}{} +>NO:{user1} +>NO:{user2} +>line: {: ~user1}{} +>line: {: ~user2}{} +>line: {: ~user1}{} + + code='compdef _tst tst; _tst () { _arguments ":desc1:(arg1)" }' + comptest -c "$code" $'tst \t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst a\t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst ar\t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst arg\t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst arg1\t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst r\t' +0:_arguments +>line: {tst r}{} + + comptest -c "$code" $'tst x\t' +0:_arguments +>line: {tst x}{} + + comptest -c "$code" $'tst a \t' +0:_arguments +>line: {tst a }{} +>MESSAGE:{no more arguments} + + comptest -c "$code" $'tst a b \t' +0:_arguments +>line: {tst a b }{} +>MESSAGE:{no more arguments} + + code='compdef _tst tst; _tst () { _arguments ":desc1:(a b)" }' + comptest -c "$code" $'tst \t' +0:_arguments +>line: {tst }{} +>DESCRIPTION:{desc1} +>NO:{a} +>NO:{b} + + code='compdef _tst tst; _tst () { _arguments ":desc1:(arg1)" ":desc2:(arg2)" ":desc3:(arg3)" }' + comptest -c "$code" $'tst \t' +0:_arguments +>line: {tst arg1 }{} + + comptest -c "$code" $'tst arg1 \t' +0:_arguments +>line: {tst arg1 arg2 }{} + + comptest -c "$code" $'tst arg1 arg2 \t' +0:_arguments +>line: {tst arg1 arg2 arg3 }{} + + comptest -c "$code" $'tst \C-D' +0:_arguments +>DESCRIPTION:{desc1} +>NO:{arg1} + +# code='compdef _tst tst; _tst () { _arguments "-\+[opt]" }' +# comptest -c "$code" $'tst -\C-D' +#0:_arguments +#>DESCRIPTION:{option} +#>NO:{-+ -- opt} + + code='compdef _tst tst; _tst () { _arguments "1:desc1:(arg1)" }' + comptest -c "$code" $'tst \t' +0:_arguments +>line: {tst arg1 }{} + + code='compdef _tst tst; _tst () { _arguments "-x" ":arg:" }' + comptest -c "$code" $'tst -\t' +0:_arguments +>line: {tst -x }{} + + code='compdef _tst tst; _tst () { _arguments "-x:arg:" }' + comptest -c "$code" $'tst -x\t' +0:_arguments +>line: {tst -x }{} + + code=' + compdef _tst tst + _tst () { _arguments "-a" "*::rest:_tst2" } + _tst2 () { compadd - -b } + ' + comptest -c "$code" $'tst arg -\t' +0:_arguments +>line: {tst arg -b }{} + diff --git a/Test/comptest b/Test/comptest new file mode 100644 index 000000000..aae996105 --- /dev/null +++ b/Test/comptest @@ -0,0 +1,94 @@ +#!/usr/local/bin/zsh -f + +zmodload zsh/zpty +setopt extendedglob + +debug= +dump=(-D) +code= +zsh=${ZSH:-zsh} + +while getopts Dd:c:z: opt; do + case $opt in + D) debug=yes;; + d) dump=(-d "$OPTARG");; + c) code="$OPTARG";; + z) zsh="$OPTARG";; + esac +done +(( OPTIND > 1 )) && shift $(( OPTIND - 1 )) + +input="$*" + +init=\ +'stty columns 80 rows 24 +LISTMAX=10000000 +'"ZLS_COLORS='no=:fi=:di=:ln=:pi=:so=:bd=:cd=:ex=:mi=:tc=:sp=:lc=:ec=\n:rc=' +bindkey -e +autoload -U compinit +compinit $dump +"'zstyle ":completion:*" group-name "" +zstyle ":completion*:messages" format "%d +" +zstyle ":completion*:descriptions" format "%d +" +zstyle ":completion*:options" verbose yes +zstyle ":completion*:values" verbose yes +setopt noalwayslastprompt listrowsfirst completeinword +zmodload zsh/complist +expand-or-complete-with-report () { + print -lr "" + zle expand-or-complete + print -lr - "$LBUFFER" "$RBUFFER" + zle clear-screen + zle -R +} +list-choices-with-report () { + print -lr "" + zle list-choices + zle clear-screen + zle -R +} +finish () { + print "" + exit 0 +} +zle -N expand-or-complete-with-report +zle -N list-choices-with-report +zle -N finish +bindkey "^I" expand-or-complete-with-report +bindkey "^D" list-choices-with-report +bindkey "^Z" finish +'"$code" + +export PS1="" +zpty zsh "$zsh" -f + +zpty -r zsh log "**" + +zpty -w zsh "eval ${init:q}" +zpty -r zsh log "**" + +zpty -w zsh "$input"$'\C-Z' +zpty -r zsh log "**" + +logs=(${(s::)log}) +shift logs + +for log in "$logs[@]"; do + if [[ "$log" = (#b)*$''(*)$'\r\n'(*)$''* ]]; then + print -lr "line: {$match[1]}{$match[2]}" + fi + while (( ${(N)log#*(#b)(<(??)>(*)|(*)|(*))} )); do + log="${log[$mend[1]+1,-1]}" + if (( 0 <= $mbegin[2] )); then + if [[ $match[2] != TC && $match[3] != \ # ]]; then + print "$match[2]:{$match[3]}" + fi + elif (( 0 <= $mbegin[4] )); then + print "DESCRIPTION:{$match[4]}" + elif (( 0 <= $mbegin[5] )); then + print "MESSAGE:{$match[5]}" + fi + done +done -- cgit 1.4.1