diff options
author | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 02:44:24 +0000 |
---|---|---|
committer | Daniel Baumann <daniel.baumann@progress-linux.org> | 2024-05-06 02:44:24 +0000 |
commit | 8baab3c8d7a6f22888bd581cd5c6098fd2e4b5a8 (patch) | |
tree | 3537e168b860f2742f6029d70501b5ed7d15d345 /src/vimtutor | |
parent | Initial commit. (diff) | |
download | vim-8baab3c8d7a6f22888bd581cd5c6098fd2e4b5a8.tar.xz vim-8baab3c8d7a6f22888bd581cd5c6098fd2e4b5a8.zip |
Adding upstream version 2:8.1.0875.upstream/2%8.1.0875upstream
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'src/vimtutor')
-rwxr-xr-x | src/vimtutor | 74 |
1 files changed, 74 insertions, 0 deletions
diff --git a/src/vimtutor b/src/vimtutor new file mode 100755 index 0000000..1e8769b --- /dev/null +++ b/src/vimtutor @@ -0,0 +1,74 @@ +#! /bin/sh + +# Start Vim on a copy of the tutor file. + +# Usage: vimtutor [-g] [xx] +# Where optional argument -g starts vimtutor in gvim (GUI) instead of vim. +# and xx is a language code like "es" or "nl". +# When an argument is given, it tries loading that tutor. +# When this fails or no argument was given, it tries using 'v:lang' +# When that also fails, it uses the English version. + +# Vim could be called "vim" or "vi". Also check for "vimN", for people who +# have Vim installed with its version number. +# We anticipate up to a future Vim 8.1 version :-). +seq="vim vim81 vim80 vim8 vim74 vim73 vim72 vim71 vim70 vim7 vim6 vi" +if test "$1" = "-g"; then + # Try to use the GUI version of Vim if possible, it will fall back + # on Vim if Gvim is not installed. + seq="gvim gvim81 gvim80 gvim8 gvim74 gvim73 gvim72 gvim71 gvim70 gvim7 gvim6 $seq" + shift +fi + +xx=$1 +export xx + +# We need a temp file for the copy. First try using a standard command. +tmp="${TMPDIR-/tmp}" +TUTORCOPY=`mktemp $tmp/tutorXXXXXX || tempfile -p tutor || echo none` + +# If the standard commands failed then create a directory to put the copy in. +# That is a secure way to make a temp file. +if test "$TUTORCOPY" = none; then + tmpdir=$tmp/vimtutor$$ + OLD_UMASK=`umask` + umask 077 + getout=no + mkdir $tmpdir || getout=yes + umask $OLD_UMASK + if test $getout = yes; then + echo "Could not create directory for tutor copy, exiting." + exit 1 + fi + TUTORCOPY=$tmpdir/tutorcopy + touch $TUTORCOPY + TODELETE=$tmpdir +else + TODELETE=$TUTORCOPY +fi + +export TUTORCOPY + +# remove the copy of the tutor on exit +trap "rm -rf $TODELETE" 0 1 2 3 9 11 13 15 + +for i in $seq; do + testvim=`which $i 2>/dev/null` + if test -f "$testvim"; then + VIM=$i + break + fi +done + +# When no Vim version was found fall back to "vim", you'll get an error message +# below. +if test -z "$VIM"; then + VIM=vim +fi + +# Use Vim to copy the tutor, it knows the value of $VIMRUNTIME +# The script tutor.vim tells Vim which file to copy +$VIM -f -u NONE -c 'so $VIMRUNTIME/tutor/tutor.vim' + +# Start vim without any .vimrc, set 'nocompatible' and 'showcmd' +$VIM -f -u NONE -c "set nocp showcmd" $TUTORCOPY |