emacs-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Emacs-diffs] trunk r115610: * lisp/hl-line.el (hl-line-make-overlay): N


From: Stefan Monnier
Subject: [Emacs-diffs] trunk r115610: * lisp/hl-line.el (hl-line-make-overlay): New fun. Set priority.
Date: Thu, 19 Dec 2013 14:00:59 +0000
User-agent: Bazaar (2.6b2)

------------------------------------------------------------
revno: 115610
revision-id: address@hidden
parent: address@hidden
fixes bug: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=16192
committer: Stefan Monnier <address@hidden>
branch nick: trunk
timestamp: Thu 2013-12-19 09:00:55 -0500
message:
  * lisp/hl-line.el (hl-line-make-overlay): New fun.  Set priority.
  (hl-line-highlight, global-hl-line-highlight): Use it.
  (hl-line-overlay): Use defvar-local.
modified:
  lisp/ChangeLog                 changelog-20091113204419-o5vbwnq5f7feedwu-1432
  lisp/hl-line.el                hlline.el-20091113204419-o5vbwnq5f7feedwu-1318
=== modified file 'lisp/ChangeLog'
--- a/lisp/ChangeLog    2013-12-19 10:25:48 +0000
+++ b/lisp/ChangeLog    2013-12-19 14:00:55 +0000
@@ -1,12 +1,18 @@
+2013-12-19  Stefan Monnier  <address@hidden>
+
+       * hl-line.el (hl-line-make-overlay): New fun.  Set priority (bug#16192).
+       (hl-line-highlight, global-hl-line-highlight): Use it.
+       (hl-line-overlay): Use defvar-local.
+
 2013-12-19  Jan Djärv  <address@hidden>
 
        * term/ns-win.el: Require dnd.
        (global-map): Remove drag items.
        (ns-insert-text, ns-set-foreground-at-mouse)
-       (ns-set-background-at-mouse): Remove
-       (ns-drag-n-drop, ns-drag-n-drop-other-frame)
-       (ns-drag-n-drop-as-text, ns-drag-n-drop-as-text-other-frame): New
-       functions.
+       (ns-set-background-at-mouse):
+       Remove (ns-drag-n-drop, ns-drag-n-drop-other-frame)
+       (ns-drag-n-drop-as-text, ns-drag-n-drop-as-text-other-frame):
+       New functions.
 
 2013-12-19  Glenn Morris  <address@hidden>
 
@@ -79,8 +85,8 @@
 
 2013-12-18  Tassilo Horn  <address@hidden>
 
-       * textmodes/reftex-vars.el (reftex-label-alist-builtin): Reference
-       tables with ~\ref{...} instead of only \ref{...}.
+       * textmodes/reftex-vars.el (reftex-label-alist-builtin):
+       Reference tables with ~\ref{...} instead of only \ref{...}.
 
 2013-12-18  Chong Yidong  <address@hidden>
 
@@ -113,8 +119,8 @@
 
 2013-12-18  Le Wang  <address@hidden>
 
-       * comint.el (comint-previous-matching-input-from-input): Retain
-       point (Bug#13404).
+       * comint.el (comint-previous-matching-input-from-input):
+       Retain point (Bug#13404).
 
 2013-12-18  Chong Yidong  <address@hidden>
 

=== modified file 'lisp/hl-line.el'
--- a/lisp/hl-line.el   2013-08-05 14:26:57 +0000
+++ b/lisp/hl-line.el   2013-12-19 14:00:55 +0000
@@ -1,4 +1,4 @@
-;;; hl-line.el --- highlight the current line
+;;; hl-line.el --- highlight the current line  -*- lexical-binding:t -*-
 
 ;; Copyright (C) 1998, 2000-2013 Free Software Foundation, Inc.
 
@@ -61,9 +61,8 @@
 
 ;;; Code:
 
-(defvar hl-line-overlay nil
+(defvar-local hl-line-overlay nil
   "Overlay used by Hl-Line mode to highlight the current line.")
-(make-variable-buffer-local 'hl-line-overlay)
 
 (defvar global-hl-line-overlay nil
   "Overlay used by Global-Hl-Line mode to highlight the current line.")
@@ -155,13 +154,18 @@
     (remove-hook 'change-major-mode-hook #'hl-line-unhighlight t)
     (remove-hook 'pre-command-hook #'hl-line-unhighlight t)))
 
+(defun hl-line-make-overlay ()
+  (let ((ol (make-overlay (point) (point))))
+    (overlay-put ol 'priority -50)           ;(bug#16192)
+    (overlay-put ol 'face hl-line-face)
+    ol))
+
 (defun hl-line-highlight ()
   "Activate the Hl-Line overlay on the current line."
   (if hl-line-mode     ; Might be changed outside the mode function.
       (progn
         (unless hl-line-overlay
-          (setq hl-line-overlay (make-overlay 1 1)) ; to be moved
-          (overlay-put hl-line-overlay 'face hl-line-face))
+          (setq hl-line-overlay (hl-line-make-overlay))) ; To be moved.
         (overlay-put hl-line-overlay
                      'window (unless hl-line-sticky-flag (selected-window)))
        (hl-line-move hl-line-overlay))
@@ -200,8 +204,7 @@
   (when global-hl-line-mode    ; Might be changed outside the mode function.
     (unless (window-minibuffer-p)
       (unless global-hl-line-overlay
-        (setq global-hl-line-overlay (make-overlay 1 1)) ; to be moved
-        (overlay-put global-hl-line-overlay 'face hl-line-face))
+        (setq global-hl-line-overlay (hl-line-make-overlay))) ; To be moved.
       (overlay-put global-hl-line-overlay 'window
                   (unless global-hl-line-sticky-flag
                     (selected-window)))


reply via email to

[Prev in Thread] Current Thread [Next in Thread]