home *** CD-ROM | disk | FTP | other *** search
/ Atari FTP / ATARI_FTP_0693.zip / ATARI_FTP_0693 / Languages / 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 "┬└DC├─└┼E    ╞└╟└DEFEç" [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. └é+┼╞ !    Bëê    G
  117. Và+╟╚
  118.     \"@└\"ê╔╚
  119. S    \"└\"ê╩ å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 "└┴ !ç" [set-buffer-modified-p buffer-modified-p] 3))
  129.  
  130. (defun vip-copy-keymap (map) (byte-code "?â
  131. ┴ é┬!ç" [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 "└┴┬Åç" [nil (byte-code "┬    \"ç" [beg end copy-region-as-kill] 3) ((error (byte-code "┴\"ç" [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!ê╧╙!ê┴ëê╘ ç" [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 "└ê┴┬!ç" [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 "└ê┴┬!ç" [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 "└ê┴┬!ç" [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é+éBK?å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 "┴ê┬├\"ç" [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 "┴ê┬├\"ç" [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 "┴ê┬├\"ç" [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 "┴ê┬├\"ç" [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 "┴à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 "┴ê├┴
  258. :â
  259. Aé┴#ç" [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 "└ê┴┬├Åç" [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 "┴ëê┬├┴\"ç" [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 "?â    ┴é:âAé┴ç" [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 "┴ê┬├!ê─ ê┼╞!ê╟ëç" [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 "┴┬!ê├─!ê┼ëç" [this-command message "undo more!" undo-more 1 vip-undo] 4))
  329.  
  330. (defun vip-string-tail (str) (byte-code "?å    ┬├\"â┴é─┴Oç" [str nil string= "" 1] 4))
  331.  
  332. (defun vip-yank-defun nil (byte-code "└ ê┴`┬ \"ç" [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 "`└ Và    ┴ ê┬ ê├ ê`└ 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àIcê╩ ê╦╠!êé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 "┴ê┬├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 "┼┴\"ê ëê╞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 "┴ê┬├B!ç" [arg nil vip-goto-eol 99] 3))
  525.  
  526. (defun vip-kill-line (arg) "\
  527. Delete line." (interactive "P") (byte-code "┴ê┬├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 "┴ê┬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 "┴ê┬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 "┴ê┬├ 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 "┴ê┬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 "┴ê┬[!ç" [arg nil vip-scroll] 2))
  645.  
  646. (defun vip-scroll-down (arg) "\
  647. Scroll up half screen." (interactive "P") (byte-code "┴ê?â┬├─ ┼\"!é┬!ç" [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 "┴ê┬!ç" [arg nil scroll-down] 2))
  651.  
  652. (defun vip-scroll-up (arg) "\
  653. Scroll down half screen." (interactive "P") (byte-code "┴ê?â┬├─ ┼\"!é┬!ç" [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 "┴ê┬!ç" [arg nil scroll-up] 2))
  657.  
  658. (defun vip-buffer-in-two-windows nil "\
  659. Show current buffer in two windows." (interactive) (byte-code "└ê┴ ê┬└!ç" [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 "┴ê┴┬├─┼╞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 "┴ê┴┬├─┼╞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 "┬ê┬┬├─┼┴p!\"!ëê    ?â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 "┴ê┴┬├!ëê─┼!!ê╞ )ç" [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 "┴ê┴┬├!ëê─┼!!ê╞ )ç" [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 "└ê┴┬├ â├ é─┼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 "è┴`!ê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 "└ê┴`!ê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 "└ê┴`!ê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 "└ê┴ ê┬ ç" [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 "┴ê┴ëê┬ ç" [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 "┴ê┬├\"ç" [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 "┴ê┬├\"ç" [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 "┴êè┬`!ê├!ê─`┼ \")ç" [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 "└ê┴┬!ç" [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 "└ê┴┬!ç" [nil error ""] 2))
  1083.  
  1084. (defun vip-looking-back (str) "\
  1085. returns t if looking back reg-exp STR before point." (byte-code "è├┴┬#)à`─┼!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 "┴┬!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ê─┼!ê╞╟!â╚╔!é\"╞╩!â┴ëé\"╦╠!ç" [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ê─┼!à ╞╟!ê╚╔!ê─╩!â#╩ëê╞╟!ê┴é6─╦!â5╦ëê╞╟!ê┴é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 "┴
  1138. ëê╟ ╚\"â ëéΓ╟ ╔\"â:è
  1139. bê╩
  1140. ╦Uâ/Sé0!ê╠ ë)éΓ╟ ═\"âRè
  1141. bê╩[!ê╠ ë)éΓ╟ ╬\"âvèebê╦Uâi╦ëér╩S!ê╠ ë)éΓ╟ ╧\"âä╨ ëéΓ╟ ╤\"âÅ╞éΓ╟ ╥\"âÜ╞éΓ╟ ╙\"â«è╘╞!ê╠ ë)éΓ╟ ╒\"â┬è╘┴!ê╠ ë)éΓ╟ ╓\"àΓè?â╘╫ é▄╪┘┌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 "┴ëê┴ëê┴ëê┼ïç" [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 "┴┴┴ëê┼ïç" [ex-variant nil ex-count ex-flag t ((byte-code "─qê┼╞!ê╟╚!à┴ëê╔╩!ê┼╞!ê╟╦!à4╠`!ê═╬!ê╧╨`╤ \"!ëê┼╞!ê╟╥!àB┴ëê╔╩!ê╟╙!?à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 "┴┴┴┴ëê╞ïç" [ex-file nil ex-variant ex-append ex-offset t ((byte-code "┼qê╞╟!ê╚╔!à┴ëê╩╦!ê╞╟!ê╚╠!à,┴┴ëê╩═!ê╞╟!ê╚╬!à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 "├─\"â ┼ é?├╞\"â╟┴!é?├╚\"â%╔ é?├╩\"â1╦ é?├╠\"â=═ é?├╬\"âJ╧╬!é?├╨\"âV╤ é?├╥\"âb╤ é?├╙\"ân╘ é?├╒\"â{╟┬!é?├╓\"âç╫ é?├╪\"âô┘ é?├┌\"âƒ█ é?├▄\"â½▌ é?├▐\"â╖▀ é?├α\"â├ß é?├Γ\"â╧π é?├Σ\"â▄╟┴!é?├σ\"âΦµ é?├τ\"â⌠Φ é?├Θ\"âΩ é?├δ\"â ∞ é?├φ\"â╦ é?├ε\"â%∩┴!é?├≡\"â2∩┬!é?├±\"â>≥ é?├≤\"âJ⌠ é?├⌡\"âV÷ é?├≈\"âc╧°!é?├∙\"âp╧·!é?├√\"â}ß┬!é?├ⁿ\"âïß┬┬\"é?├²\"å»├■\"å»├ \"å»├ü@\"å»├üA\"â┴ü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. `┴Bëê┬`!ê@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égbê╫╪!ê@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 "└┴!êè┬├!)ç" [vip-read-string "[Hit return to continue] " kill-buffer "*copy text*"] 3) ((quit (byte-code "è┴┬!)ê├─└\"ç" [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 "└┴!ç" [vip-read-string "[Hit return to continue] "] 2) ((quit (byte-code "è└┴!)ê┬├!ç" [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 "┴qê┬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 "┴qê┬`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 "┴┬!ê├`─ #ç" [com vip-read-string "[Hit return to continue] " ex-line-subr mark] 6) ((quit (byte-code "└ ç" [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 "┴qê┬├!ê─┼!â&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 "┴qê┬├!ê─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â┼┴!é╞ )ç" [char t nil ((byte-code "┴qê┬├!ê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ê┼╞!ê╟╚!â*┴ëê╔╩!ê┼╞!ê╦`!ê╠ ê═╬ `\"ëé=╦`!ê╧╨!ê╤╩!ê═`╬ \"ëç" [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 "└┴┬├!└─┼!!E!ç" [eval setq read-variable "Variable: " read-minibuffer "Value: "] 7))
  1230.  
  1231. (defun ex-shell nil "\
  1232. ex shell" (byte-code "└ ê┴ ç" [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`ëêσ    !ê▀ êµ êé√)),êànbêß ê à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 "┴qê┬├!ê─`!ê┬┼!ê╞╟ `\"ëç" [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 "┴ ê┬!ç" [conditions vip-change-mode-to-vi vip-message-conditions] 3)))] 5))
  1244.  
  1245. (defun ex-write (q-flag) "\
  1246. ex write" (byte-code "╔└!ê╩ ê╦    ╠\"â
  1247. ?à═╬!ê
  1248. ëé\"╧    !ëê╦    ┬ \"?à4╨    !à4 ?à=═╤╥    \"!ê@A@ VàP═╙!êè╘ \"ê╒`╓     └%)*ê
  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 "┴qê┬├!ê─`!ê┼ ê╞╟ `\"ëç" [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 "┴┬├e?âdé@\"T\"ç" [ex-addresses message "%d" count-lines] 5))
  1263.  
  1264. (if (file-exists-p "~/.vip") (load "~/.vip"))
  1265.