home *** CD-ROM | disk | FTP | other *** search
/ GEMini Atari / GEMini_Atari_CD-ROM_Walnut_Creek_December_1993.iso / zip / language / elisp.zoo / lisp / vip.elc < prev   
Text File  |  1988-02-16  |  69KB  |  1,266 lines

  1.  
  2. (defvar vip-emacs-local-map nil "\
  3. Local map used in emacs mode. (buffer specific)")
  4.  
  5. (defvar vip-insert-local-map nil "\
  6. Local map used in insert command mode. (buffer specific)")
  7.  
  8. (make-variable-buffer-local (quote vip-emacs-local-map))
  9.  
  10. (make-variable-buffer-local (quote vip-insert-local-map))
  11.  
  12. (defvar vip-insert-point nil "\
  13. Remember insert point as a marker. (buffer specific)")
  14.  
  15. (set-default (quote vip-insert-point) (make-marker))
  16.  
  17. (make-variable-buffer-local (quote vip-insert-point))
  18.  
  19. (defvar vip-com-point nil "\
  20. Remember com point as a marker. (buffer specific)")
  21.  
  22. (set-default (quote vip-com-point) (make-marker))
  23.  
  24. (make-variable-buffer-local (quote vip-com-point))
  25.  
  26. (defvar vip-current-mode nil "\
  27. Current mode.  One of emacs-mode, vi-mode, insert-mode.")
  28.  
  29. (make-variable-buffer-local (quote vip-current-mode))
  30.  
  31. (setq-default vip-current-mode (quote emacs-mode))
  32.  
  33. (defvar vip-emacs-mode-line-buffer-identification nil "\
  34. value of mode-line-buffer-identification in emacs-mode.")
  35.  
  36. (make-variable-buffer-local (quote vip-emacs-mode-line-buffer-identification))
  37.  
  38. (setq-default vip-emacs-mode-line-buffer-identification (quote ("Emacs: %17b")))
  39.  
  40. (defvar vip-current-major-mode nil "\
  41. vip-current-major-mode is the major-mode vi considers it is now.
  42. (buffer specific)")
  43.  
  44. (make-variable-buffer-local (quote vip-current-major-mode))
  45.  
  46. (defvar vip-last-shell-com nil "\
  47. last shell command executed by ! command")
  48.  
  49. (defvar vip-use-register nil "\
  50. name of register to store deleted or yanked strings.")
  51.  
  52. (defvar vip-d-com nil "\
  53. If non-nil, it's value is a list (M-COM VAL COM), and is used to
  54. re-execute last destrcutive command")
  55.  
  56. (defconst vip-shift-width 8 "\
  57. *The number of colums shifted by > and < command.")
  58.  
  59. (defconst vip-re-replace nil "\
  60. *If t then do regexp replace, if nil then do string replace.")
  61.  
  62. (defvar vip-d-char nil "\
  63. The character remenbered by the vi \"r\" command")
  64.  
  65. (defvar vip-f-char nil "\
  66. for use by \";\" command")
  67.  
  68. (defvar vip-F-char nil "\
  69. for use by \".\" command")
  70.  
  71. (defvar vip-f-forward nil "\
  72. for use by \";\" command")
  73.  
  74. (defvar vip-f-offset nil "\
  75. for use by \";\" command")
  76.  
  77. (defconst vip-search-wrap-around t "\
  78. *if t, search wraps around")
  79.  
  80. (defconst vip-re-search nil "\
  81. *if t, search is reg-exp search, otherwise vanilla search.")
  82.  
  83. (defvar vip-s-string nil "\
  84. last search string")
  85.  
  86. (defvar vip-s-forward nil "\
  87. if t, search is forward.")
  88.  
  89. (defconst vip-case-fold-search nil "\
  90. *if t, search ignores cases.")
  91.  
  92. (defconst vip-re-query-replace nil "\
  93. *If t then do regexp replace, if nil then do string replace.")
  94.  
  95. (defconst vip-open-with-indent nil "\
  96. *if t, indent when open a new line.")
  97.  
  98. (defconst vip-help-in-insert-mode nil "\
  99. *if t then C-h is bound to help-command in insert mode, if nil then it is
  100. bound to delete-backward-char.")
  101.  
  102. (defvar vip-quote-string "> " "\
  103. string inserted at the beginning of region")
  104.  
  105. (defvar vip-tags-file-name "TAGS")
  106.  
  107. (defvar vip-inhibit-startup-message nil)
  108.  
  109. (global-set-key "ə" (quote vip-change-mode-to-vi))
  110.  
  111. (defmacro vip-loop (count body) "(COUNT BODY) Execute BODY COUNT times." (byte-code "אij✓DCבגijדE    הijוijDEFEç" [count body let while > 0 setq 1-] 9))
  112.  
  113. (defun vip-push-mark-silent (&optional location) "\
  114. Set mark at LOCATION (point, by default) and push old mark on mark ring.
  115. No message." (byte-code "ג ?â
  116. ijé+דה !    Bë①ê    G
  117. Và+וז
  118.     \"@ij\"êחז
  119. S    \"ij\"êט♪å2`!ç" [nil mark-ring mark-ring-max location mark copy-marker mark-marker move-marker nthcdr setcdr set-mark] 9))
  120.  
  121. (defun vip-goto-col (arg) "\
  122. Go to ARG's column." (interactive "P") (byte-code "גêד    !ה    !ə⑧èו ê✓iTVà⑧זח!)ê
  123. à\"ט♪`\"êי êכ✓S!ê
  124. à4למ✓
  125. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom end-of-line error "" move-marker beginning-of-line forward-char vip-execute-com vip-goto-col] 11))
  126.  
  127. (defun vip-refresh-mode-line nil "\
  128. Redraw mode line." (byte-code "ijIJ !ç" [set-buffer-modified-p buffer-modified-p] 3))
  129.  
  130. (defun vip-copy-keymap (map) (byte-code "✓?â
  131. IJ éא✓!ç" [map make-sparse-keymap copy-keymap] 3))
  132.  
  133. (defun vip-change-mode (new-mode) "\
  134. Change mode to NEW-MODE.  NEW-MODE is either emacs-mode, vi-mode,
  135. or insert-mode." (byte-code "✓    =åƒ✓ח=â4    ט=âי`
  136. \"êכ é(ל ③④מל !ë⑥╱êנס!êע◆!éÿ✓ט=âïפ
  137. `\"ê    צ=âTל ③④מל !ë⑥╱éZמ♪!ë⑥╱êנק!êע╱!êר╱שת#êר╱ןך#êר╱ם✓âףéÇץ#êר╱§∧#éÿ✓צ=àÿנ∞!êע♪!ê✓ë①êα ç" [new-mode vip-current-mode vip-insert-point vip-emacs-local-map vip-emacs-mode-line-buffer-identification mode-line-buffer-identification vip-insert-local-map vip-mode-map vip-help-in-insert-mode vi-mode insert-mode vip-copy-region-as-kill vip-repeat-insert-command current-local-map vip-copy-keymap vip-change-mode-line "Vi:   " use-local-map move-marker emacs-mode "Insert" define-key "" vip-change-mode-to-vi "ə" vip-ESC "✓" help-command delete-backward-char "⑦" vip-delete-backward-word "Emacs:" vip-refresh-mode-line] 22))
  138.  
  139. (defun vip-copy-region-as-kill (beg end) "\
  140. If BEG and END do not belong to the same buffer, it copies empty region." (byte-code "ijIJאÅç" [nil (byte-code "א✓    \"ç" [beg end copy-region-as-kill] 3) ((error (byte-code "IJ✓✓\"ç" [beg copy-region-as-kill] 3)))] 3))
  141.  
  142. (defun vip-change-mode-line (string) "\
  143. Assuming that the mode line format contains the string \"Emacs:\", this
  144. function replaces the string by \"Vi:   \" etc." (byte-code "ב    ג\"â♪
  145. é    דPCë⓪ç" [mode-line-buffer-identification string vip-emacs-mode-line-buffer-identification string= "Emacs:" " %17b"] 3))
  146.  
  147. (defun vip-mode nil "\
  148. Turn on VIP emulation of VI." (interactive) (byte-code "אê✓?àCבג!êד êהcêebêוז!à7èחטי!!qêdbêכcêל êמp!)êנס!êעפ!êמp!êנצ!êIJë⓪êק ç" [vip-inhibit-startup-message t nil switch-to-buffer "VIP Startup Message" erase-buffer "VIP is a Vi emulation package for GNU Emacs.  VIP provides most Vi commands
  149. including Ex commands.  VIP is however different from Vi in several points.
  150. You can get more information on VIP by:
  151.     1.  Typing `M-x info' and selecting menu item \"vip\".
  152.     2.  Typing `C-h k' followed by a key whose description you want.
  153.     3.  Printing VIP manual which can be found as GNU/man/vip.texinfo
  154.     4.  Printing VIP Reference Card which can be found as GNU/etc/vipcard.tex
  155.  
  156. This startup message appears whenever you load VIP unless you type `y' now.
  157. Type `n' to quit this window for now.
  158. " y-or-n-p "Inhibit VIP startup message? " find-file-noselect substitute-in-file-name "~/.vip" "
  159. (setq vip-inhibit-startup-message t)
  160. " save-buffer kill-buffer message "VIP startup message inhibited." sit-for 2 "" vip-change-mode-to-vi] 13))
  161.  
  162. (defun vip-change-mode-to-vi nil "\
  163. Change mode to vi mode." (interactive) (byte-code "ijêIJא!ç" [nil vip-change-mode vi-mode] 2))
  164.  
  165. (defun vip-change-mode-to-insert nil "\
  166. Change mode to insert mode." (interactive) (byte-code "ijêIJא!ç" [nil vip-change-mode insert-mode] 2))
  167.  
  168. (defun vip-change-mode-to-emacs nil "\
  169. Change mode to emacs mode." (interactive) (byte-code "ijêIJא!ç" [nil vip-change-mode emacs-mode] 2))
  170.  
  171. (defun vip-get-editor-command (l-map g-map &optional str) "\
  172. Read characters from keyboard until an editor command is formed, using
  173. local keymap L-MAP and global keymap G-MAP.  If the command is a
  174. self-insert-command, the character just read is returned instead.  Optional
  175. string STR is used as initial input string." (byte-code "וווə⑨⑧♪?åז♪ח\"â⑥ré⑨ט♪!ë⓪ê✓ë④êי✓\"ë①ê    ?â[י✓╱\"ë②ê
  176. ?â=וéXכ
  177. !âMלו
  178. מ♪!#éX
  179. נ=âW✓éX
  180. é¥כ    !âÆי✓╱\"ë②ê
  181. ?âxל    ומ♪!#éÅכ
  182. !âêל    
  183. מ♪!#éÅל    ומ♪!#饠   נ=â£✓饠   +ç" [char l-bind g-bind str last-command-char l-map g-map nil string= "" string-to-char vip-binding-of keymapp vip-get-editor-command vip-string-tail self-insert-command] 19))
  184.  
  185. (defun vip-binding-of (char map) "\
  186. Return key-binding of CHAR under keymap MAP.  It is nil if the binding
  187. is void, or a command, or a keymap" (byte-code "    <âה
  188.     \"Aé⓪    
  189. H⑧✓?âəבéBו✓!â.✓9â*✓Ké+✓éB✓K?å9ו!â@éA✓))ç" [val map char nil t fun assq keymapp] 4))
  190.  
  191. (defun vip-escape-to-emacs (arg &optional char) "\
  192. Escape to emacs mode and execute one emacs command and then return to
  193. vi mode.  ARG is used as the prefix value for the executed command.  If
  194. CHAR is given it becomes the first character of the command." (interactive "P") (byte-code "זêזpבə⑨⑧ à ë⑤ê◆ë⑥╱ê
  195. åכYà\\זë②êל    
  196. \"ë⓪êמ✓!âSנ╱!♪♪כVàOס✓!cê♪Së⑥♪êé9)éXע✓╱\"êé⑥êזë⑥╱+ç" [com buff first t char unread-command-char prefix-arg arg nil vip-emacs-local-map global-map count 0 vip-get-editor-command numberp vip-p-val char-to-string command-execute] 8))
  197.  
  198. (defun vip-message-conditions (conditions) "\
  199. Print CONDITIONS as a message." (byte-code "    @    Aə⑧
  200. ?â②בג✓\"é⑨בד✓ה
  201. !#êו *ç" [case conditions msg message "%s" "%s %s" prin1-to-string ding] 6))
  202.  
  203. (defun vip-ESC (arg) "\
  204. Emulate ESC key in Emacs mode." (interactive "P") (byte-code "IJêא✓ב\"ç" [arg nil vip-escape-to-emacs 27] 3))
  205.  
  206. (defun vip-ctl-c (arg) "\
  207. Emulate C-c key in Emacs mode." (interactive "P") (byte-code "IJêא✓ב\"ç" [arg nil vip-escape-to-emacs 3] 3))
  208.  
  209. (defun vip-ctl-x (arg) "\
  210. Emulate C-x key in Emacs mode." (interactive "P") (byte-code "IJêא✓ב\"ç" [arg nil vip-escape-to-emacs 24] 3))
  211.  
  212. (defun vip-ctl-h (arg) "\
  213. Emulate C-h key in Emacs mode." (interactive "P") (byte-code "IJêא✓ב\"ç" [arg nil vip-escape-to-emacs 8] 3))
  214.  
  215. (defun vip-prefix-arg-value (char value com) "\
  216. Compute numeric prefix arg value.  Invoked by CHAR.  VALUE is the value
  217. obtained so far, and COM is the command part obtained so far." (byte-code "✓דYà    ✓הXà(וז    !â⑦    é⑧חט\"✓דZ\\ë①êrë⓪êéê    ë②ê♪à6
  218. ♪Bë②ê✓יUàHכ
  219. !êrë⓪êé7ê✓ë④ç" [char value prefix-arg com unread-command-char 48 57 * numberp 0 10 85 vip-describe-arg] 6))
  220.  
  221. (defun vip-prefix-arg-com (char value com) "\
  222. Vi operator as prefix argument." (byte-code "IJ⑧✓àE
  223. טUåE
  224. יUåE
  225. כUåE
  226. לUåE
  227. מUåE
  228. נUåE
  229. סUåE
  230. עUåE
  231. פUåE
  232. צUåE
  233. קUà√♪âh
  234. עUåU
  235. קUà[רש!ê
  236. ♪Bë③êגë⓪é≈
  237. לUåq
  238. סUâé
  239. ë③êrë②êגë⓪é≈
  240. עUâÿתr\\ë③êrë②êגë⓪é≈
  241. מUåí
  242. נUâ®
  243. ë③êrë②ê♪
  244. UàÃ
  245. ♪Bë③êגë⓪é≈
  246. קUâ≡rןXàנךXåףםXàףףXâσë⑥╱éΦרש!êrë②)é≈
  247. ë③êrë②êé⇩)êץ♪!â%⇧✓♪Bë⑥◆ê
  248. §Uà⇧∧◆!êrë②êé♪⇧ê
  249. ë⑥    é∩⇧♪@פUå0⇧♪@צUâ[⇧♪@♪Aə✓♪Bë⑥◆ê
  250. פUâN⇧∞◆!éR⇧α◆!êגë⑥◆*é∩⇧✓?âe⇧βég⇧✓ë⑥✓êגë⑥◆êΓ♪π\"âÇ⇧Σ✓σB!é∩⇧Γ♪µ\"âÉ⇧Σ✓τB!é∩⇧Γ♪Φ\"â£⇧Θ é∩⇧Γ♪Ω\"â¼⇧Σ✓δB!é∩⇧Γ♪∮\"â¶⇧Σ✓מB!é∩⇧Γ♪ϕ\"âכ⇧Σ✓נB!é∩⇧Γ♪∈\"âץ⇧Σ✓לB!é∩⇧Γ♪∩\"â∮⇧Σ✓סB!é∩⇧רש!ç" [cont t char com nil reg vip-use-register prefix-arg value unread-command-char 99 100 121 33 60 62 61 35 114 82 34 error "" 128 65 122 49 57 atom 85 vip-describe-arg vip-region vip-Region 1 equal (99 . 99) vip-line 67 (100 . 100) 68 (100 . 121) vip-yank-defun (121 . 121) 89 (60 . 60) (62 . 62) (33 . 33) (61 . 61)] 24))
  251.  
  252. (defun vip-describe-arg (arg) (byte-code "בב⑨⑧ג
  253. !⓪ד
  254. !ë①ê✓?â%    ?âהו!é\"הז    \"é6    ?â1הח✓\"é6הט✓    #*ç" [val com arg nil vip-P-val vip-getcom message "Value is nil, and commmand is nil." "Value is nil, and command is %c." "Value is %d, and command is nil." "Value is %d, and command is %c."] 9))
  255.  
  256. (defun vip-digit-argument (arg) "\
  257. Begin numeric argument for the next command." (interactive "P") (byte-code "IJêב✓IJ
  258. :â
  259. Aé⓪IJ#ç" [last-command-char nil arg vip-prefix-arg-value] 4))
  260.  
  261. (defun vip-command-argument (arg) "\
  262. Accept a motion command as an argument." (interactive "P") (byte-code "ijêIJאבÅç" [nil conditions (byte-code "ג✓    ?â♪אé\"    :â⑤    @é\"ד    !â    é\"הו!    ?â+אéB    :â5    AéBד    !â?אéBהו!#ç" [last-command-char arg nil t vip-prefix-arg-com numberp error "strange arg"] 8) ((quit (byte-code "IJë⓪êאבIJ\"ç" [vip-use-register nil signal quit] 3)))] 3))
  263.  
  264. (defun vip-p-val (arg) "\
  265. Get value part of prefix-argument ARG." (byte-code "✓?â    אé✓:â✓@?â⑧אéə✓@é✓ç" [arg t 1] 1))
  266.  
  267. (defun vip-P-val (arg) "\
  268. Get value part of prefix-argument ARG." (byte-code "✓:â
  269. ✓@é♪✓ç" [arg t] 1))
  270.  
  271. (defun vip-getcom (arg) "\
  272. Get com part of prefix-argument ARG." (byte-code "✓?â    IJé④✓:â③✓Aé④IJç" [arg nil t] 1))
  273.  
  274. (defun vip-getCom (arg) "\
  275. Get com part of prefix-argument ARG and modify it." (byte-code "ב    !⑧ג✓ד\"âהé&ג✓ו\"âəזé&ג✓ח\"â%טé&✓)ç" [com arg t vip-getcom equal 99 67 100 68 121 89] 6))
  276.  
  277. (defun vip-append-to-register (reg start end) "\
  278. Append region to text in register REG.
  279. START and END are buffer positions indicating what to append." (byte-code "ב✓ג✓!å    דה    
  280. \"P\"ç" [reg start end set-register get-register "" buffer-substring] 7))
  281.  
  282. (defun vip-execute-com (m-com val com) "\
  283. (M-COM VAL COM)  Execute command COM. The list (M-COM VAL COM) is set
  284. to vip-d-com for later use by vip-repeat" (byte-code "    ⑧
  285. àŒ⇩
  286. לUâ③מ♪`\"éŒ⇩
  287. ל[Uâ!נ♪`\"éŒ⇩
  288. סUå+
  289. ס[Uâæèע♪!êפצ `\"ê    àuק    XàF    רXâSש    צ `ג$éqת    Xà\\    ןXâjך    ם\\צ `#éqגë①êףץ!êגë①ê§צ `\")ê∧∞!ê
  290. סUâîα éÄβ éŒ⇩
  291. ΓUâ∈    àעק    Xàñ    רXâãש    ♪`ג$éלת    Xਠ   ןXâהך    ם\\♪`#éלגë①êףץ!êגë①ê╱π=â§Σé∧גë⑥╱êΣ♪`\"êπë⑥◆éŒ⇩
  292. σUâd⇧èע♪!êפצ `\"ê    à;⇧ק    Xà ⇧    רXâ⑨⇧ש    צ `ג$é7⇧ת    Xà\"⇧    ןXâ0⇧ך    ם\\צ `#é7⇧גë①êףץ!êגë①ê╱µ=âG⇧ΣéH⇧גë⑥╱êΣצ `\"ê✓τ=à]⇧µë⑥◆)êΦ éŒ⇩
  293. ΘUâœ⇧    àñ⇧ק    Xàw⇧    רXââ⇧ש    ♪`ג$éá⇧ת    Xàî⇧    ןXâÖ⇧ך    ם\\♪`#éá⇧גë①êףץ!êגë①êגë⑥╱êΩ♪`\"ê♪béŒ⇩
  294. δUâ③⇩èע♪!êפצ `\"ê    à⇧⇩ק    Xàפ⇧    רXâ∞⇧ש    צ `ג$é²⇧ת    XàΦ⇧    ןXâ÷⇧ך    ם\\צ `#é²⇧גë①êףץ!êגë①êגë⑥╱êΩצ `\")ê♪béŒ⇩
  295. ∮Uå⇩
  296. ∮[UâF⇩èע♪!êפצ `\"êϕצ `
  297. ∮Uâ>⇩∈∩!ë⑥    é@⇩    ד$)éŒ⇩
  298. ≡Uâk⇩èע♪!êפצ `\"êצ `Và`⇩± ê≥צ `ג#)éŒ⇩
  299. ≤Uâï⇩èע♪!êפצ `\"ê⌠צ `
  300. [#)ê♪béŒ⇩
  301. ⌡Uâ¬⇩èע♪!êפצ `\"ê⌠צ `
  302. #)ê♪béŒ⇩
  303. ÷YàŒ⇩≈
  304. ÷Z!ê✓
  305. לUåח⇩
  306. סUåח⇩
  307. ∮Uâע⇩
  308. [éפ⇩
  309. ✓Fë⑥♪)ç" [reg vip-use-register com vip-com-point nil t last-command this-command m-com vip-last-shell-com vip-shift-width vip-d-com val 99 vip-change vip-change-subr 67 set-mark vip-enlarge-region mark 97 122 copy-to-register 65 90 vip-append-to-register 32 error "" delete-region open-line 1 vip-change-mode-to-insert yank 100 d-command kill-region 68 D-command vip-line back-to-indentation 121 copy-region-as-kill 89 33 shell-command-on-region vip-read-string "!" 61 exchange-point-and-mark indent-region 60 indent-rigidly 62 128 vip-special-prefix-com] 72))
  310.  
  311. (defun vip-repeat (arg) "\
  312. (ARG)  Re-excute last destructive command.  vip-d-com has the form
  313. (COM ARG CH REG), where COM is the command to be re-executed, ARG is the
  314. argument for COM, CH is a flag for repeat, and REG is optional and if exists
  315. is the name of the register for COM." (interactive "P") (byte-code "זê✓ח=âט é?
  316. @י !
  317. AA@כ
  318. 8╱⑨♪?à(
  319. A@ë③ê    ?à1למ!ê╱ë⑥◆êנ    ♪B\",ç" [last-command m-com vip-d-com val arg com reg vip-use-register nil vip-undo vip-undo-more vip-P-val 3 error "No previous command to repeat." funcall] 7))
  320.  
  321. (defun vip-special-prefix-com (char) "\
  322. This command is invoked interactively by the key sequence #<char>" (byte-code "✓אUâ①ב    `^    `]\"éJ✓גUâ\"ד    `^    `]\"éJ✓הUâ1ו    !êז éJ✓חUâ@ו    !êט éJ✓יUàJכ    `\"ç" [char vip-com-point 99 downcase-region 67 upcase-region 103 set-mark vip-global-execute 113 vip-quote-region 115 spell-region] 9))
  323.  
  324. (defun vip-undo nil "\
  325. Undo previous change." (interactive) (byte-code "IJêאב!êג êדה!êוë⓪ç" [this-command nil message "undo!" undo-start undo-more 2 vip-undo] 5))
  326.  
  327. (defun vip-undo-more nil "\
  328. Continue undoing previous changes." (byte-code "IJא!êבג!êדë⓪ç" [this-command message "undo more!" undo-more 1 vip-undo] 4))
  329.  
  330. (defun vip-string-tail (str) (byte-code "✓?å    א✓ב\"â⓪IJé④✓גIJOç" [str nil string= "" 1] 4))
  331.  
  332. (defun vip-yank-defun nil (byte-code "ij êIJ`א \"ç" [mark-defun copy-region-as-kill mark] 5))
  333.  
  334. (defun vip-enlarge-region (beg end) "\
  335. Enlarge region between BEG and END." (byte-code "✓    Wâ✓bêא    !é⑤    bêא✓!êב êג êm?å#n?à)דה!êב ê✓    Và5ג ç" [beg end set-mark beginning-of-line exchange-point-and-mark next-line 1] 8))
  336.  
  337. (defun vip-global-execute nil "\
  338. Call last keyboad macro for each line in the region." (byte-code "`ij Và    IJ êא êב ê`ij Wà$גד!êא êב êé⓪ç" [mark exchange-point-and-mark beginning-of-line call-last-kbd-macro forward-line 1] 10))
  339.  
  340. (defun vip-quote-region nil "\
  341. Quote region by inserting the user supplied string at the beginning of
  342. each line in the region." (byte-code "אבג✓\"!⑨ד    ה\"â②✓é③    )ë⓪êו`ז \"ê`ז Và&ח ê✓cêט êיכ!ê`ז Wà9nàI✓cêט êיכ!êé1ç" [vip-quote-string str vip-read-string format "quote string (default \"%s\"): " string= "" vip-enlarge-region mark exchange-point-and-mark beginning-of-line forward-line 1] 14))
  343.  
  344. (defun vip-end-with-a-newline-p (string) "\
  345. Check if the string ends with a newline." (byte-code "א✓ב\"å        GSHגUç" [text string string= "" 10] 3))
  346.  
  347. (defun vip-read-string (prompt &optional init) (byte-code "ב    !ë⓪êג    דה#êג    וז#êג    חט#êיəכלמÅê✓ë①ê
  348. )ç" [save-minibuffer-local-map minibuffer-local-map str copy-keymap define-key "✓" backward-char "⑦" backward-word "" exit-minibuffer nil conditions (byte-code "ב    
  349. \"ë⓪ç" [str prompt init read-string] 3) ((quit (byte-code "    ë⓪êבגא\"ç" [minibuffer-local-map save-minibuffer-local-map nil signal quit] 3)))] 7))
  350.  
  351. (defun vip-repeat-insert-command nil "\
  352. This function is called when mode changes from insertion mode to
  353. vi command mode.  It will repeat the insertion command if original insertion
  354. command was invoked with argument > 1." (byte-code "    @    A@ə⑧
  355. à
  356. גVà#✓
  357. SדEë①êהב!ê✓
  358. דEë①*ç" [i-com vip-d-com val nil 1 114 vip-repeat] 4))
  359.  
  360. (defun vip-insert (arg) "\
  361. " (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③ê
  362. â,✓ טVà(י ê Së④êé⑦)é.כ *ç" [val arg com vip-d-com count nil vip-p-val vip-getcom vip-insert 114 0 yank vip-change-mode-to-insert] 6))
  363.  
  364. (defun vip-append (arg) "\
  365. Append after point." (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③êl?à⑧ט êי
  366. ח\"â7✓ כVà3ל ê Së④êé\")é9מ *ç" [val arg com vip-d-com count nil vip-p-val vip-getcom vip-append 114 forward-char equal 0 yank vip-change-mode-to-insert] 8))
  367.  
  368. (defun vip-Append (arg) "\
  369. Append at end of line." (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③êט êי
  370. ח\"â2✓ כVà.ל ê Së④êé)é4מ *ç" [val arg com vip-d-com count nil vip-p-val vip-getcom vip-Append 114 end-of-line equal 0 yank vip-change-mode-to-insert] 8))
  371.  
  372. (defun vip-Insert (arg) "\
  373. Insert before first non-white." (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③êט êי
  374. ח\"â2✓ כVà.ל ê Së④êé)é4מ *ç" [val arg com vip-d-com count nil vip-p-val vip-getcom vip-Insert 114 back-to-indentation equal 0 yank vip-change-mode-to-insert] 8))
  375.  
  376. (defun vip-open-line (arg) "\
  377. Open line below." (interactive "P") (byte-code "וêז    !ח    !ə⑧ט✓יEë③êכ ל
  378. י\"âA✓מVà=נ êסע!ê╱à1 jêפ êSë⑤êé)éRנ êסע!ê╱àO jêצ )*ç" [val arg com vip-d-com col count vip-open-with-indent nil vip-p-val vip-getcom vip-open-line 114 current-indentation equal 0 end-of-line newline 1 yank vip-change-mode-to-insert] 11))
  379.  
  380. (defun vip-Open-line (arg) "\
  381. Open line above." (interactive "P") (byte-code "וêז    !ח    !ə⑧ט✓יEë③êכ ל
  382. י\"âA✓מVà=נ êסע!ê╱à1 jêפ êSë⑤êé)éRנ êסע!ê╱àO jêצ )*ç" [val arg com vip-d-com col count vip-open-with-indent nil vip-p-val vip-getcom vip-Open-line 114 current-indentation equal 0 beginning-of-line open-line 1 yank vip-change-mode-to-insert] 11))
  383.  
  384. (defun vip-open-line-at-point (arg) "\
  385. Open line at point." (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③êט
  386. ח\"â3✓ יVà/כל!êמ ê Së④êéə)é9כל!êנ *ç" [val arg com vip-d-com count nil vip-p-val vip-getcom vip-open-line-at-point 114 equal 0 open-line 1 yank vip-change-mode-to-insert] 8))
  387.  
  388. (defun vip-substitute (arg) "\
  389. Substitute characters." (interactive "P") (byte-code "גêד    !ה    !ə⑧èו`!êז✓!êח
  390. ט\"â\"יכ `\"é'לכ `\")êמ✓טEë③*ç" [val arg com vip-d-com nil vip-p-val vip-getcom set-mark forward-char equal 114 vip-change-subr mark vip-change vip-substitute] 12))
  391.  
  392. (defun vip-substitute-line (arg) "\
  393. Substitute lines." (interactive "p") (byte-code "IJêא✓בB!ç" [arg nil vip-line 67] 3))
  394.  
  395. (defun vip-line (arg) (byte-code "    @    Aə⑧ג♪`\"êד✓S!êהו✓
  396. #*ç" [val arg com vip-com-point move-marker next-line vip-execute-com vip-line] 6))
  397.  
  398. (defun vip-yank-line (arg) "\
  399. Yank ARG lines (in vi's sense)" (interactive "P") (byte-code "אêב    !⑧ג✓דB!)ç" [val arg nil vip-p-val vip-line 89] 4))
  400.  
  401. (defun vip-region (arg) (interactive "P") (byte-code "גêד    !ה    !ə⑧ו♪`\"êז êחט✓
  402. #*ç" [val arg com vip-com-point nil vip-P-val vip-getcom move-marker exchange-point-and-mark vip-execute-com vip-region] 8))
  403.  
  404. (defun vip-Region (arg) (interactive "P") (byte-code "גêד    !ה    !ə⑧ו♪`\"êז êחט✓
  405. #*ç" [val arg com vip-com-point nil vip-P-val vip-getCom move-marker exchange-point-and-mark vip-execute-com vip-Region] 8))
  406.  
  407. (defun vip-replace-char (arg) "\
  408. Replace the following ARG chars by the character read." (interactive "P") (byte-code "דêה    !ו    !ə⑧ז✓חEë③êטי
  409. ח\"â ér✓\"*ç" [val arg com vip-d-com vip-d-char nil vip-p-val vip-getcom vip-replace-char 114 vip-replace-char-subr equal] 6))
  410.  
  411. (defun vip-replace-char-subr (char arg) (byte-code "ד✓IJ\"ê♪ë②ê✓הVâ③✓é⑤✓[ הVà'♪cê Së④êé⑥)êו✓!ç" [arg t vip-d-char char count delete-char 0 backward-char] 4))
  412.  
  413. (defun vip-replace-string nil "\
  414. Replace string.  If you supply null string as the string to be replaced,
  415. the query replace mode will toggle between string replace and regexp replace." (interactive) (byte-code "אêא⑧ב    âגéד!ë⓪êה✓ו\"â/    ?ë①êזחט    â)יé*כ\"!éH    â?ל✓בחמ✓\"!\"éHנ✓בחס✓\"!\")ç" [str vip-re-replace nil vip-read-string "Replace regexp: " "Replace string: " string= "" message format "Replace mode changed to %s." "regexp replace" "string replace" replace-regexp "Replace regexp \"%s\" with: " replace-string "Replace \"%s\" with: "] 13))
  416.  
  417. (defun vip-forward-char (arg) "\
  418. Move point right ARG characters (left if ARG negative).On reaching end
  419. of buffer, stop and signal error." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  420. à②ו♪`\"êז✓!ê
  421. à חט✓
  422. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker forward-char vip-execute-com vip-forward-char] 8))
  423.  
  424. (defun vip-backward-char (arg) "\
  425. Move point left ARG characters (right if ARG negative).  On reaching
  426. beginning of buffer, stop and signal error." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  427. à②ו♪`\"êז✓!ê
  428. à חט✓
  429. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker backward-char vip-execute-com vip-backward-char] 8))
  430.  
  431. (defun vip-forward-word (arg) "\
  432. Forward word." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  433. à②ו♪`\"êז✓!êחט!ê
  434. àQ
  435. יUå)
  436. י[Uà3כל!êזל!ê
  437. מUå=
  438. נUàKכל!êזל!êחס!êעפ✓
  439. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker forward-word skip-chars-forward "     
  440. " 99 backward-word 1 100 121 "     " vip-execute-com vip-forward-word] 14))
  441.  
  442. (defun vip-end-of-word (arg) "\
  443. Move point to end of current word." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  444. à②ו♪`\"êז êח✓!êט ê
  445. à)ז êיכ✓
  446. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker forward-char forward-word backward-char vip-execute-com vip-end-of-word] 11))
  447.  
  448. (defun vip-backward-word (arg) "\
  449. Backward word." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  450. à②ו♪`\"êז✓!ê
  451. à חט✓
  452. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker backward-word vip-execute-com vip-backward-word] 8))
  453.  
  454. (defun vip-forward-Word (arg) "\
  455. Forward word delimited by white character." (interactive "P") (byte-code "גêה    !ו    !ə⑧
  456. à②ז♪`\"êחטגד✓$ê
  457. àP
  458. יUå(
  459. י[Uà2כל!êמל!ê
  460. נUå<
  461. סUàJכל!êמל!êעפ!êצק✓
  462. #*ç" [val arg com vip-com-point nil t vip-p-val vip-getcom move-marker re-search-forward "[^     
  463. ]*[     
  464. ]+" 99 backward-word 1 forward-word 100 121 skip-chars-forward "     " vip-execute-com vip-forward-Word] 13))
  465.  
  466. (defun vip-end-of-Word (arg) "\
  467. Move forward to end of word delimited by white character." (interactive "P") (byte-code "גêה    !ו    !ə⑧
  468. à②ז♪`\"êח êטיגד✓$à!כ ê
  469. à.ח êלמ✓
  470. #*ç" [val arg com vip-com-point nil t vip-p-val vip-getcom move-marker forward-char re-search-forward "[^     
  471. ]+" backward-char vip-execute-com vip-end-of-Word] 11))
  472.  
  473. (defun vip-backward-Word (arg) "\
  474. Backward word delimited by white character." (interactive "P") (byte-code "גêה    !ו    !ə⑧
  475. à②ז♪`\"êחטגד✓$â!י é#ebê
  476. à-כל✓
  477. #*ç" [val arg com vip-com-point nil t vip-p-val vip-getcom move-marker re-search-backward "[     
  478. ]+[^     
  479. ]+" forward-char vip-execute-com vip-backward-Word] 9))
  480.  
  481. (defun vip-beginning-of-line (arg) "\
  482. Go to beginning of line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  483. à②ו♪`\"êז✓!ê
  484. à חט✓
  485. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker beginning-of-line vip-execute-com vip-beginning-of-line] 8))
  486.  
  487. (defun vip-bol-and-skip-white (arg) "\
  488. Beginning of line at first non-white character." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  489. à②ו♪`\"êז ê
  490. àחט✓
  491. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker back-to-indentation vip-execute-com vip-bol-and-skip-white] 8))
  492.  
  493. (defun vip-goto-eol (arg) "\
  494. Go to end of line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  495. à②ו♪`\"êז✓!ê
  496. à חט✓
  497. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker end-of-line vip-execute-com vip-goto-eol] 8))
  498.  
  499. (defun vip-next-line (arg) "\
  500. Go to next line." (interactive "P") (byte-code "דêה    !ו    !ə⑧
  501. à②ז♪`\"êח✓!êטë④ê
  502. à$יכ✓
  503. #*ç" [val arg com vip-com-point this-command nil vip-p-val vip-getCom move-marker line-move next-line vip-execute-com vip-next-line] 8))
  504.  
  505. (defun vip-next-line-at-bol (arg) "\
  506. Next line at beginning of line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  507. à②ו♪`\"êז✓!êח ê
  508. à#טי✓
  509. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker next-line back-to-indentation vip-execute-com vip-next-line-at-bol] 9))
  510.  
  511. (defun vip-previous-line (arg) "\
  512. Go to previous line." (interactive "P") (byte-code "דêה    !ו    !ə⑧
  513. à②ז♪`\"êח✓[!êטë④ê
  514. à%יכ✓
  515. #*ç" [val arg com vip-com-point this-command nil vip-p-val vip-getCom move-marker next-line previous-line vip-execute-com vip-previous-line] 8))
  516.  
  517. (defun vip-previous-line-at-bol (arg) "\
  518. Previous line at beginning of line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  519. à②ו♪`\"êז✓[!êח ê
  520. à$טי✓
  521. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker next-line back-to-indentation vip-execute-com vip-previous-line] 9))
  522.  
  523. (defun vip-change-to-eol (arg) "\
  524. Change to end of line." (interactive "P") (byte-code "IJêא✓בB!ç" [arg nil vip-goto-eol 99] 3))
  525.  
  526. (defun vip-kill-line (arg) "\
  527. Delete line." (interactive "P") (byte-code "IJêא✓בB!ç" [arg nil vip-goto-eol 100] 3))
  528.  
  529. (defun vip-goto-line (arg) "\
  530. Go to ARG's line.  Without ARG go to end of buffer." (interactive "P") (byte-code "גêד    !ה    !ə⑧ו♪`\"êז`!ê✓?âdbé$ebêח✓S!êט ê
  531. à1יכ✓
  532. #*ç" [val arg com vip-com-point nil vip-P-val vip-getCom move-marker set-mark forward-line back-to-indentation vip-execute-com vip-goto-line] 10))
  533.  
  534. (defun vip-find-char (arg char forward offset) "\
  535. Find ARG's occurence of CHAR on the current line.  If FORWARD then
  536. search is forward, otherwise backward.  OFFSET is used to adjust point
  537. after search." (byte-code "    â✓✓é
  538. ✓[גə⑧èî✓וVâ-זlâ חט!é!`יכ!êל ê`\"é>זnâ8חט!é9`ל ê`\"ê✓וVâKeTbéMdbêגמנ!גו✓$)ê`ë②ê✓וVàg
  539. dUås✓וWàs
  540. eUàyחט!))ê
  541. ✓וVâÉ╱âîסéìעéÜ╱âÖכéÜו\\b*ç" [arg forward point case-fold-search nil char offset 0 narrow-to-region error "" next-line 1 beginning-of-line search-forward char-to-string -2 -1] 13))
  542.  
  543. (defun vip-find-char-forward (arg) "\
  544. Find char on the line.  If called interactively read the char to find
  545. from the terminal, and if called from vip-repeat, the char last used is
  546. used.  This behaviour is controlled by the sign of prefix numeric value." (interactive "P") (byte-code "וêט    !י    !ə⑧✓כVâr③ד④וë⑥╱é✓[ë⓪ê
  547. à)ל✓`\"êמ✓ט    !כVâ8♪é:    דו$ê✓[ë⓪ê
  548. àT♪ë⑥    êנ êסע✓
  549. #*ç" [val arg com vip-f-char vip-f-forward t vip-f-offset nil vip-com-point vip-F-char vip-p-val vip-getcom 0 move-marker vip-find-char forward-char vip-execute-com vip-find-char-forward] 10))
  550.  
  551. (defun vip-goto-char-forward (arg) "\
  552. Go up to char ARG forward on line." (interactive "P") (byte-code "חêט    !י    !ə⑧✓כVâr③ד④דë⑥╱é✓[ë⓪ê
  553. à)ל◆`\"êמ✓ט    !כVâ8♪é:✓דד$ê✓[ë⓪ê
  554. àT♪ë⑥✓êנ êסע✓
  555. #*ç" [val arg com vip-f-char vip-f-forward t vip-f-offset vip-com-point vip-F-char nil vip-p-val vip-getcom 0 move-marker vip-find-char forward-char vip-execute-com vip-goto-char-forward] 10))
  556.  
  557. (defun vip-find-char-backward (arg) "\
  558. Find char ARG on line backward." (interactive "P") (byte-code "דêח    !ט    !ə⑧✓יVâr③ד④דë⑥╱é✓[ë⓪ê
  559. à)כ◆`\"êל✓ח    !יVâ8♪é:✓דד$ê✓[ë⓪ê
  560. àQ♪ë⑥✓êמנ✓
  561. #*ç" [val arg com vip-f-char vip-f-forward nil vip-f-offset vip-com-point vip-F-char vip-p-val vip-getcom 0 move-marker vip-find-char vip-execute-com vip-find-char-backward] 9))
  562.  
  563. (defun vip-goto-char-backward (arg) "\
  564. Go up to char ARG backward on line." (interactive "P") (byte-code "דêט    !י    !ə⑧✓כVâr③ד④וë⑥╱é✓[ë⓪ê
  565. à)ל✓`\"êמ✓ט    !כVâ8♪é:    דו$ê✓[ë⓪ê
  566. àQ♪ë⑥    êנס✓
  567. #*ç" [val arg com vip-f-char vip-f-forward nil vip-f-offset t vip-com-point vip-F-char vip-p-val vip-getcom 0 move-marker vip-find-char vip-execute-com vip-goto-char-backward] 9))
  568.  
  569. (defun vip-repeat-find (arg) "\
  570. Repeat previous find command." (interactive "P") (byte-code "וêז    !ח    !ə⑧
  571. à②ט♪`\"êי✓ ╱$ê
  572. à+à%כ êלמ✓
  573. #*ç" [val arg com vip-com-point vip-f-char vip-f-forward vip-f-offset nil vip-p-val vip-getcom move-marker vip-find-char forward-char vip-execute-com vip-repeat-find] 9))
  574.  
  575. (defun vip-repeat-find-opposite (arg) "\
  576. Repeat previous find command in the opposite direction." (interactive "P") (byte-code "וêז    !ח    !ə⑧
  577. à②ט♪`\"êי✓ ?╱$ê
  578. à,à&כ êלמ✓
  579. #*ç" [val arg com vip-com-point vip-f-char vip-f-forward vip-f-offset nil vip-p-val vip-getcom move-marker vip-find-char forward-char vip-execute-com vip-repeat-find-opposite] 9))
  580.  
  581. (defun vip-other-window (arg) "\
  582. Switch to other window." (interactive "p") (byte-code "אêב✓!ê    ג=?å⑧דהp!ו\"å⑧ז ç" [arg vip-current-mode nil other-window emacs-mode string= buffer-name " *Minibuf-1*" vip-change-mode-to-vi] 5))
  583.  
  584. (defun vip-window-top (arg) "\
  585. Go to home window line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  586. à②ו♪`\"êז✓S!ê
  587. à!חט✓
  588. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker move-to-window-line vip-execute-com vip-window-top] 8))
  589.  
  590. (defun vip-window-middle (arg) "\
  591. Go to middle window line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  592. à②ו♪`\"êזחט Sי\"✓S\\!ê
  593. à(כל✓
  594. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker move-to-window-line / window-height 2 vip-execute-com vip-window-middle] 10))
  595.  
  596. (defun vip-window-bottom (arg) "\
  597. Go to last window line." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  598. à②ו♪`\"êז✓[!ê
  599. à!חט✓
  600. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker move-to-window-line vip-execute-com vip-window-bottom] 8))
  601.  
  602. (defun vip-line-to-top (arg) "\
  603. Put current line on the home line." (interactive "p") (byte-code "IJêא✓S!ç" [arg nil recenter] 2))
  604.  
  605. (defun vip-line-to-middle (arg) "\
  606. Put current line on the middle line." (interactive "p") (byte-code "IJêא✓Sבג Sד\"\\!ç" [arg nil recenter / window-height 2] 6))
  607.  
  608. (defun vip-line-to-bottom (arg) "\
  609. Put current line on the last line." (interactive "p") (byte-code "IJêאב ✓TZ!ç" [arg nil recenter window-height] 4))
  610.  
  611. (defun vip-paren-match (arg) "\
  612. Go to the matching parenthesis." (interactive "P") (byte-code "בêד    !⑧ה    !â<    וVå⑤    זWâחט!é9dיVâ.כלdמ\"    \"é5לכd    \"מ\"bêנ éàסע!â`✓àJפ
  613. `\"êצז!ê✓â[קרב✓#é]ש éàסת!âéן ê✓àqפ
  614. `\"êךז!ê✓àקרב✓#éàחם!)ç" [com arg vip-com-point nil t vip-getcom numberp 99 1 error "Prefix must be between 1 and 99." 80000 * / 100 back-to-indentation looking-at "[([{]" move-marker forward-sexp vip-execute-com vip-paren-match backward-char "[])}]" forward-char backward-sexp ""] 21))
  615.  
  616. (defun vip-forward-sentence (arg) "\
  617. Forward sentence." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  618. à②ו♪`\"êז✓!ê
  619. à חטג
  620. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker forward-sentence vip-execute-com vip-forward-sentence] 8))
  621.  
  622. (defun vip-backward-sentence (arg) "\
  623. Backward sentence." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  624. à②ו♪`\"êז✓!ê
  625. à חטג
  626. #*ç" [val arg com vip-com-point nil vip-p-val vip-getcom move-marker backward-sentence vip-execute-com vip-backward-sentence] 8))
  627.  
  628. (defun vip-forward-paragraph (arg) "\
  629. Forward paragraph." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  630. à②ו♪`\"êז✓!ê
  631. à חטג
  632. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker forward-paragraph vip-execute-com vip-forward-paragraph] 8))
  633.  
  634. (defun vip-backward-paragraph (arg) "\
  635. Backward paragraph." (interactive "P") (byte-code "גêד    !ה    !ə⑧
  636. à②ו♪`\"êז✓!ê
  637. à חטג
  638. #*ç" [val arg com vip-com-point nil vip-p-val vip-getCom move-marker backward-paragraph vip-execute-com vip-backward-paragraph] 8))
  639.  
  640. (defun vip-scroll (arg) "\
  641. Scroll to next screen." (interactive "p") (byte-code "IJê✓אVâ✓אVà⑨ב ê✓Së⓪êé✓é-א✓Và-ג ê✓Të⓪êéç" [arg nil 0 scroll-up scroll-down] 5))
  642.  
  643. (defun vip-scroll-back (arg) "\
  644. Scroll to previous screen." (interactive "p") (byte-code "IJêא✓[!ç" [arg nil vip-scroll] 2))
  645.  
  646. (defun vip-scroll-down (arg) "\
  647. Scroll up half screen." (interactive "P") (byte-code "IJê✓?â①אבג ד\"!é④א✓!ç" [arg nil scroll-down / window-height 2] 5))
  648.  
  649. (defun vip-scroll-down-one (arg) "\
  650. Scroll up one line." (interactive "p") (byte-code "IJêא✓!ç" [arg nil scroll-down] 2))
  651.  
  652. (defun vip-scroll-up (arg) "\
  653. Scroll down half screen." (interactive "P") (byte-code "IJê✓?â①אבג ד\"!é④א✓!ç" [arg nil scroll-up / window-height 2] 5))
  654.  
  655. (defun vip-scroll-up-one (arg) "\
  656. Scroll down one line." (interactive "p") (byte-code "IJêא✓!ç" [arg nil scroll-up] 2))
  657.  
  658. (defun vip-buffer-in-two-windows nil "\
  659. Show current buffer in two windows." (interactive) (byte-code "ijêIJ êאij!ç" [nil delete-other-windows split-window-vertically] 3))
  660.  
  661. (defun vip-search-forward (arg) "\
  662. Search a string forward.  ARG is used to find the ARG's occurence
  663. of the string.  Default is vanilla search.  Search mode can be toggled by
  664. giving null search string." (interactive "P") (byte-code "זêח    !ט    !ə⑧ג③י╱â⑥כé⑦ל!ë⑤êמנ\"â;╱?ë⑥╱êסעפ╱â5צé6ק\"!éQרג✓#ê
  665. àQש◆ת \"êןך✓
  666. #*ç" [val arg com vip-s-forward t vip-s-string vip-re-search vip-com-point nil vip-P-val vip-getcom vip-read-string "RE-/" "/" string= "" message format "Search mode changed to %s search." "regular expression" "vanilla" vip-search move-marker mark vip-execute-com vip-search-next] 13))
  667.  
  668. (defun vip-search-backward (arg) "\
  669. Search a string backward.  ARG is used to find the ARG's occurence
  670. of the string.  Default is vanilla search.  Search mode can be toggled by
  671. giving null search string." (interactive "P") (byte-code "גêז    !ח    !ə⑧ג③ט╱â⑥יé⑦כ!ë⑤êלמ\"â;╱?ë⑥╱êנסע╱â5פé6צ\"!éQקג✓#ê
  672. àQר◆ש \"êתן✓
  673. #*ç" [val arg com vip-s-forward nil vip-s-string vip-re-search vip-com-point vip-P-val vip-getcom vip-read-string "RE-?" "?" string= "" message format "Search mode changed to %s search." "regular expression" "vanilla" vip-search move-marker mark vip-execute-com vip-search-next] 13))
  674.  
  675. (defun vip-search (string forward arg &optional no-offset init-point) "\
  676. (STRING FORWARD COUNT &optional NO-OFFSET) Search COUNT's occurrence of
  677. STRING.  Search will be forward if FORWARD, otherwise backward." (byte-code "י    !כ    !ל    !??◆    å④`✓╱ə⑧
  678. â(מנסÅé,מעפÅ.╱ç" [val arg com null-arg offset no-offset case-fold-search vip-case-fold-search start-point init-point forward vip-p-val vip-getcom vip-P-val conditions (byte-code "✓à╱m?à♪ה ê    âו
  679. בב $êז
  680. !é'ח
  681. בב $êט
  682. !êי!ç" [offset vip-re-search string nil val start-point forward-char re-search-forward re-search-backward search-forward search-backward push-mark] 8) ((search-failed (byte-code "✓à❎    â⑧ebêז
  683. ♪ח Bד╱%é\"╱bêטי◆A\"ç" [null-arg vip-search-wrap-around string forward com t start-point conditions vip-search 1 signal search-failed] 6))) (byte-code "✓âד    אא♪$é③ה    אא♪$êו !ç" [vip-re-search string nil val start-point re-search-backward search-backward push-mark] 6) ((search-failed (byte-code "✓à❎    â⑧dbêז
  684. ♪ח Bד╱%é\"╱bêטי◆A\"ç" [null-arg vip-search-wrap-around string forward com t start-point conditions vip-search 1 signal search-failed] 6)))] 9))
  685.  
  686. (defun vip-search-next (arg) "\
  687. Repeat previous search." (interactive "P") (byte-code "דêה    !ו    !ə⑧♪?à②זח!êט♪     #ê
  688. à\"יכ✓
  689. #*ç" [val arg com vip-s-string vip-s-forward nil vip-p-val vip-getcom error "No previous search string." vip-search vip-execute-com vip-search-next] 8))
  690.  
  691. (defun vip-search-Next (arg) "\
  692. Repeat previous search in the reverse direction." (interactive "P") (byte-code "דêה    !ו    !ə⑧♪?à②זח!êט♪ ?    #ê
  693. à#יכ✓
  694. #*ç" [val arg com vip-s-string vip-s-forward nil vip-p-val vip-getcom error "No previous search string." vip-search vip-execute-com vip-search-Next] 8))
  695.  
  696. (defun vip-switch-to-buffer nil "\
  697. Switch to buffer in the current window." (interactive) (byte-code "IJêIJ⑧אבגדהp!!\"!ë⓪êו✓!êז )ç" [buffer nil read-buffer format "switch to buffer (%s): " buffer-name other-buffer switch-to-buffer vip-change-mode-to-vi] 7))
  698.  
  699. (defun vip-switch-to-buffer-other-window nil "\
  700. Switch to buffer in another window." (interactive) (byte-code "IJêIJ⑧אבגדהp!!\"!ë⓪êו✓!êז )ç" [buffer nil read-buffer format "Switch to buffer (%s): " buffer-name other-buffer switch-to-buffer-other-window vip-change-mode-to-vi] 7))
  701.  
  702. (defun vip-kill-buffer nil "\
  703. Kill a buffer." (interactive) (byte-code "אêאא⑨⑧בגדIJp!\"!ë①ê    ?âəpéה    !ë⓪ê✓?à)וז    \"êח✓!?å4טי!â=כ✓!é@ול!*ç" [buffer buffer-name nil read-buffer format "Kill buffer (%s): " get-buffer error "Buffer %s nonexistent." buffer-modified-p y-or-n-p "Buffer is modified, are you sure? " kill-buffer "Buffer not killed."] 10))
  704.  
  705. (defun vip-find-file nil "\
  706. Visit file in the current window." (interactive) (byte-code "IJêIJ⑧אב!ë⓪êגד✓!!êה )ç" [file nil read-file-name "visit file: " switch-to-buffer find-file-noselect vip-change-mode-to-vi] 5))
  707.  
  708. (defun vip-find-file-other-window nil "\
  709. Visit file in another window." (interactive) (byte-code "IJêIJ⑧אב!ë⓪êגד✓!!êה )ç" [file nil read-file-name "Visit file: " switch-to-buffer-other-window find-file-noselect vip-change-mode-to-vi] 5))
  710.  
  711. (defun vip-info-on-file nil "\
  712. Give information of the file associated to the current buffer." (interactive) (byte-code "ijêIJאב âב éגדe`\"Tדed\"T$ç" [nil message "\"%s\" line %d of %d" buffer-file-name "" count-lines] 10))
  713.  
  714. (defun vip-yank (text) "\
  715. yank TEXT silently." (byte-code "èIJ`!ê✓cêא )êבג!ç" [text vip-push-mark-silent exchange-point-and-mark skip-chars-forward "     "] 4))
  716.  
  717. (defun vip-put-back (arg) "\
  718. Put back after point/below line." (interactive "P") (byte-code "הêח    !♪â#ט♪Xà②♪יXâ♪טZ 8é כ♪!é% @ə⑧
  719. ?àA♪â>♪הë③êלמ\")éAלנ!êהë③êס
  720. !âUעפ!êצ éal?à\\m?àaק êר✓ה♪Fë⑥◆ê✓✓✓שVàâת
  721. !ê✓Së⑥✓êén)*ç" [val arg text vip-use-register kill-ring-yank-pointer reg nil vip-d-com count vip-p-val 49 57 get-register error "Nothing in register %c" "" vip-end-with-a-newline-p next-line 1 beginning-of-line forward-char vip-put-back 0 vip-yank] 12))
  722.  
  723. (defun vip-Put-back (arg) "\
  724. Put back at point/above line." (interactive "P") (byte-code "הêח    !♪â#ט♪Xà②♪יXâ♪טZ 8é כ♪!é% @ə⑧
  725. ?àA♪â>♪הë③êלמ\")éAלנ!êהë③êס
  726. !àNע êפ✓ה♪Fë⑥◆ê✓✓✓צVàpק
  727. !ê✓Së⑥✓êé[)*ç" [val arg text vip-use-register kill-ring-yank-pointer reg nil vip-d-com count vip-p-val 49 57 get-register error "Nothing in register %c" "" vip-end-with-a-newline-p beginning-of-line vip-Put-back 0 vip-yank] 10))
  728.  
  729. (defun vip-delete-char (arg) "\
  730. Delete character." (interactive "P") (byte-code "בêה    !⑧ו✓בEë②ê à6ז Xàə חXâ*ט י\\``✓Zב$é2כ ``✓Zב$êבë④êל✓ד\")ç" [val arg vip-d-com nil vip-use-register t vip-p-val vip-delete-char 65 90 vip-append-to-register 32 copy-to-register delete-char] 7))
  731.  
  732. (defun vip-delete-backward-char (arg) "\
  733. Delete previous character." (interactive "P") (byte-code "בêה    !⑧ו✓בEë②ê à6ז Xàə חXâ*ט י\\``✓\\ב$é2כ ``✓\\ב$êבë④êל✓ד\")ç" [val arg vip-d-com nil vip-use-register t vip-p-val vip-delete-backward-char 65 90 vip-append-to-register 32 copy-to-register delete-backward-char] 7))
  734.  
  735. (defun vip-join-lines (arg) "\
  736. Join this line to next, if ARG is nil.  Otherwise, join ARG lines" (interactive "*P") (byte-code "בêד    !⑧ה✓בEë②ê✓?â⑥וé⑧✓S זVà<ח êm?à3טו!êי``S\"êכ ê Së④êé⑨))ç" [val arg vip-d-com nil count vip-P-val vip-join-lines 1 0 end-of-line forward-line delete-region fixup-whitespace] 8))
  737.  
  738. (defun vip-change (beg end) (byte-code "בגדה    
  739. \"\"!ë⓪êו    
  740. \"ç" [c-string beg end vip-read-string format "%s => " buffer-substring vip-change-subr] 6))
  741.  
  742. (defun vip-change-subr (beg end) (byte-code "✓àה✓    
  743. ב$êבë⓪êו    
  744. \"êזë④êcç" [vip-use-register beg end nil this-command c-string copy-to-register kill-region vip-change] 5))
  745.  
  746. (defun vip-query-replace nil "\
  747. Query replace.  If you supply null string as the string to be replaced,
  748. the query replace mode will toggle between string replace and regexp replace." (interactive) (byte-code "אêא⑧ב    âגéד!ë⓪êה✓ו\"â-    ?ë①êזח    â(טé)י\"éF    â=כ✓בלמ✓\"!\"éFנ✓בלס✓\"!\")ç" [str vip-re-query-replace nil vip-read-string "Query replace regexp: " "Query replace: " string= "" message "Query replace mode changed to %s." "regexp replace" "string replace" query-replace-regexp format "Query replace regexp \"%s\" with: " query-replace "Query replace \"%s\" with: "] 12))
  749.  
  750. (defun vip-mark-beginning-of-buffer nil (interactive) (byte-code "ijêIJ`!êebêא êבג!ç" [nil set-mark exchange-point-and-mark message "mark set at the beginning of buffer"] 4))
  751.  
  752. (defun vip-mark-end-of-buffer nil (interactive) (byte-code "ijêIJ`!êdbêא êבג!ç" [nil set-mark exchange-point-and-mark message "mark set at the end of buffer"] 4))
  753.  
  754. (defun vip-mark-point (char) (interactive "c") (byte-code "אêב✓Xà♪✓גXâ⑧ד✓בהZZ!éS✓וUâ#ז éS✓חUâ.ט éS✓יUâ9כ éS✓לUâEמה!éS✓נUâPס éSעפ!ç" [char t nil 97 122 point-to-register 1 60 vip-mark-beginning-of-buffer 62 vip-mark-end-of-buffer 46 push-mark 44 set-mark-command 68 mark-defun error ""] 8))
  755.  
  756. (defun vip-goto-mark (arg) "\
  757. Go to mark." (interactive "P") (byte-code "בêrג
  758. !⑨⑧ד✓    ב#*ç" [char com arg nil vip-getcom vip-goto-mark-subr] 5))
  759.  
  760. (defun vip-goto-mark-and-skip-white (arg) "\
  761. Go to mark and skip to first non-white on line." (interactive "P") (byte-code "גêrד
  762. !⑨⑧ה✓    ב#*ç" [char com arg t nil vip-getCom vip-goto-mark-subr] 5))
  763.  
  764. (defun vip-goto-mark-subr (char com skip-white) (byte-code "ו✓Xà    ✓זXâVp⑨
  765. à⑥ח♪`\"êט✓ויZZ!bê à&כ êל ê
  766. àRמ    p\"âEנ â>סé?עד
  767. #éRפ    !ê♪bêל êצק!)éí ?à^✓רUây
  768. àiח♪`\"êש ê
  769. àvנעד
  770. #éí àÇ✓תUâß
  771. àïח♪`\"êש êכ ê
  772. à¢נסד
  773. #éíצק!ç" [char buff com vip-com-point skip-white nil t 97 122 move-marker register-to-point 1 back-to-indentation vip-change-mode-to-vi equal vip-execute-com vip-goto-mark-and-skip-white vip-goto-mark switch-to-buffer error "" 96 exchange-point-and-mark 39] 19))
  774.  
  775. (defun vip-exchange-point-and-mark nil (interactive) (byte-code "ijêIJ êא ç" [nil exchange-point-and-mark back-to-indentation] 3))
  776.  
  777. (defun vip-keyboard-quit nil "\
  778. Abort partially formed or running command." (interactive) (byte-code "IJêIJë⓪êא ç" [vip-use-register nil keyboard-quit] 2))
  779.  
  780. (defun vip-ctl-c-equivalent (arg) "\
  781. Emulate C-c in Emacs mode." (interactive "P") (byte-code "IJêאב✓\"ç" [arg nil vip-ctl-key-equivalent "⇨"] 3))
  782.  
  783. (defun vip-ctl-x-equivalent (arg) "\
  784. Emulate C-x in Emacs mode." (interactive "P") (byte-code "IJêאב✓\"ç" [arg nil vip-ctl-key-equivalent "⑧"] 3))
  785.  
  786. (defun vip-ctl-key-equivalent (key arg) (byte-code "r⑧ה✓Xà♪✓וXà⑤✓הזZZë⓪ê
  787. ë①êחט♪ יכל✓!##!)ç" [char prefix-arg arg vip-emacs-local-map global-map key 65 90 1 command-execute vip-get-editor-command format "%s%s" char-to-string] 9))
  788.  
  789. (defun vip-delete-backward-word (arg) "\
  790. Delete previous word." (interactive "p") (byte-code "IJêèא`!êב✓!êג`ד \")ç" [arg nil set-mark backward-word delete-region mark] 6))
  791.  
  792. (set (quote vip-mode-map) (make-keymap))
  793.  
  794. (define-key vip-mode-map "⇧" (quote beginning-of-line))
  795.  
  796. (define-key vip-mode-map "⇩" (quote vip-scroll-back))
  797.  
  798. (define-key vip-mode-map "⇨" (quote vip-ctl-c))
  799.  
  800. (define-key vip-mode-map "⇦" (quote vip-scroll-up))
  801.  
  802. (define-key vip-mode-map "❎" (quote vip-scroll-up-one))
  803.  
  804. (define-key vip-mode-map "╱" (quote vip-scroll))
  805.  
  806. (define-key vip-mode-map "◆" (quote vip-keyboard-quit))
  807.  
  808. (define-key vip-mode-map "✓" (quote help-command))
  809.  
  810. (define-key vip-mode-map "" (quote vip-scroll-back))
  811.  
  812. (define-key vip-mode-map "" (quote vip-other-window))
  813.  
  814. (define-key vip-mode-map "" (quote vip-open-line-at-point))
  815.  
  816. (define-key vip-mode-map "⑤" (quote vip-scroll-down))
  817.  
  818. (define-key vip-mode-map "⑧" (quote vip-ctl-x))
  819.  
  820. (define-key vip-mode-map "⑨" (quote vip-scroll-down-one))
  821.  
  822. (define-key vip-mode-map "ə" (quote vip-change-mode-to-emacs))
  823.  
  824. (define-key vip-mode-map "" (quote vip-ESC))
  825.  
  826. (define-key vip-mode-map " " (quote vip-scroll))
  827.  
  828. (define-key vip-mode-map "!" (quote vip-command-argument))
  829.  
  830. (define-key vip-mode-map "\"" (quote vip-command-argument))
  831.  
  832. (define-key vip-mode-map "#" (quote vip-command-argument))
  833.  
  834. (define-key vip-mode-map "$" (quote vip-goto-eol))
  835.  
  836. (define-key vip-mode-map "%" (quote vip-paren-match))
  837.  
  838. (define-key vip-mode-map "&" (quote vip-nil))
  839.  
  840. (define-key vip-mode-map "'" (quote vip-goto-mark-and-skip-white))
  841.  
  842. (define-key vip-mode-map "(" (quote vip-backward-sentence))
  843.  
  844. (define-key vip-mode-map ")" (quote vip-forward-sentence))
  845.  
  846. (define-key vip-mode-map "*" (quote call-last-kbd-macro))
  847.  
  848. (define-key vip-mode-map "+" (quote vip-next-line-at-bol))
  849.  
  850. (define-key vip-mode-map "," (quote vip-repeat-find-opposite))
  851.  
  852. (define-key vip-mode-map "-" (quote vip-previous-line-at-bol))
  853.  
  854. (define-key vip-mode-map "." (quote vip-repeat))
  855.  
  856. (define-key vip-mode-map "/" (quote vip-search-forward))
  857.  
  858. (define-key vip-mode-map "0" (quote vip-beginning-of-line))
  859.  
  860. (define-key vip-mode-map "1" (quote vip-digit-argument))
  861.  
  862. (define-key vip-mode-map "2" (quote vip-digit-argument))
  863.  
  864. (define-key vip-mode-map "3" (quote vip-digit-argument))
  865.  
  866. (define-key vip-mode-map "4" (quote vip-digit-argument))
  867.  
  868. (define-key vip-mode-map "5" (quote vip-digit-argument))
  869.  
  870. (define-key vip-mode-map "6" (quote vip-digit-argument))
  871.  
  872. (define-key vip-mode-map "7" (quote vip-digit-argument))
  873.  
  874. (define-key vip-mode-map "8" (quote vip-digit-argument))
  875.  
  876. (define-key vip-mode-map "9" (quote vip-digit-argument))
  877.  
  878. (define-key vip-mode-map ":" (quote vip-ex))
  879.  
  880. (define-key vip-mode-map ";" (quote vip-repeat-find))
  881.  
  882. (define-key vip-mode-map "<" (quote vip-command-argument))
  883.  
  884. (define-key vip-mode-map "=" (quote vip-command-argument))
  885.  
  886. (define-key vip-mode-map ">" (quote vip-command-argument))
  887.  
  888. (define-key vip-mode-map "?" (quote vip-search-backward))
  889.  
  890. (define-key vip-mode-map "@" (quote vip-nil))
  891.  
  892. (define-key vip-mode-map "A" (quote vip-Append))
  893.  
  894. (define-key vip-mode-map "B" (quote vip-backward-Word))
  895.  
  896. (define-key vip-mode-map "C" (quote vip-ctl-c-equivalent))
  897.  
  898. (define-key vip-mode-map "D" (quote vip-kill-line))
  899.  
  900. (define-key vip-mode-map "E" (quote vip-end-of-Word))
  901.  
  902. (define-key vip-mode-map "F" (quote vip-find-char-backward))
  903.  
  904. (define-key vip-mode-map "G" (quote vip-goto-line))
  905.  
  906. (define-key vip-mode-map "H" (quote vip-window-top))
  907.  
  908. (define-key vip-mode-map "I" (quote vip-Insert))
  909.  
  910. (define-key vip-mode-map "J" (quote vip-join-lines))
  911.  
  912. (define-key vip-mode-map "K" (quote vip-kill-buffer))
  913.  
  914. (define-key vip-mode-map "L" (quote vip-window-bottom))
  915.  
  916. (define-key vip-mode-map "M" (quote vip-window-middle))
  917.  
  918. (define-key vip-mode-map "N" (quote vip-search-Next))
  919.  
  920. (define-key vip-mode-map "O" (quote vip-Open-line))
  921.  
  922. (define-key vip-mode-map "P" (quote vip-Put-back))
  923.  
  924. (define-key vip-mode-map "Q" (quote vip-query-replace))
  925.  
  926. (define-key vip-mode-map "R" (quote vip-replace-string))
  927.  
  928. (define-key vip-mode-map "S" (quote vip-switch-to-buffer-other-window))
  929.  
  930. (define-key vip-mode-map "T" (quote vip-goto-char-backward))
  931.  
  932. (define-key vip-mode-map "U" (quote vip-nil))
  933.  
  934. (define-key vip-mode-map "V" (quote vip-find-file-other-window))
  935.  
  936. (define-key vip-mode-map "W" (quote vip-forward-Word))
  937.  
  938. (define-key vip-mode-map "X" (quote vip-ctl-x-equivalent))
  939.  
  940. (define-key vip-mode-map "Y" (quote vip-yank-line))
  941.  
  942. (define-key vip-mode-map "ZZ" (quote save-buffers-kill-emacs))
  943.  
  944. (define-key vip-mode-map "[" (quote vip-nil))
  945.  
  946. (define-key vip-mode-map "\\" (quote vip-escape-to-emacs))
  947.  
  948. (define-key vip-mode-map "]" (quote vip-nil))
  949.  
  950. (define-key vip-mode-map "^" (quote vip-bol-and-skip-white))
  951.  
  952. (define-key vip-mode-map "_" (quote vip-nil))
  953.  
  954. (define-key vip-mode-map "`" (quote vip-goto-mark))
  955.  
  956. (define-key vip-mode-map "a" (quote vip-append))
  957.  
  958. (define-key vip-mode-map "b" (quote vip-backward-word))
  959.  
  960. (define-key vip-mode-map "c" (quote vip-command-argument))
  961.  
  962. (define-key vip-mode-map "d" (quote vip-command-argument))
  963.  
  964. (define-key vip-mode-map "e" (quote vip-end-of-word))
  965.  
  966. (define-key vip-mode-map "f" (quote vip-find-char-forward))
  967.  
  968. (define-key vip-mode-map "g" (quote vip-info-on-file))
  969.  
  970. (define-key vip-mode-map "h" (quote vip-backward-char))
  971.  
  972. (define-key vip-mode-map "i" (quote vip-insert))
  973.  
  974. (define-key vip-mode-map "j" (quote vip-next-line))
  975.  
  976. (define-key vip-mode-map "k" (quote vip-previous-line))
  977.  
  978. (define-key vip-mode-map "l" (quote vip-forward-char))
  979.  
  980. (define-key vip-mode-map "m" (quote vip-mark-point))
  981.  
  982. (define-key vip-mode-map "n" (quote vip-search-next))
  983.  
  984. (define-key vip-mode-map "o" (quote vip-open-line))
  985.  
  986. (define-key vip-mode-map "p" (quote vip-put-back))
  987.  
  988. (define-key vip-mode-map "q" (quote vip-nil))
  989.  
  990. (define-key vip-mode-map "r" (quote vip-replace-char))
  991.  
  992. (define-key vip-mode-map "s" (quote vip-switch-to-buffer))
  993.  
  994. (define-key vip-mode-map "t" (quote vip-goto-char-forward))
  995.  
  996. (define-key vip-mode-map "u" (quote vip-undo))
  997.  
  998. (define-key vip-mode-map "v" (quote vip-find-file))
  999.  
  1000. (define-key vip-mode-map "w" (quote vip-forward-word))
  1001.  
  1002. (define-key vip-mode-map "x" (quote vip-delete-char))
  1003.  
  1004. (define-key vip-mode-map "y" (quote vip-command-argument))
  1005.  
  1006. (define-key vip-mode-map "zH" (quote vip-line-to-top))
  1007.  
  1008. (define-key vip-mode-map "zM" (quote vip-line-to-middle))
  1009.  
  1010. (define-key vip-mode-map "zL" (quote vip-line-to-bottom))
  1011.  
  1012. (define-key vip-mode-map "z" (quote vip-line-to-top))
  1013.  
  1014. (define-key vip-mode-map "z." (quote vip-line-to-middle))
  1015.  
  1016. (define-key vip-mode-map "z-" (quote vip-line-to-bottom))
  1017.  
  1018. (define-key vip-mode-map "{" (quote vip-backward-paragraph))
  1019.  
  1020. (define-key vip-mode-map "|" (quote vip-goto-col))
  1021.  
  1022. (define-key vip-mode-map "}" (quote vip-forward-paragraph))
  1023.  
  1024. (define-key vip-mode-map "~" (quote vip-nil))
  1025.  
  1026. (define-key vip-mode-map "" (quote vip-delete-backward-char))
  1027.  
  1028. (define-key ctl-x-map "3" (quote vip-buffer-in-two-windows))
  1029.  
  1030. (define-key ctl-x-map "    " (quote insert-file))
  1031.  
  1032. (defun vip-version nil (interactive) (byte-code "ijêIJא!ç" [nil message "VIP version 3.5 of September 15, 1987"] 2))
  1033.  
  1034. (defvar ex-token-type nil "\
  1035. type of token.  if non-nil, gives type of address.  if nil, it
  1036. is a command.")
  1037.  
  1038. (defvar ex-token nil "\
  1039. value of token.")
  1040.  
  1041. (defvar ex-addresses nil "\
  1042. list of ex addresses")
  1043.  
  1044. (defvar ex-flag nil "\
  1045. flag for ex flag")
  1046.  
  1047. (defvar ex-buffer nil "\
  1048. name of ex buffer")
  1049.  
  1050. (defvar ex-count nil "\
  1051. value of ex count")
  1052.  
  1053. (defvar ex-g-flag nil "\
  1054. flag for global command")
  1055.  
  1056. (defvar ex-g-variant nil "\
  1057. if t global command is executed on lines not matching ex-g-pat")
  1058.  
  1059. (defvar ex-reg-exp nil "\
  1060. save reg-exp used in substitute")
  1061.  
  1062. (defvar ex-repl nil "\
  1063. replace pattern for substitute")
  1064.  
  1065. (defvar ex-g-pat nil "\
  1066. pattern for global command")
  1067.  
  1068. (defvar ex-map (make-sparse-keymap) "\
  1069. save commnads for mapped keys")
  1070.  
  1071. (defvar ex-tag nil "\
  1072. save ex tag")
  1073.  
  1074. (defvar ex-file nil)
  1075.  
  1076. (defvar ex-variant nil)
  1077.  
  1078. (defvar ex-offset nil)
  1079.  
  1080. (defvar ex-append nil)
  1081.  
  1082. (defun vip-nil nil (interactive) (byte-code "ijêIJא!ç" [nil error ""] 2))
  1083.  
  1084. (defun vip-looking-back (str) "\
  1085. returns t if looking back reg-exp STR before point." (byte-code "èב✓IJא#)à`גד!Uç" [str nil t re-search-backward match-end 0] 4))
  1086.  
  1087. (defun vip-check-sub (str) "\
  1088. check if ex-token is an initial segment of STR" (byte-code "    G⑧✓
  1089. GXà①ג    
  1090. ד✓O\"âə
  1091. ë①éהë③)ç" [length ex-token str ex-token-type string= 0 "non-command"] 5))
  1092.  
  1093. (defun vip-get-ex-com-subr nil "\
  1094. get a complete ex command" (byte-code "ב`!êגד!êהë⓪êו`ז \"ë①êח êטי!â;טכ!â)למ!é8טנ!â5לס!é8לע!éx⇩טפ!âGצë⓪éx⇩טק!â_טר!âYלש!é\\לת!éx⇩טן!âkלך!éx⇩טם!ââטף!â}לף!éÇלץ!éx⇩ט§!âÅל∧!éx⇩ט∞!â¢לα!éx⇩טβ!âºלΓ!éx⇩טπ!âøלΣ!éx⇩טσ!â™לµ!éx⇩טτ!âπטΦ!âעלΦ!éαטΘ!â§לΩ!éαלδ!éx⇩ט∮!â√טϕ!â⌡ל∈!é°ל∩!éx⇩ט≡!â◆⇧ל±!éx⇩ט≥!â+⇧ט≤!â⑨⇧ל⌠!é(⇧ט⌡!â%⇧ל÷!é(⇧ל≈!éx⇩ט°!â7⇧ל∙!éx⇩ט·!â[⇧ט√!âI⇧לⁿ!éX⇧ט²!âU⇧ל³!éX⇧ל¯!éx⇩טü@!â½⇧טüA!âs⇧לüB!é¿⇧טüC!ââ⇧לüD!é¿⇧טüE!âô⇧לüF!é¿⇧טüG!âú⇧לüH!é¿⇧לüI!éx⇩טüJ!âי⇧טüK!âב⇧לüL!éז⇧לüJ!éx⇩טüM!â√⇧טüN!âπ⇧לüO!é°⇧טüP!â≤⇧לüQ!é°⇧לüR!éx⇩טüS!â+⇩טüT!â③⇩לüU!é(⇩טüV!â#⇩לüW!é(⇩לüS!éx⇩טüX!âK⇩טüY!âC⇩לüY!éH⇩לüZ!éx⇩טü[!â[⇩לü\\!éx⇩טü]!âk⇩לü^!éx⇩טü_!àx⇩לü_!êח ç" [ex-token-type ex-token t set-mark re-search-forward "[a-z][a-z]*" "command" buffer-substring mark exchange-point-and-mark looking-at "a" "ab" vip-check-sub "abbreviate" "ar" "args" "append" "[bh]" "non-command" "c" "co" "copy" "change" "d" "delete" "e" "ex" "edit" "f" "file" "g" "global" "i" "insert" "j" "join" "l" "list" "m" "map" "mar" "mark" "move" "n" "nu" "number" "next" "o" "open" "p" "pre" "preserve" "pu" "put" "print" "q" "quit" "r" "rec" "recover" "rew" "rewind" "read" "s" "se" "set" "sh" "shell" "so" "source" "st" "stop" "substitute" "t" "ta" "tag" "u" "una" "unabbreviate" "unm" "unmap" "undo" "v" "ve" "version" "vi" "visual" "w" "wq" "write" "x" "xit" "y" "yank" "z"] 96))
  1095.  
  1096. (defun vip-get-ex-token nil "\
  1097. get an ex-token which is either an address or a command.
  1098. a token has type (command, address, end-mark) and value." (byte-code "דïç" [ex-token-type ex-token t cont nil ((byte-code "דqêהו!êזח!âטë⓪êיg!ë①êכל!é③⇩זמ!â(נ é③⇩זס!â8כל!êעë⓪é③⇩זפ!âlצ`!êקר!êש✓ת\"âQןé]ש✓ך\"â\\םé]ףë⓪êץ§`∧ \"!ë①é③⇩ז∞!â|כל!êαë⓪é③⇩זβ!âîכל!êΓë⓪é③⇩זπ!âדזΣ!å¢זσ!â»כל!êµcêτל!êתë⓪éאזΦ!â™כל!êתë⓪éאΘΩ!é③⇩זδ!â³ז∮!åקזϕ!âΦכל!êµcêτל!êךë⓪é√ז∈!â°כל!êךë⓪é√ΘΩ!é③⇩ז∩!âG⇧כל!êצ`!êאl?à④⇧♪à)⇧ק≡!ê±≥!?à%⇧גë③êé⇧)êτל!ê§`∧ \"ë①êז∩!à@⇧כל!ê≤ë⓪é③⇩ז⌠!âÆ⇧כל!êצ`!êאl?à]⇧♪àü⇧ק⌡!ê±÷!?àn⇧גë③êτל!êז≈!?à}⇧כל!êéW⇧)ê°ë⓪ê§`S∧ \"ë①é③⇩ז∙!âó⇧כל!ê·ë⓪é③⇩ז√!âØ⇧כל!êⁿë⓪é③⇩ז²!âז⇧טë⓪êיg!ë①êכל!é③⇩ז³!â·⇧¯ë⓪êכל!êז³!âΓ⇧גë①é≤⇧זמ!â∈⇧gë①é≤⇧Θü@!êכל!é③⇩ז≈!â⇩üAë⓪êüBë①é③⇩ΘüC!ç" [ex-token-type ex-token t cont nil " *ex-working-space*" skip-chars-forward "     " looking-at "[k#]" "command" char-to-string forward-char 1 "[a-z]" vip-get-ex-com-subr "\\." "dot" "[0-9]" set-mark re-search-forward "[0-9]*" string= "plus" "add-number" "minus" "sub-number" "abs-number" string-to-int buffer-substring mark "\\$" "end" "%" "whole" "+" "+[-+]" "+[
  1099. |]" "1" backward-char "+[0-9]" error "Badly formed address" "-" "-[-+]" "-[
  1100. |]" "-[0-9]" "/" "[^/]*\\(/\\|
  1101. \\)" vip-looking-back "[^\\\\]\\(\\\\\\\\\\)*\\\\/" "search-forward" "\\?" "[^\\?]*\\(\\?\\|
  1102. \\)" "[^\\\\]\\(\\\\\\\\\\)*\\\\\\?" "
  1103. " "search-backward" "," "comma" ";" "semi-colon" "[!=><&~]" "'" "goto-mark" "Marks are ' and a-z" "end-mark" "goto" "illegal token"] 72))] 1))
  1104.  
  1105. (defun vip-ex (&optional string) "\
  1106. ex commands within VIP." (interactive) (byte-code "אê✓å♪א①אë③ê✓å③למ!או`✓╱נïêסë⑥    êאë⑥
  1107. ê╱à⌡ע êפ    צ\"å>פ    ק\"â{àL
  1108. Bë⑥
  1109. êפ♪ר\"â`שא!êאë⑥╱éxפ♪ת\"âsשו!êאë⑥╱éxן êךïé±פ    ם\"âìףץ§♪\"!é±פ    ∧\"âíde
  1110. BBë⑥
  1111. é±פ    ∞\"â¶?âØ`éø
  1112. Bë⑥
  1113. é±פ    α\"âαàכë⑥✓ê?âש`éת
  1114. Bë⑥
  1115. é±β✓\"  à≡ ë⑤)êé),ç" [string ex-g-flag nil ex-g-variant com-str address cont t dot ex-token-type ex-addresses ex-token ans vip-read-string ":" ((byte-code "IJא!qêבed\"êג✓ד\"êebç" [com-str get-buffer-create " *ex-working-space*" delete-region insert "
  1116. "] 5)) "" vip-get-ex-token string= "command" "end-mark" "global" ex-global "v" vip-execute-ex-command ((byte-code "בqêגד!êהו!â③זח!é\"הט!âIJë⓪é\"יכ!ç" [cont nil t " *ex-working-space*" skip-chars-forward "     " looking-at "|" forward-char 1 "
  1117. " error "Extra character at end of a command"] 6)) "non-command" error format "%s: Not an editor command" "whole" "comma" "semi-colon" vip-get-ex-address-subr] 19))
  1118.  
  1119. (defun vip-get-ex-pat nil "\
  1120. get a regular expression and set ex-variant if found" (byte-code "הïç" [ex-g-variant ex-g-flag cont t nil ex-token ((byte-code "הqêוז!êחט!à✓?⓪    ?ë①êיכ!êוז!êחל!âdיכ!êמ`!êבəl?à3
  1121. àHנס!êעפ!?àDגë②êé-)êצ `UâUקé[ר`Sצ \"ë⑤êשכ!égגë⑤ç" [ex-g-variant ex-g-flag cont t nil ex-token " *ex-working-space*" skip-chars-forward "     " looking-at "!" forward-char 1 "/" set-mark re-search-forward "[^/]*\\(/\\|
  1122. \\)" vip-looking-back "[^\\\\]\\(\\\\\\\\\\)*\\\\/" mark "" buffer-substring backward-char] 15))] 1))
  1123.  
  1124. (defun vip-get-ex-command nil "\
  1125. get an ex command" (byte-code "בïç" [ex-token-type ex-token t ((byte-code "בqêגד!à הו!êזח!êגט!â(י êכ✓ל\"à%מנ    \"é=גס!â:עg!ë①êהו!é=מפ!ç" [ex-token-type ex-token t " *ex-working-space*" looking-at "/" forward-char 1 skip-chars-forward "     " "[a-z]" vip-get-ex-com-subr string= "non-command" error "%s: not an editor command" "[!=><&~]" char-to-string "Could not find an ex command"] 12))] 1))
  1126.  
  1127. (defun vip-get-ex-opt-gc nil "\
  1128. get an ex option g or c" (byte-code "בïç" [ex-token t nil ((byte-code "בqêגד!à הו!êזח!êגט!â#טë⓪êהו!êIJé6גי!â5יë⓪êהו!êIJé6אç" [ex-token t nil " *ex-working-space*" looking-at "/" forward-char 1 skip-chars-forward "     " "g" "c"] 8))] 1))
  1129.  
  1130. (defun vip-default-ex-addresses (&optional whole-flag) "\
  1131. compute default addresses.  whole-flag means whole buffer." (byte-code "✓?â    â①deאBBé⑥``אBBë⓪é'✓A?à'✓@✓Bë⓪ç" [ex-addresses whole-flag nil] 3))
  1132.  
  1133. (defun vip-get-ex-address nil "\
  1134. get an ex-address as a marker and set ex-flag if a flag is found" (byte-code "ז א⑨⑧חë③êדë④ê    àÇט êי╱כ\"âAי♪ל\"å.י♪מ\"å.י♪נ\"â;אë④êדë①é>סע!é|י╱פ\"âOדë①é|י╱צ\"â]סק!é|י╱ר\"âkסש!é|ת✓ז \"◆◆à{◆ë⓪)êéê✓*ç" [address cont t ex-token ex-flag nil ex-token-type ans point-marker "" vip-get-ex-token string= "command" "print" "list" "#" error "address expected" "end-mark" "whole" "a trailing address is expected" "comma" "Extra characters after an address" vip-get-ex-address-subr] 17))
  1135.  
  1136. (defun vip-get-ex-address-subr (old-address dot) "\
  1137. returns an address as a point" (byte-code "IJ⑧
  1138. ♪ë②êו ז\"â⑧♪ë⓪éΓו ח\"â:è
  1139. bêט
  1140. יUâ/Sé0!êכ ë⓪)éΓו ל\"âRè
  1141. bêט[!êכ ë⓪)éΓו מ\"âvèebêיUâiיë⓪érטS!êכ ë⓪)éΓו נ\"âäס ë⓪éΓו ע\"âÅהéΓו פ\"âÜהéΓו צ\"â«èקה!êכ ë⓪)éΓו ר\"âאèקIJ!êכ ë⓪)éΓו ש\"àΓè?âקת éץןךםZZ!bêכ ë⓪)ê✓)ç" [address nil old-address dot ex-token-type ex-token t string= "dot" "add-number" forward-line 0 point-marker "sub-number" "abs-number" "end" point-max-marker "plus" "minus" "search-forward" ex-search-address "search-backward" "goto-mark" exchange-point-and-mark register-to-point 97 1] 26))
  1142.  
  1143. (defun ex-search-address (forward) "\
  1144. search pattern and set address" (byte-code "ב✓ג\"â⑧    ?â②דה!é⑤    ë⓪é✓ë①ê
  1145. â*וז!êח✓!é1וט!êי✓!ç" [ex-token vip-s-string forward string= "" error "No previous search string" forward-line 1 re-search-forward -1 re-search-backward] 7))
  1146.  
  1147. (defun vip-get-ex-buffer nil "\
  1148. get a buffer name and set ex-count and ex-flag if found" (byte-code "IJë⓪êIJë②êIJë③êדïç" [ex-buffer nil ex-count ex-flag t ((byte-code "גqêדה!êוז!à⑧gë⓪êחט!êדה!êוי!à4כ`!êלמ!êנס`ע \"!ë①êדה!êופ!àBבë②êחט!êוצ!?àMקר!ç" [ex-buffer ex-count ex-flag t " *ex-working-space*" skip-chars-forward "     " looking-at "[a-zA-Z]" forward-char 1 "[0-9]" set-mark re-search-forward "[0-9][0-9]*" string-to-int buffer-substring mark "[pl#]" "[
  1149. |]" error "Illegal extra characters"] 16))] 2))
  1150.  
  1151. (defun vip-get-ex-count nil (byte-code "IJ⓪IJ②IJë③êדïç" [ex-variant nil ex-count ex-flag t ((byte-code "גqêדה!êוז!à④IJë⓪êחט!êדה!êוי!à4כ`!êלמ!êנס`ע \"!ë②êדה!êופ!àBIJë③êחט!êוצ!?àMקר!ç" [ex-variant t ex-count ex-flag " *ex-working-space*" skip-chars-forward "     " looking-at "!" forward-char 1 "[0-9]" set-mark re-search-forward "[0-9][0-9]*" string-to-int buffer-substring mark "[pl#]" "[
  1152. |]" error "Illegal extra characters"] 16))] 2))
  1153.  
  1154. (defun vip-get-ex-file nil "\
  1155. get a file name and set ex-variant, ex-append and ex-offset if found" (byte-code "IJ⓪IJ②IJ③IJë④êהïç" [ex-file nil ex-variant ex-append ex-offset t ((byte-code "דqêהו!êזח!à⑧IJë⓪êטי!êהו!êזכ!à,IJ②IJë⓪êטל!êהו!êזמ!àRטי!êנ`!êסע!êפי!êצ`ק \"ë③êטי!êהו!êנ`!êסע!êפי!êצ`ק \"ë④ç" [ex-variant t ex-append ex-offset ex-file " *ex-working-space*" skip-chars-forward "     " looking-at "!" forward-char 1 ">>" 2 "+" set-mark re-search-forward "[     
  1156. ]" backward-char buffer-substring mark] 23))] 2))
  1157.  
  1158. (defun vip-execute-ex-command nil "\
  1159. execute ex command using the value of addresses." (byte-code "ב✓ג\"â ד é?⇩ב✓ה\"â⑨וIJ!é?⇩ב✓ז\"â%ח é?⇩ב✓ט\"â1י é?⇩ב✓כ\"â=ל é?⇩ב✓מ\"âJנמ!é?⇩ב✓ס\"âVע é?⇩ב✓פ\"âbע é?⇩ב✓צ\"ânק é?⇩ב✓ר\"â{וא!é?⇩ב✓ש\"âçת é?⇩ב✓ן\"âôך é?⇩ב✓ם\"âƒף é?⇩ב✓ץ\"⽧ é?⇩ב✓∧\"âÃ∞ é?⇩ב✓α\"âבβ é?⇩ב✓Γ\"âנπ é?⇩ב✓Σ\"âץוIJ!é?⇩ב✓σ\"âΦµ é?⇩ב✓τ\"â⌠Φ é?⇩ב✓Θ\"â⇧Ω é?⇩ב✓δ\"â ⇧∮ é?⇩ב✓ϕ\"â⑧⇧י é?⇩ב✓∈\"â%⇧∩IJ!é?⇩ב✓≡\"â2⇧∩א!é?⇩ב✓±\"â>⇧≥ é?⇩ב✓≤\"âJ⇧⌠ é?⇩ב✓⌡\"âV⇧÷ é?⇩ב✓≈\"âc⇧נ°!é?⇩ב✓∙\"âp⇧נ·!é?⇩ב✓√\"â}⇧βא!é?⇩ב✓ⁿ\"âï⇧βאא\"é?⇩ב✓²\"å»⇧ב✓³\"å»⇧ב✓¯\"å»⇧ב✓ü@\"å»⇧ב✓üA\"âIJ⇧üBüCüD✓\"!é?⇩ב✓üE\"å!⇩ב✓üF\"å!⇩ב✓üG\"å!⇩ב✓üH\"å!⇩ב✓üI\"å!⇩ב✓üJ\"å!⇩ב✓üK\"å!⇩ב✓üL\"å!⇩ב✓üM\"å!⇩ב✓üN\"å!⇩ב✓üO\"â3⇩üBüCüP✓\"!é?⇩üBüCüQ✓\"!ç" [ex-token nil t string= "goto" ex-goto "copy" ex-copy "delete" ex-delete "edit" ex-edit "file" vip-info-on-file "join" ex-line "k" ex-mark "mark" "map" ex-map "move" "put" ex-put "quit" ex-quit "read" ex-read "set" ex-set "shell" ex-shell "substitute" ex-substitute "stop" suspend-emacs "t" "tag" ex-tag "undo" vip-undo "unmap" ex-unmap "version" vip-version "visual" "write" ex-write "wq" "yank" ex-yank "!" ex-command "=" ex-line-no ">" "right" "<" "left" "&" "~" "append" "args" "change" "insert" "open" error format "%s: no such command from VIP" "abbreviate" "list" "next" "print" "preserve" "recover" "rewind" "source" "unabbreviate" "xit" "z" "%s: not implemented in VIP" "%s: Not an editor command"] 88))
  1160.  
  1161. (defun ex-goto nil "\
  1162. ex goto command" (byte-code "✓?à
  1163. `IJBë⓪êא`!ê✓@bêב ç" [ex-addresses nil push-mark beginning-of-line] 3))
  1164.  
  1165. (defun ex-copy (del-flag) "\
  1166. ex copy and move command.  DEL-FLAG means delete." (byte-code "ח êט 
  1167. @
  1168. A@⑨⑧    bêèי♪!êכל `\"ê â'מ`ל \"é,נ`ל \"êàTסÉע å?╱å?◆âH✓@éMפ`ל \"!æêצקרÅ)ê✓שUâaebég✓bêתן!ê✓@c+ç" [address end ex-addresses beg del-flag ex-flag ex-g-flag ex-g-variant kill-ring-yank-pointer vip-default-ex-addresses vip-get-ex-address set-mark vip-enlarge-region mark kill-region copy-region-as-kill "*copy text*" princ buffer-substring nil (byte-code "ijIJ!êèאב!)ç" [vip-read-string "[Hit return to continue] " kill-buffer "*copy text*"] 3) ((quit (byte-code "èIJא!)êבגij\"ç" [nil kill-buffer "*copy text*" signal quit] 4))) 0 forward-line 1] 15))
  1169.  
  1170. (defun ex-delete nil "\
  1171. ex delete" (byte-code "ו êז ê    @    A@ə⑧
  1172. ✓Và⑥חט!êèי
  1173. ✓\"êכ ê♪â/ל`!êמ♪S!é2ל✓!êי`נ \"ê âUסÉעפ`נ \"!æêצקרÅêèשס!)é~àxתXàbןXâqךם\\`נ ה$éxף`נ ה$êץ`נ \")*ç" [end ex-addresses beg ex-count ex-flag ex-buffer nil vip-default-ex-addresses vip-get-ex-buffer error "First address exceeds second" vip-enlarge-region exchange-point-and-mark set-mark forward-line mark " *delete text*" princ buffer-substring conditions (byte-code "ijIJ!ç" [vip-read-string "[Hit return to continue] "] 2) ((quit (byte-code "èijIJ!)êאב!ç" [kill-buffer " *delete text*" error ""] 3))) kill-buffer 65 90 vip-append-to-register 32 copy-to-register delete-region] 22))
  1174.  
  1175. (defun ex-edit nil "\
  1176. ex-edit" (byte-code "ד ê✓?àה à    à④וז!êח êט
  1177. ♪P!qêי êebê à2כïêל bêמ ç" [ex-variant buffer-file-name default-directory ex-file ex-offset vip-get-ex-file buffer-modified-p error "No write since last change (:e! overrides)" vip-change-mode-to-emacs find-file-noselect vip-change-mode-to-vi ((byte-code "IJqêאed\"êב✓ג\"êebç" [ex-offset " *ex-working-space*" delete-region insert "
  1178. "] 4)) vip-get-ex-address beginning-of-line] 9))
  1179.  
  1180. (defun ex-global (variant) "\
  1181. ex global command" (byte-code "✓å❎    âעפ!é
  1182. âəב⓪גë①éג⓪בë①êצ ê?à+עק!êרש\"âG╱?â?עת!éD╱ë⑥◆éN⑥◆ë⑥╱ê✓?à[deDë⑥✓êבןב✓@✓A@ ♪
  1183.      Và{עך!êèם \"êף êגץ ף ê§ êmàÜo?àá∧∞!êà»o?à»`Yà⇦⇧§ êα`!êβ êΓ◆π ג#⓪✓àי⓪åר    àר⓪?àΩβ ê
  1184. Të⑥
  1185. êץ     Bë⑥    )ꧠêoâ·בë⑥é⇧Σσ!êβ êéí*)êµïê    à*⇧    @bêτ♪!ê
  1186. Së⑥
  1187. ê    Aë⑥    êé
  1188. ⇧-ç" [ex-g-flag ex-g-variant variant nil t ex-token vip-s-string ex-g-pat ex-addresses marks mark-count com-str end beg cont limit found error "Global within global not allowed" vip-get-ex-pat "Missing regular expression for global command" string= "" "No previous search string" 0 "First address exceeds second" vip-enlarge-region exchange-point-and-mark point-marker beginning-of-line backward-char 1 set-mark end-of-line re-search-backward mark forward-line -1 ((byte-code "IJqêא`TdS\"ë⓪ç" [com-str " *ex-working-space*" buffer-substring] 3)) vip-ex] 26))
  1189.  
  1190. (defun ex-line (com) "\
  1191. ex line commands.  COM is join, shift-right or shift-left." (byte-code "ו êז ê    @    A@חə⑧
  1192. ✓Và⑧טי!êèכ
  1193. ✓\"êל ê à-מ`!êנ !êâJסÉעפ`צ \"!æêקרשÅêèתס!)éQן╱`צ #ê`ë③)ê♪Sbêך +ç" [end ex-addresses beg point ex-count ex-flag com vip-default-ex-addresses vip-get-ex-count nil error "First address exceeds second" vip-enlarge-region exchange-point-and-mark set-mark forward-line " *text*" princ buffer-substring mark conditions (byte-code "IJא!êב✓`ג #ç" [com vip-read-string "[Hit return to continue] " ex-line-subr mark] 6) ((quit (byte-code "ij ç" [ding] 2))) kill-buffer ex-line-subr beginning-of-line] 16))
  1194.  
  1195. (defun ex-line-subr (com beg end) (byte-code "ד✓ה\"âA    
  1196. ^bêm?à⑥`    
  1197. ]Wà>ו ê`    
  1198. ]Xà&m?à:זח!êט``S\"ê♪?à:י êé épד✓כ\"åLד✓ל\"àpמ    
  1199. ^    
  1200. ]ד✓כ\"âa éc [#ê    
  1201. ]bêו êנח!ç" [com beg end ex-variant vip-shift-width string= "join" end-of-line forward-line 1 delete-region fixup-whitespace "right" "left" indent-rigidly forward-char] 13))
  1202.  
  1203. (defun ex-mark nil "\
  1204. ex mark" (byte-code "א⑧    ?à `אBë①êבïêè    @bêג✓דהZZ!))ç" [char ex-addresses nil ((byte-code "IJqêאב!êגד!â&gë⓪êהו!êאב!êגז!?à#חט!é5גז!â2חי!é5חכ!ç" [char " *ex-working-space*" skip-chars-forward "     " looking-at "[a-z]" forward-char 1 "[
  1205. |]" error "Extra characters at end of \"k\" command" "\"k\" requires a following letter" "Mark must specify a letter"] 10)) point-to-register 97 1] 4))
  1206.  
  1207. (defun ex-map nil "\
  1208. ex map" (byte-code "גג⑨⑧דïêה
  1209. ✓\"?àו
  1210. ✓ה♪✓\"åəז#êו♪✓חטיכלמ    נEEBD!#*ç" [char string ex-map vip-mode-map nil ((byte-code "אqêבג!êדg!ë⓪êהו!êבג!êזח!àטי!êכ`!êל êמו!êנס `\"ë①ç" [char string " *ex-working-space*" skip-chars-forward "     " char-to-string forward-char 1 looking-at "[
  1211. |]" error "Missing rhs" set-mark end-of-buffer backward-char buffer-substring mark] 13)) lookup-key define-key vip-nil eval quote lambda (count) (interactive "p") execute-kbd-macro count] 14))
  1212.  
  1213. (defun ex-unmap nil "\
  1214. ex unmap" (byte-code "ב⑧גïêד    ✓\"?à⓪הו!êז
  1215. ✓ד    ✓\"#êז    ✓ב#)ç" [char ex-map vip-mode-map nil ((byte-code "IJqêאב!êגg!ë⓪êדה!êאב!êוז!?àחט!ç" [char " *ex-working-space*" skip-chars-forward "     " char-to-string forward-char 1 looking-at "[
  1216. |]" error "Macro must be a character"] 7)) lookup-key error "That macro wasn't mapped" define-key] 8))
  1217.  
  1218. (defun ex-put nil "\
  1219. ex put" (byte-code "    ?â    `é♪    @⑧ג ê♪ë②ê✓bê✓דUâ\"הו!é%זו!)ç" [point ex-addresses vip-use-register ex-buffer vip-get-ex-buffer 0 vip-Put-back 1 vip-put-back] 4))
  1220.  
  1221. (defun ex-quit nil "\
  1222. ex quit" (byte-code "א⑧בïê✓גUâ①דIJ!é③ה )ç" [char t nil ((byte-code "IJqêאב!êgë⓪ç" [char " *ex-working-space*" skip-chars-forward "     "] 3)) 33 kill-emacs save-buffers-kill-emacs] 3))
  1223.  
  1224. (defun ex-read nil "\
  1225. ex read" (byte-code "    ?â    `é♪    @בבבə⑧✓bê✓וU?àזח!êט êיïê
  1226. â1כ ה\"é4ל!,ç" [point ex-addresses variant nil command file t 0 next-line 1 beginning-of-line ((byte-code "גqêדה!êוז!â*IJë⓪êחט!êדה!êי`!êכ êלמ `\"ë②é=י`!êנס!êעט!êל`מ \"ë③ç" [variant t command file " *ex-working-space*" skip-chars-forward "     " looking-at "!" forward-char 1 set-mark end-of-line buffer-substring mark re-search-forward "[     
  1227. ]" backward-char] 15)) shell-command insert-file] 5))
  1228.  
  1229. (defun ex-set nil (byte-code "ijIJאב!ijגד!!E!ç" [eval setq read-variable "Variable: " read-minibuffer "Value: "] 7))
  1230.  
  1231. (defun ex-shell nil "\
  1232. ex shell" (byte-code "ij êIJ ç" [vip-change-mode-to-emacs shell] 3))
  1233.  
  1234. (defun ex-substitute (&optional repeat r-flag) "\
  1235. ex substitute. if REPEAT use previous reg-exp which is ex-reg-exp or
  1236. vip-s-string" (byte-code "בבבבבə⑨⑧╱â⑥בë⑥◆é⑧ק ê◆?â3✓â)    é+
  1237. ⓪♪ë①éhר◆ש\"â@    éB◆ë⓪ê✓⑥    ✓ë⑥
  1238. êק ê◆?â`ש⑥◆שë⑥♪éh◆①◆ë⑥♪êת àâר◆ן\"â|כë②éכë④êéiêך êâ«èàû@bêם`!êףS!ê`ץ בBBë⑥)éנ?â™``בBBë⑥éנA?àנ@Bë⑥ê@A@כב②①⓪è§⓪\"êè`ץ ]bê∧ )③`ץ ^bê`③Wàd⇧∞ êα ë⑥②êβ ê
  1239. â?⇧l?à⇧Γ✓②כ#à6⇧ ?å(⇧πΣ!à2⇧`ë⑤êσ    !êé②⇧ê∞ êµ é`⇧Γ✓②כ#àP⇧ ?åP⇧πΣ!àZ⇧`ë⑤êσ    !ê∞ êµ êé√)),êàn⇧bêβ ê ày⇧τΦ!-ç" [pat repl opt-g nil opt-c matched-pos repeat ex-token r-flag vip-s-string ex-reg-exp ex-repl t ex-count ex-addresses beg end cont eol-mark limit vip-get-ex-pat string= "" vip-get-ex-opt-gc "g" vip-get-ex-count set-mark forward-line mark vip-enlarge-region point-marker end-of-line dot-marker beginning-of-line re-search-forward y-or-n-p "Replace? " replace-match forward-char message "done"] 29))
  1240.  
  1241. (defun ex-tag nil "\
  1242. ex tag" (byte-code "א⑧בïêג✓ד\"?à⓪✓ë①êה êוזחÅ)ç" [tag ex-tag nil ((byte-code "IJqêאב!êג`!êאד!êהו `\"ë⓪ç" [tag " *ex-working-space*" skip-chars-forward "     " set-mark "^ |    
  1243. " buffer-substring mark] 7)) string= "" vip-change-mode-to-emacs conditions (byte-code "ב✓ג\"âד    א\"é①ה    !êו ç" [tag ex-tag t string= "" find-tag find-tag-other-window vip-change-mode-to-vi] 5) ((error (byte-code "IJ êא✓!ç" [conditions vip-change-mode-to-vi vip-message-conditions] 3)))] 5))
  1244.  
  1245. (defun ex-write (q-flag) "\
  1246. ex write" (byte-code "חij!êט êי    כ\"â
  1247. ?à⑥למ!ê
  1248. ë①é\"נ    !ë①êי    א \"?à4ס    !à4♪?à=לעפ    \"!ê@A@╱╱ VàPלצ!êèק╱ \"êר`ש     ◆ij%)*ê
  1249. ?àl    ë②ê✓àtת ç" [t ex-file buffer-file-name ex-variant end ex-addresses beg ex-append q-flag vip-default-ex-addresses vip-get-ex-file string= "" error "No file associated with this buffer" expand-file-name file-exists-p format "\"%s\" File exists - use w! to override" "First address exceeds second" vip-enlarge-region write-region mark save-buffers-kill-emacs] 19))
  1250.  
  1251. (defun ex-yank nil "\
  1252. ex yank" (byte-code "ח êט ê    @    A@ə⑧
  1253. ✓Và⑥יכ!êèל
  1254. ✓\"êמ ê♪å% à+ינ!êâ;ס`!êעS!é>ס✓!êל`פ \"ê╱àMיצ!ê◆à[ק◆`פ ז$êר`פ \")*ç" [end ex-addresses beg ex-g-flag ex-g-variant ex-count ex-flag ex-buffer nil vip-default-ex-addresses vip-get-ex-buffer error "First address exceeds second" vip-enlarge-region exchange-point-and-mark "Can't yank within global" set-mark forward-line mark "Extra chacters at end of command" copy-to-register copy-region-as-kill] 18))
  1255.  
  1256. (defun ex-command nil "\
  1257. execute shell command" (byte-code "ד⑧הïê    ?â⓪ו✓!é:    @    A@ə♪?à
  1258. ë③êè♪bêז
  1259. !êח`ט \"êי`ט ✓ג$)ê♪b*)ç" [command ex-addresses end beg t nil ((byte-code "IJqêאב!êג`!êד êהו `\"ë⓪ç" [command " *ex-working-space*" skip-chars-forward "     " set-mark end-of-line buffer-substring mark] 7)) shell-command set-mark vip-enlarge-region mark shell-command-on-region] 10))
  1260.  
  1261. (defun ex-line-no nil "\
  1262. print line number" (byte-code "IJאבe✓?âdé✓@\"T\"ç" [ex-addresses message "%d" count-lines] 5))
  1263.  
  1264. (if (file-exists-p "~/.vip") (load "~/.vip"))
  1265.