Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 1 | #!/bin/sh |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 2 | |
| 3 | # Start Vim on a copy of the tutor file. |
| 4 | |
Bram Moolenaar | 2b57078 | 2008-05-07 15:40:33 +0000 | [diff] [blame] | 5 | # Usage: vimtutor [-g] [xx] |
| 6 | # Where optional argument -g starts vimtutor in gvim (GUI) instead of vim. |
| 7 | # and xx is a language code like "es" or "nl". |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 8 | # When an argument is given, it tries loading that tutor. |
| 9 | # When this fails or no argument was given, it tries using 'v:lang' |
| 10 | # When that also fails, it uses the English version. |
| 11 | |
Bram Moolenaar | 2b57078 | 2008-05-07 15:40:33 +0000 | [diff] [blame] | 12 | # Vim could be called "vim" or "vi". Also check for "vimN", for people who |
| 13 | # have Vim installed with its version number. |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 14 | seq="vim vim91 vim90 vim81 vim80 vim8 vim74 vim73 vim72 vim71 vim70 vim7 vim6 vi" |
Bram Moolenaar | 2b57078 | 2008-05-07 15:40:33 +0000 | [diff] [blame] | 15 | |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 16 | usage() |
| 17 | { |
| 18 | echo "==USAGE=========================================================================================" |
| 19 | echo "${0##*/} [-(-l)anguage ISO639] [-(-c)hapter) NUMBER] [-(-g)ui] | [-(-h)elp] | [--list]" |
| 20 | printf "\twhere:\n" |
| 21 | printf "\t\tISO639 (default=en) is a 2 or 3 character language code\n" |
| 22 | printf "\t\tNUMBER (default=01) is one or two digits representing the chapter number\n" |
| 23 | printf "\texamples:\n" |
| 24 | printf "\t\tvimtutor -l es -c 2 -g\n" |
| 25 | printf "\t\tvimtutor --language de --chapter 02\n" |
| 26 | printf "\t\tvimtutor fr\n" |
| 27 | echo "More information at 'man vimtutor'" |
| 28 | echo "================================================================================================" |
| 29 | } |
| 30 | |
| 31 | listOptions() |
| 32 | { |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 33 | echo "==OPTIONS=======================================================================================" |
| 34 | echo "Chapter: 1" |
| 35 | printf "\tLang: %-3s => %s\n" \ |
| 36 | bar Bavarian \ |
| 37 | bg Bulgarian \ |
| 38 | ca Catalan \ |
| 39 | cs Czech \ |
| 40 | da Danish \ |
| 41 | de German \ |
| 42 | el Greek \ |
| 43 | en English\(default\) \ |
| 44 | eo Esperanto \ |
| 45 | es Spanish \ |
| 46 | fr French \ |
| 47 | hr Croatian \ |
| 48 | hu Hungarian \ |
| 49 | it Italian \ |
| 50 | ja Japanese \ |
| 51 | ko Korean \ |
| 52 | lv Latvian \ |
| 53 | nb Bokmål \ |
| 54 | nl Dutch \ |
| 55 | no Norwegian \ |
| 56 | pl Polish \ |
| 57 | pt Portuguese \ |
| 58 | ru Russian \ |
| 59 | sk Slovak \ |
| 60 | sr Serbian \ |
| 61 | sv Swedish \ |
| 62 | tr Turkish \ |
| 63 | uk English \ |
| 64 | vi Vietnamese \ |
| 65 | zh Chinese |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 66 | |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 67 | echo "Chapter: 2" |
| 68 | printf "\tLang: %-3s => %s\n" \ |
| 69 | en English\(default\) |
| 70 | echo "================================================================================================" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 71 | } |
| 72 | |
| 73 | validateLang() |
| 74 | { |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 75 | case "$xx" in |
| 76 | '' | *[!a-z]* ) |
| 77 | echo "Error: iso639 code must contain only [a-z]" |
| 78 | exit 1 |
| 79 | esac |
| 80 | |
| 81 | case "${#xx}" in |
| 82 | [23] ) |
| 83 | ;; |
| 84 | * ) |
| 85 | echo "Error: iso639 code must be 2 or 3 characters only" |
| 86 | exit 1 |
| 87 | esac |
| 88 | |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 89 | export xx |
| 90 | } |
| 91 | |
| 92 | validateChapter() |
| 93 | { |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 94 | case "$cc" in |
| 95 | '' | *[!0-9]* ) |
| 96 | echo "Error: chapter argument must contain digits only" |
| 97 | exit 1 |
| 98 | ;; |
| 99 | 0 | 00 ) |
| 100 | echo "Error: chapter must be non-zero" |
| 101 | exit 1 |
| 102 | esac |
| 103 | |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 104 | export CHAPTER="$cc" |
| 105 | } |
| 106 | |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 107 | while [ "$1" != "" ]; do |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 108 | case "$1" in |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 109 | -g | --gui ) seq="gvim gvim91 gvim90 gvim81 gvim80 gvim8 gvim74 gvim73 gvim72 gvim71 gvim70 gvim7 gvim6 $seq" |
| 110 | ;; |
| 111 | -l | --language ) shift |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 112 | xx="$1" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 113 | validateLang |
| 114 | ;; |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 115 | -l[a-z][a-z][a-z] | -l[a-z][a-z] ) |
| 116 | export xx="${1#*l}" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 117 | ;; |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 118 | --language[a-z][a-z][a-z] | --language[a-z][a-z] ) |
| 119 | export xx="${1#*e}" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 120 | ;; |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 121 | [a-z][a-z][a-z] | [a-z][a-z] ) export xx="$1" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 122 | ;; |
| 123 | -c | --chapter ) shift |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 124 | cc="$1" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 125 | validateChapter |
| 126 | ;; |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 127 | -c[1-9][0-9] | -c[1-9] ) export CHAPTER="${1#*c}" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 128 | ;; |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 129 | --chapter[1-9][0-9] | --chapter[1-9] ) |
| 130 | export CHAPTER="${1#*r}" |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 131 | ;; |
| 132 | -h | --help ) usage |
| 133 | exit |
| 134 | ;; |
| 135 | --list ) listOptions |
| 136 | exit |
| 137 | ;; |
| 138 | "" ) ;; |
| 139 | * ) usage |
| 140 | exit 1 |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 141 | esac |
| 142 | shift |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 143 | done |
| 144 | |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 145 | |
| 146 | # We need a temp file for the copy. First try using a standard command. |
| 147 | tmp="${TMPDIR-/tmp}" |
| 148 | TUTORCOPY=`mktemp $tmp/tutorXXXXXX || tempfile -p tutor || echo none` |
| 149 | |
| 150 | # If the standard commands failed then create a directory to put the copy in. |
| 151 | # That is a secure way to make a temp file. |
| 152 | if test "$TUTORCOPY" = none; then |
| 153 | tmpdir=$tmp/vimtutor$$ |
| 154 | OLD_UMASK=`umask` |
| 155 | umask 077 |
| 156 | getout=no |
| 157 | mkdir $tmpdir || getout=yes |
| 158 | umask $OLD_UMASK |
| 159 | if test $getout = yes; then |
| 160 | echo "Could not create directory for tutor copy, exiting." |
| 161 | exit 1 |
| 162 | fi |
| 163 | TUTORCOPY=$tmpdir/tutorcopy |
| 164 | touch $TUTORCOPY |
| 165 | TODELETE=$tmpdir |
| 166 | else |
| 167 | TODELETE=$TUTORCOPY |
| 168 | fi |
| 169 | |
| 170 | export TUTORCOPY |
| 171 | |
| 172 | # remove the copy of the tutor on exit |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 173 | trap "rm -rf $TODELETE" EXIT HUP INT QUIT SEGV PIPE TERM |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 174 | |
Bram Moolenaar | 1315349 | 2007-07-17 12:33:46 +0000 | [diff] [blame] | 175 | for i in $seq; do |
Aliaksei Budavei | 09cc8c9 | 2024-11-04 19:43:22 +0100 | [diff] [blame] | 176 | testvim=$(command -v "$i" 2>/dev/null) |
Bram Moolenaar | 89a9c15 | 2021-08-29 21:55:35 +0200 | [diff] [blame] | 177 | if test -f "$testvim"; then |
| 178 | VIM=$i |
| 179 | break |
| 180 | fi |
Bram Moolenaar | 1315349 | 2007-07-17 12:33:46 +0000 | [diff] [blame] | 181 | done |
| 182 | |
| 183 | # When no Vim version was found fall back to "vim", you'll get an error message |
| 184 | # below. |
| 185 | if test -z "$VIM"; then |
Bram Moolenaar | 89a9c15 | 2021-08-29 21:55:35 +0200 | [diff] [blame] | 186 | VIM=vim |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 187 | fi |
| 188 | |
| 189 | # Use Vim to copy the tutor, it knows the value of $VIMRUNTIME |
| 190 | # The script tutor.vim tells Vim which file to copy |
Paul Desmond Parker | 17c71da | 2024-11-03 20:47:53 +0100 | [diff] [blame] | 191 | |
Bram Moolenaar | 2b57078 | 2008-05-07 15:40:33 +0000 | [diff] [blame] | 192 | $VIM -f -u NONE -c 'so $VIMRUNTIME/tutor/tutor.vim' |
Bram Moolenaar | 071d427 | 2004-06-13 20:20:40 +0000 | [diff] [blame] | 193 | |
Bram Moolenaar | 527dec3 | 2018-04-12 20:36:43 +0200 | [diff] [blame] | 194 | # Start vim without any .vimrc, set 'nocompatible' and 'showcmd' |
Bram Moolenaar | 89a9c15 | 2021-08-29 21:55:35 +0200 | [diff] [blame] | 195 | $VIM -f -u NONE -c "set nocp showcmd" "$TUTORCOPY" |