changeset 44943:c5a1b54e283e

(f90-mark-subprogram-overlay): New internal variable. (f90-mark-subprogram): Use it to highlight the subprogram with an overlay.
author Glenn Morris <rgm@gnu.org>
date Sun, 28 Apr 2002 22:15:51 +0000
parents 972dc81abf82
children dbacf99cccc4
files lisp/progmodes/f90.el
diffstat 1 files changed, 15 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/progmodes/f90.el	Sun Apr 28 22:09:55 2002 +0000
+++ b/lisp/progmodes/f90.el	Sun Apr 28 22:15:51 2002 +0000
@@ -1215,9 +1215,14 @@
       (message "No end found.")
       nil)))
 
+(defvar f90-mark-subprogram-overlay nil
+  "Used internally by `f90-mark-subprogram' to highlight the subprogram.")
+(make-variable-buffer-local 'f90-mark-subprogram-overlay)
+
 (defun f90-mark-subprogram ()
-  "Put mark at end of F90 subprogram, point at beginning.
-Marks are pushed and highlight (grey shadow) is turned on."
+  "Put mark at end of F90 subprogram, point at beginning, push marks.
+If called interactively, highlight the subprogram with the face `highlight'.
+Call again to remove the highlighting."
   (interactive)
   (let ((pos (point)) program)
     (f90-end-of-subprogram)
@@ -1228,7 +1233,14 @@
     (if f90-xemacs-flag
 	(zmacs-activate-region)
       (setq mark-active t
-            deactivate-mark nil))
+            deactivate-mark nil)
+      (if (interactive-p)
+	  (if (overlayp f90-mark-subprogram-overlay)
+	      (if (overlay-buffer f90-mark-subprogram-overlay)
+		  (delete-overlay f90-mark-subprogram-overlay)
+		(move-overlay f90-mark-subprogram-overlay (point) (mark)))
+	    (setq f90-mark-subprogram-overlay (make-overlay (point) (mark)))
+	    (overlay-put f90-mark-subprogram-overlay 'face 'highlight))))
     program))
 
 (defun f90-comment-region (beg-region end-region)