changeset 10998:2c184ff2351d

entered into RCS
author Richard M. Stallman <rms@gnu.org>
date Tue, 14 Mar 1995 05:43:48 +0000 (1995-03-14)
parents 66d853abce42
children 84076f6a1f1b
files lisp/textmodes/outline.el
diffstat 1 files changed, 13 insertions(+), 6 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/textmodes/outline.el	Tue Mar 14 04:25:37 1995 +0000
+++ b/lisp/textmodes/outline.el	Tue Mar 14 05:43:48 1995 +0000
@@ -248,14 +248,14 @@
 	(make-local-variable 'line-move-ignore-invisible)
 	(setq line-move-ignore-invisible t)
 	;; Cause use of ellipses for invisible text.
-	(setq buffer-invisibility-spec '((t . t))))
-    (run-hooks 'outline-minor-mode-hook)
+	(setq buffer-invisibility-spec '((t . t)))
+	(run-hooks 'outline-minor-mode-hook))
     (setq line-move-ignore-invisible nil)
     ;; Cause use of ellipses for invisible text.
     (setq buffer-invisibility-spec t))
-  ;; When turning off outline mode, get rid of any invisible props.
+  ;; When turning off outline mode, get rid of any outline hiding.
   (or outline-minor-mode
-      (outline-flag-region (point-min) (point-max) nil))
+      (show-all))
   (set-buffer-modified-p (buffer-modified-p)))
 
 (defvar outline-level 'outline-level
@@ -288,7 +288,7 @@
 (defun outline-next-heading ()
   "Move to the next (possibly invisible) heading line."
   (interactive)
-  (if (re-search-forward (concat "^\\(" outline-regexp "\\)")
+  (if (re-search-forward (concat "\n\\(" outline-regexp "\\)")
 			 nil 'move)
       (goto-char (1+ (match-beginning 0)))))
 
@@ -363,6 +363,11 @@
 	    (overlay-put o 'invisible flag)
 	    (overlay-put o 'outline t))))))
 
+;; Exclude from the region BEG ... END all overlays
+;; with a non-nil PROP property.
+;; Exclude them by shrinking them to exclude BEG ... END,
+;; or even by splitting them if necessary.
+;; Overlays without a non-nil PROP property are not touched.
 (defun outline-discard-overlays (beg end prop)
   (if (< end beg)
       (setq beg (prog1 end (setq end beg))))
@@ -387,8 +392,10 @@
 	  (setq overlays (cdr overlays))))
       (goto-char (next-overlay-change (point))))))
 
+;; Make a copy of overlay O, with the same beginning, end and properties.
 (defun outline-copy-overlay (o)
-  (let ((o1 (make-overlay (overlay-start o) (overlay-end o)))
+  (let ((o1 (make-overlay (overlay-start o) (overlay-end o)
+			  (overlay-buffer o)))
 	(props (overlay-properties o)))
     (while props
       (overlay-put o1 (car props) (nth 1 props))