Mercurial > emacs
changeset 6298:4f65581e0972
(outline-mode, outline-level): Doc fix.
(outline-on-heading-p): Use bolp, not bobp.
(outline-hide-other): Rename from hide-other.
(outline-hide-sublevels): Rename from hide-sublevels.
(outline-back-to-heading): Error if no previous heading.
(outline-next-visible-heading): Check for search failure.
(outline-hide-sublevels): Ignore text before first outline heading.
(outline-level): Count characters, not columns, so ^L is level 1.
author | Karl Heuer <kwzh@gnu.org> |
---|---|
date | Thu, 10 Mar 1994 23:49:00 +0000 |
parents | b44907fd0ff0 |
children | d0a9fa0d0a8d |
files | lisp/textmodes/ooutline.el |
diffstat | 1 files changed, 27 insertions(+), 23 deletions(-) [+] |
line wrap: on
line diff
--- a/lisp/textmodes/ooutline.el Thu Mar 10 22:55:04 1994 +0000 +++ b/lisp/textmodes/ooutline.el Thu Mar 10 23:49:00 1994 +0000 @@ -77,9 +77,9 @@ (define-key outline-mode-map [menu-bar hide] (cons "Hide" (make-sparse-keymap "Hide"))) - (define-key outline-mode-map [menu-bar hide hide-other] + (define-key outline-mode-map [menu-bar hide outline-hide-other] '("Hide Other" . outline-hide-other)) - (define-key outline-mode-map [menu-bar hide hide-sublevels] + (define-key outline-mode-map [menu-bar hide outline-hide-sublevels] '("Hide Sublevels" . outline-hide-sublevels)) (define-key outline-mode-map [menu-bar hide hide-subtree] '("Hide Subtree" . hide-subtree)) @@ -144,8 +144,8 @@ \\[outline-backward-same-level] outline-backward-same-level \\[outline-up-heading] outline-up-heading move from subheading to heading -M-x hide-body make all text invisible (not headings). -M-x show-all make everything in buffer visible. +\\[hide-body] make all text invisible (not headings). +\\[show-all] make everything in buffer visible. The remaining commands are used when point is on a heading line. They apply to some of the body or subheadings of that heading. @@ -154,11 +154,11 @@ \\[show-children] show-children make direct subheadings visible. No effect on body, or subheadings 2 or more levels down. With arg N, affects subheadings N levels down. -M-x hide-entry make immediately following body invisible. -M-x show-entry make it visible. -M-x hide-leaves make body under heading and under its subheadings invisible. +\\[hide-entry] make immediately following body invisible. +\\[show-entry] make it visible. +\\[hide-leaves] make body under heading and under its subheadings invisible. The subheadings remain visible. -M-x show-branches make all subheadings at all levels visible. +\\[show-branches] make all subheadings at all levels visible. The variable `outline-regexp' can be changed to control what is a heading. A line is a heading if `outline-regexp' matches something at the @@ -230,10 +230,10 @@ (defun outline-level () "Return the depth to which a statement is nested in the outline. Point must be at the beginning of a header line. This is actually -the column number of the end of what `outline-regexp matches'." +the number of characters that `outline-regexp' matches." (save-excursion (looking-at outline-regexp) - (save-excursion (goto-char (match-end 0)) (current-column)))) + (- (match-end 0) (match-beginning 0)))) (defun outline-next-preface () "Skip forward to just before the next heading line." @@ -256,13 +256,14 @@ Only visible heading lines are considered." (beginning-of-line) (or (outline-on-heading-p) - (re-search-backward (concat "^\\(" outline-regexp "\\)") nil 'move))) + (re-search-backward (concat "^\\(" outline-regexp "\\)") nil t) + (error "before first heading"))) (defun outline-on-heading-p () "Return T if point is on a (visible) heading line." (save-excursion (beginning-of-line) - (and (bobp) + (and (bolp) (looking-at outline-regexp)))) (defun outline-end-of-heading () @@ -278,7 +279,8 @@ (if (< arg 0) (beginning-of-line) (end-of-line)) - (re-search-forward (concat "^\\(" outline-regexp "\\)") nil nil arg) + (or (re-search-forward (concat "^\\(" outline-regexp "\\)") nil t arg) + (error "")) (beginning-of-line)) (defun outline-previous-visible-heading (arg) @@ -357,7 +359,7 @@ (interactive) (outline-flag-subtree ?\n)) -(defun hide-sublevels (levels) +(defun outline-hide-sublevels (levels) "Hide everything except the top LEVELS levels of headers." (interactive "p") (if (< levels 1) @@ -365,6 +367,8 @@ (setq levels (1- levels)) (save-excursion (goto-char (point-min)) + (or (outline-on-heading-p) + (outline-next-heading)) (hide-subtree) (show-children levels) (condition-case err @@ -373,7 +377,7 @@ (show-children levels)) (error nil)))) -(defun hide-other () +(defun outline-hide-other () "Hide everything except for the current body and the parent headings." (interactive) (outline-hide-sublevels 1) @@ -412,7 +416,7 @@ nil ;; go to end of line before heading (forward-char -1) - ;; skip preceding balnk line, if there is one + ;; skip preceding blank line, if there is one (if (memq (preceding-char) '(?\n ?\^M)) (forward-char -1))))) @@ -464,13 +468,13 @@ (outline-back-to-heading) (if (eq (funcall outline-level) 1) (error "")) - (while (and (> (funcall outline-level) 1) - (> arg 0) - (not (bobp))) - (let ((present-level (funcall outline-level))) - (while (not (< (funcall outline-level) present-level)) - (outline-previous-visible-heading 1)) - (setq arg (- arg 1))))) + (while (and (> (funcall outline-level) 1) + (> arg 0) + (not (bobp))) + (let ((present-level (funcall outline-level))) + (while (not (< (funcall outline-level) present-level)) + (outline-previous-visible-heading 1)) + (setq arg (- arg 1))))) (defun outline-forward-same-level (arg) "Move forward to the ARG'th subheading from here of the same level as the