home *** CD-ROM | disk | FTP | other *** search
/ Geek Gadgets 1 / ADE-1.bin / ade-dist / emacs-18.59-src.tgz / emacs-18.59-src.tar / fsf / emacs18 / lisp / view.elc < prev    next >
Text File  |  1996-09-28  |  13KB  |  144 lines

  1.  
  2. (provide (quote view))
  3.  
  4. (defvar view-mode-map nil)
  5.  
  6. (if view-mode-map nil (setq view-mode-map (make-keymap)) (fillarray view-mode-map (quote View-undefined)) (define-key view-mode-map "" (quote exit-recursive-edit)) (define-key view-mode-map "" (quote suspend-emacs)) (define-key view-mode-map "q" (quote exit-recursive-edit)) (define-key view-mode-map "-" (quote negative-argument)) (define-key view-mode-map "0" (quote digit-argument)) (define-key view-mode-map "1" (quote digit-argument)) (define-key view-mode-map "2" (quote digit-argument)) (define-key view-mode-map "3" (quote digit-argument)) (define-key view-mode-map "4" (quote digit-argument)) (define-key view-mode-map "5" (quote digit-argument)) (define-key view-mode-map "6" (quote digit-argument)) (define-key view-mode-map "7" (quote digit-argument)) (define-key view-mode-map "8" (quote digit-argument)) (define-key view-mode-map "9" (quote digit-argument)) (define-key view-mode-map "" (quote universal-argument)) (define-key view-mode-map "" nil) (define-key view-mode-map "" (quote Control-X-prefix)) (define-key view-mode-map "-" (quote negative-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "" (quote digit-argument)) (define-key view-mode-map "<" (quote beginning-of-buffer)) (define-key view-mode-map ">" (quote end-of-buffer)) (define-key view-mode-map "v" (quote View-scroll-lines-backward)) (define-key view-mode-map "" (quote View-scroll-lines-forward)) (define-key view-mode-map " " (quote View-scroll-lines-forward)) (define-key view-mode-map "" (quote View-scroll-lines-backward)) (define-key view-mode-map "
  7. " (quote View-scroll-one-more-line)) (define-key view-mode-map "" (quote View-scroll-one-more-line)) (define-key view-mode-map " " (quote recenter)) (define-key view-mode-map "z" (quote View-scroll-lines-forward-set-scroll-size)) (define-key view-mode-map "g" (quote View-goto-line)) (define-key view-mode-map "=" (quote what-line)) (define-key view-mode-map "." (quote set-mark-command)) (define-key view-mode-map "" (quote set-mark-command)) (define-key view-mode-map "'" (quote View-back-to-mark)) (define-key view-mode-map "@" (quote View-back-to-mark)) (define-key view-mode-map "x" (quote exchange-point-and-mark)) (define-key view-mode-map "h" (quote Helper-describe-bindings)) (define-key view-mode-map "?" (quote Helper-describe-bindings)) (define-key view-mode-map "" (quote Helper-help)) (define-key view-mode-map "" (quote View-next-line)) (define-key view-mode-map "" (quote View-previous-line)) (define-key view-mode-map "" (quote isearch-forward)) (define-key view-mode-map "" (quote isearch-backward)) (define-key view-mode-map "s" (quote isearch-forward)) (define-key view-mode-map "r" (quote isearch-backward)) (define-key view-mode-map "/" (quote View-search-regexp-forward)) (define-key view-mode-map "\\" (quote View-search-regexp-backward)) (define-key view-mode-map "" (quote View-search-regexp-forward)) (define-key view-mode-map "" (quote View-search-regexp-backward)) (define-key view-mode-map "n" (quote View-search-last-regexp-forward)) (define-key view-mode-map "p" (quote View-search-last-regexp-backward)))
  8.  
  9. (defun view-file (file-name) "\
  10. View FILE in View mode, returning to previous buffer when done.
  11. The usual Emacs commands are not available; instead,
  12. a special set of commands (mostly letters and punctuation)
  13. are defined for moving around in the buffer.
  14. Space scrolls forward, Delete scrolls backward.
  15. For list of all View commands, type ? or h while viewing.
  16.  
  17. Calls the value of  view-hook  if that is non-nil." (interactive "fView file: ") (byte-code "ÈŠ   !ÃƎÇpÈÉ    !‰Ä\"ˆ!)*‡" [had-a-buf file-name buf-to-view nil t get-file-buffer ((byte-code "?…    …    !?…à   !‡" [had-a-buf buf-to-view buffer-modified-p kill-buffer] 3)) view-mode switch-to-buffer find-file-noselect] 7))
  18.  
  19. (defun view-buffer (buffer-name) "\
  20. View BUFFER in View mode, returning to previous buffer when done.
  21. The usual Emacs commands are not available; instead,
  22. a special set of commands (mostly letters and punctuation)
  23. are defined for moving around in the buffer.
  24. Space scrolls forward, Delete scrolls backward.
  25. For list of all View commands, type ? or h while viewing.
  26.  
  27. Calls the value of  view-hook  if that is non-nil." (interactive "bView buffer: ") (byte-code "ÁˆÂpÃ!ˆ!‡" [buffer-name nil view-mode switch-to-buffer] 4))
  28.  
  29. (defun view-mode (&optional view-return-to-buffer) "\
  30. Major mode for viewing text but not editing it.
  31. Letters do not insert themselves.  Instead these commands are provided.
  32. Most commands take prefix arguments.  Commands dealing with lines
  33. default to \"scroll size\" lines (initially size of window).
  34. Search commands default to a repeat count of one.
  35. M-< or <    move to beginning of buffer.
  36. M-> or >    move to end of buffer.
  37. C-v or Space    scroll forward lines.
  38. M-v or DEL    scroll backward lines.
  39. CR or LF    scroll forward one line (backward with prefix argument).
  40. z        like Space except set number of lines for further
  41.            scrolling commands to scroll by.
  42. C-u and Digits    provide prefix arguments.  `-' denotes negative argument.
  43. =        prints the current line number.
  44. g        goes to line given by prefix argument.
  45. / or M-C-s    searches forward for regular expression
  46. \\ or M-C-r    searches backward for regular expression.
  47. n        searches forward for last regular expression.
  48. p        searches backward for last regular expression.
  49. C-@ or .    set the mark.
  50. x        exchanges point and mark.
  51. C-s or s    do forward incremental search.
  52. C-r or r    do reverse incremental search.
  53. @ or '        return to mark and pops mark ring.
  54.           Mark ring is pushed at start of every
  55.           successful search and when jump to line to occurs.
  56.           The mark is set on jump to buffer start or end.
  57. ? or h        provide help message (list of commands).
  58. C-h        provides help (list of commands or description of a command).
  59. C-n        moves down lines vertically.
  60. C-p        moves upward lines vertically.
  61. C-l        recenters the screen.
  62. q or C-c    exit view-mode and return to previous buffer.
  63.  
  64. Entry to this mode calls the value of  view-hook  if non-nil.
  65. \\{view-mode-map}" (byte-code "È ÂɎÄÊ ƒ˂ÌCÍЈÏЍ+)*‡" [view-buffer-window view-scroll-size nil buffer-read-only t mode-line-buffer-identification mode-name view-return-to-buffer selected-window ((byte-code "…Á!‡" [view-return-to-buffer switch-to-buffer] 2)) buffer-file-name "Viewing %f" "Viewing %b" "View" beginning-of-line view-mode-exit (byte-code "À ‡" [view-mode-command-loop] 2)] 5))
  66.  
  67. (defun view-helpful-message nil (byte-code "ÀÁÂ!Ã=…ÁÄ!Å=…ÁÆ!Ç=ƒȂ ÉÊ!!‡" [message key-binding "" Helper-help "?" Helper-describe-bindings "" exit-recursive-edit "Type C-h for help, ? for commands, C-c to quit" substitute-command-keys "Type \\[Helper-help] for help, \\[Helper-describe-bindings] for commands, \\[exit-recursive-edit] to quit."] 6))
  68.  
  69. (defun View-undefined nil (interactive) (byte-code "ÀˆÁ ˆÂ ‡" [nil ding view-helpful-message] 3))
  70.  
  71. (defun view-window-size nil (byte-code "Á!S‡" [view-buffer-window window-height] 2))
  72.  
  73. (defun view-scroll-size nil (byte-code "Á †Á ^‡" [view-scroll-size view-window-size] 4))
  74.  
  75. (defvar view-hook nil "\
  76. If non-nil, its value is called when viewing buffer or file.")
  77.  
  78. (defun view-mode-command-loop nil (byte-code "Ç ˆÈ ÂÂÉÊË ƒÌË !‚Í \"Í ΎÏ!ˆÐÑ!ˆÒ ˆÓ )-ˆÔ ‡" [old-local-map mark-ring nil view-last-regexp Helper-return-blurb view-buffer view-mode-map push-mark current-local-map format "continue viewing %s" buffer-file-name file-name-nondirectory buffer-name ((byte-code "ŠqˆÂ    !)‡" [view-buffer old-local-map use-local-map] 2)) use-local-map run-hooks view-hook view-helpful-message recursive-edit pop-mark] 14))
  79.  
  80. (defun View-goto-line (&optional line) "\
  81. Move to LINE in View mode.
  82. Display is centered at LINE.  Sets mark at starting position and pushes
  83. mark ring." (interactive "p") (byte-code "ÁˆÂ ˆÃ† Ä!ˆÅÆÇ È\"!‡" [line nil push-mark goto-line 1 recenter / view-window-size 2] 7))
  84.  
  85. (defun View-scroll-lines-forward (&optional lines) "\
  86. Scroll forward in View mode, or exit if end of text is visible.
  87. No arg means whole window full, or number of lines set by \\[View-scroll-lines-forward-set-scroll-size].
  88. Arg is number of lines to scroll." (interactive "P") (byte-code "ÁˆÂd!…
  89. àˆƒÄ!‚Å ‰ˆÆ Yƒ'ÇÁ!‚8[Æ Yƒ5ÈÁ!‚8Ç!ˆÂd!…KdbˆÉÊ!ˆËÌÍ!!ˆÎÊ!ˆÏ ‡" [lines nil pos-visible-in-window-p exit-recursive-edit prefix-numeric-value view-scroll-size view-window-size scroll-up scroll-down recenter -1 message substitute-command-keys "End.  Type \\[exit-recursive-edit] to quit viewing." move-to-window-line beginning-of-line] 16))
  90.  
  91. (defun View-scroll-lines-forward-set-scroll-size (&optional lines) "\
  92. Scroll forward LINES lines in View mode, setting the \"scroll size\".
  93. This is the number of lines which \\[View-scroll-lines-forward] and \\[View-scroll-lines-backward] scroll by default.
  94. The absolute value of LINES is used, so this command can be used to scroll
  95. backwards (but \"scroll size\" is always positive).  If LINES is greater than
  96. window height or omitted, then window height is assumed.  If LINES is less
  97. than window height then scrolling context is provided from previous screen." (interactive "P") (byte-code "ˆ?ƒà‰‚%Ä!‰ˆÅVƒ‚ [à^‰ˆÆ!‡" [lines view-scroll-size nil view-window-size prefix-numeric-value 0 View-scroll-lines-forward] 5))
  98.  
  99. (defun View-scroll-one-more-line (&optional arg) "\
  100. Scroll one more line up in View mode.
  101. With ARG scroll one line down." (interactive "P") (byte-code "ÁˆÂ?ƒ ÂÄ!‡" [arg nil View-scroll-lines-forward 1 -1] 2))
  102.  
  103. (defun View-scroll-lines-backward (&optional lines) "\
  104. Scroll backward in View mode.
  105. No arg means whole window full, or number of lines set by \\[View-scroll-lines-forward-set-scroll-size].
  106. Arg is number of lines to scroll." (interactive "P") (byte-code "ÁˆÂƒÃ![‚Ä [!‡" [lines nil View-scroll-lines-forward prefix-numeric-value view-scroll-size] 4))
  107.  
  108. (defun View-search-regexp-forward (times regexp) "\
  109. Search forward for NTH occurrence of REGEXP in View mode.
  110. Displays line found at center of window.  REGEXP is remembered for
  111. searching with \\[View-search-last-regexp-forward] and \\[View-search-last-regexp-backward].  Sets mark at starting position and pushes mark ring." (interactive "p
  112. sSearch forward (regexp): ") (byte-code "ˆGÃV…Ä    \"‡" [regexp times nil 0 view-search] 3))
  113.  
  114. (defun View-search-regexp-backward (times regexp) "\
  115. Search backward from window start for NTH instance of REGEXP in View mode.
  116. Displays line found at center of window.  REGEXP is remembered for
  117. searching with \\[View-search-last-regexp-forward] and \\[View-search-last-regexp-backward].  Sets mark at starting position and pushes mark ring." (interactive "p
  118. sSearch backward (regexp): ") (byte-code "ˆÃ[    \"‡" [times regexp nil View-search-regexp-forward] 3))
  119.  
  120. (defun View-search-last-regexp-forward (times) "\
  121. Search forward from window end for NTH instance of last regexp in View mode.
  122. Displays line found at center of window.  Sets mark at starting position
  123. and pushes mark ring." (interactive "p") (byte-code "ˆà   \"‡" [times view-last-regexp nil View-search-regexp-forward] 3))
  124.  
  125. (defun View-search-last-regexp-backward (times) "\
  126. Search backward from window start for NTH instance of last regexp in View mode.
  127. Displays line found at center of window.  Sets mark at starting position and
  128. pushes mark ring." (interactive "p") (byte-code "ˆà   \"‡" [times view-last-regexp nil View-search-regexp-backward] 3))
  129.  
  130. (defun View-back-to-mark (&optional ignore) "\
  131. Return to last mark set in View mode, else beginning of file.
  132. Displays line at center of window.  Pops mark ring so successive
  133. invocations return to earlier marks." (interactive) (byte-code "ÀˆÁ †ebˆÂ ˆÃÄÅ Æ\"!‡" [nil mark pop-mark recenter / view-window-size 2] 7))
  134.  
  135. (defun view-search (times regexp) (byte-code "    ‰ˆÄŠÆ ÇWƒǂÈ!ˆÉ    ÄÅ $…!`‰)ˆ
  136. ƒ:Ê ˆ
  137. bˆË ˆÌÍΠÏ\"!‚CÐÑ     #ˆÒÓ!)‡" [view-last-regexp regexp where times nil t move-to-window-line 0 -1 re-search-forward push-mark beginning-of-line recenter / view-window-size 2 message "Can't find occurrence %d of %s" sit-for 4] 11))
  138.  
  139. (defun View-previous-line (count) "\
  140. Move up to start of previous line.  Argument is repeat count." (interactive "p") (byte-code "ÁˆÂ[!‡" [count nil forward-line] 2))
  141.  
  142. (defun View-next-line (count) "\
  143. Move down to start of next line.  Argument is repeat count." (interactive "p") (byte-code "ÁˆÂ!‡" [count nil forward-line] 2))
  144.