home *** CD-ROM | disk | FTP | other *** search
/ OpenStep 4.2J / os42j.iso / usr / lib / emacs / lisp / vip.elc < prev    next >
Text File  |  1991-09-12  |  69KB  |  1,268 lines

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