;;; col-highlight.el --- Highlight the current column. ;; ;; Filename: col-highlight.el ;; Description: Highlight the current column. ;; Author: Drew Adams ;; Maintainer: Drew Adams ;; Copyright (C) 2006-2011, Drew Adams, all rights reserved. ;; Created: Fri Sep 08 11:06:35 2006 ;; Version: 22.0 ;; Last-Updated: Mon Jan 3 19:55:33 2011 (-0800) ;; By: dradams ;; Update #: 320 ;; URL: http://www.emacswiki.org/cgi-bin/wiki/col-highlight.el ;; Keywords: faces, frames, emulation, highlight, cursor, accessibility ;; Compatibility: GNU Emacs: 22.x, 23.x ;; ;; Features that might be required by this library: ;; ;; `vline'. ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; ;;; Commentary: ;; ;; This library highlights the current column. When you move the ;; cursor, the highlighting follows (tracks the cursor), as long as ;; the highlighting stays on. ;; ;; Command `column-highlight-mode' toggles this highlighting on and ;; off. ;; ;; If you use `column-highlight-mode' twice in succession (I bind it ;; to `C-+'), you can flash the highlighting to show you the current ;; column temporarily. An alternative way to flash-highlight is to ;; use command `flash-column-highlight' (once). It shows the ;; highlighting for just a second or two (see option ;; `col-highlight-period'). ;; ;; You can also have current-column highlighting come on ;; automatically, when Emacs is idle. Command ;; `toggle-highlight-column-when-idle' toggles this mode. Command ;; `col-highlight-set-interval' changes the number of idle seconds to ;; wait before highlighting. ;; ;; ;; To use this file, you must also have library `vline.el'. ;; Put this in your Emacs init file (~/.emacs): ;; ;; (require 'col-highlight) ; Load this file (and `vline') ;; ;; If you want to turn on continual current-column highlighting by ;; default, then add this to your init file: ;; ;; (column-highlight-mode 1) ;; ;; If you want to turn on automatic idle highlighting of the current ;; column, then add this to your init file: ;; ;; (toggle-highlight-column-when-idle 1) ;; ;; If you want to use a different wait interval, before idle ;; highlighting begins, then set it in your init file using ;; `col-highlight-set-interval': ;; ;; (col-highlight-set-interval 6) ; Wait 6 idle secs. ;; ;; Note that `column-highlight-mode' is intentionally a global minor ;; mode. If you want a local minor mode, so that highlighting ;; affects only a particular buffer, you can use `vline-mode' (in ;; `vline.el'). ;; ;; ;; See also: ;; ;; * Library `hl-line+.el', which offers the same functionality, but ;; for the current line instead of the current column. ;; ;; * Library `crosshairs.el', which combines the features of ;; `col-highlight.el' and `hl-line+.el', providing a crosshair ;; highlighting effect. It requires `col-highlight.el' and ;; `hl-line+.el'. ;; ;; * Library `cursor-chg.el' or library `oneonone.el', to change the ;; cursor type when Emacs is idle. ;; ;; User options defined here: ;; ;; `col-highlight-period', `column-highlight-mode', ;; `col-highlight-vline-face-flag'. ;; ;; Faces defined here: ;; ;; `col-highlight'. ;; ;; Commands defined here: ;; ;; `col-highlight-flash', `col-highlight-set-interval', ;; `col-highlight-toggle-when-idle', `column-highlight-mode', ;; `flash-column-highlight', `toggle-highlight-column-when-idle'. ;; ;; Non-interactive functions defined here: ;; ;; `col-highlight-highlight', `col-highlight-unhighlight'. ;; ;; Internal variables defined here: ;; ;; `col-highlight-face', `col-highlight-idle-interval', ;; `col-highlight-idle-timer', `col-highlight-when-idle-p'. ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; ;;; Change log: ;; ;; 2011/01/03 dadams ;; Added autoload cookies for defgroup, defcustom, defface, and commands. ;; 2008/09/03 dadams ;; col-highlight-highlight: Bind vline-current-window-only to t. ;; 2008/08/08 dadams ;; col-highlight-(un)highlight: Added optional arg. ;; 2008/01/21 dadams ;; Use vline.el instead of column-marker.el. ;; Added: group column-highlight, option col-highlight-vline-face-flag. ;; col-highlight-toggle-when-idle: col-highlight-unhighlight when turn off. ;; col-highlight-flash: Use col-highlight-highlight, not mode. ;; col-highlight-(un)highlight: Respect col-highlight-vline-face-flag. ;; Don't highlight minibuffer. ;; Renamed: face col-highlight-face to col-highlight. ;; Removed semi-support for Emacs 20. ;; 2006/09/08 dadams ;; Created. ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; ;; This program is free software; you can redistribute it and/or ;; modify it under the terms of the GNU General Public License as ;; published by the Free Software Foundation; either version 3, or ;; (at your option) any later version. ;; ;; This program is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU ;; General Public License for more details. ;; ;; You should have received a copy of the GNU General Public License ;; along with this program; see the file COPYING. If not, write to ;; the Free Software Foundation, Inc., 51 Franklin Street, Fifth ;; Floor, Boston, MA 02110-1301, USA. ;; ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;; ;;; Code: (require 'vline) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;;###autoload (defgroup column-highlight nil "Highlight the current column." :prefix "col-highlight-" :group 'editing :group 'cursor :group 'hl-line :group 'frames :link `(url-link :tag "Send Bug Report" ,(concat "mailto:" "drew.adams" "@" "oracle" ".com?subject=\ col-highlight.el bug: \ &body=Describe bug here, starting with `emacs -q'. \ Don't forget to mention your Emacs and library versions.")) :link '(url-link :tag "Other Libraries by Drew" "http://www.emacswiki.org/cgi-bin/wiki/DrewsElispLibraries") :link '(url-link :tag "Download" "http://www.emacswiki.org/cgi-bin/wiki/col-highlight.el")) ;;;###autoload (defcustom col-highlight-vline-face-flag t "*Non-nil means `column-highlight-mode' uses `col-highlight-face'. nil means that it uses `vline-face'." :type 'boolean :group 'column-highlight) ;;;###autoload (defcustom col-highlight-period 1 "*Number of seconds to highlight the current column." :type 'integer :group 'column-highlight) ;;;###autoload (defface col-highlight '((t (:background "SlateGray3"))) "*Face for current-column highlighting by `column-highlight-mode'. Not used if `col-highlight-vline-face-flag' is nil." :group 'column-highlight :group 'faces) (defvar col-highlight-face 'col-highlight "Face used for highlighting current column. Do NOT change this.") (defvar col-highlight-idle-interval 5 "Number of seconds to wait before highlighting current column. Do NOT change this yourself to change the wait period; instead, use `\\[col-highlight-set-interval]'.") (defvar col-highlight-when-idle-p nil "Non-nil means highlight the current column whenever Emacs is idle. Do NOT change this yourself; instead, use `\\[toggle-highlight-column-when-idle]'.") (defvar col-highlight-idle-timer (progn ; Cancel to prevent duplication. (when (boundp 'col-highlight-idle-timer) (cancel-timer col-highlight-idle-timer)) (run-with-idle-timer col-highlight-idle-interval t 'col-highlight-highlight)) "Timer used to highlight current column whenever Emacs is idle.") ;; Turn it off, by default. ;; You must use `toggle-highlight-column-when-idle' to turn it on. (cancel-timer col-highlight-idle-timer) ;;;###autoload (define-minor-mode column-highlight-mode "Toggle highlighting the current column. With ARG, turn column highlighting on if and only if ARG is positive. Column-Highlight mode uses the functions `col-highlight-unhighlight' and `col-highlight-highlight' on `pre-command-hook' and `post-command-hook'." :init-value nil :global t :group 'column-highlight :link `(url-link :tag "Send Bug Report" ,(concat "mailto:" "drew.adams" "@" "oracle" ".com?subject=\ col-highlight.el bug: \ &body=Describe bug here, starting with `emacs -q'. \ Don't forget to mention your Emacs and library versions.")) :link '(url-link :tag "Other Libraries by Drew" "http://www.emacswiki.org/cgi-bin/wiki/DrewsElispLibraries") :link '(url-link :tag "Download" "http://www.emacswiki.org/cgi-bin/wiki/col-highlight.el") :link '(url-link :tag "Description" "http://www.emacswiki.org/cgi-bin/wiki/ChangingCursorDynamically") :link '(emacs-commentary-link :tag "Commentary" "col-highlight") (cond (column-highlight-mode (add-hook 'pre-command-hook #'col-highlight-unhighlight) (add-hook 'post-command-hook #'col-highlight-highlight)) (t (col-highlight-unhighlight) (remove-hook 'pre-command-hook #'col-highlight-unhighlight) (remove-hook 'post-command-hook #'col-highlight-highlight)))) ;;;###autoload (defalias 'toggle-highlight-column-when-idle 'col-highlight-toggle-when-idle) ;;;###autoload (defun col-highlight-toggle-when-idle (&optional arg) "Turn on or off highlighting the current column when Emacs is idle. With prefix argument, turn on if ARG > 0; else turn off." (interactive "P") (setq col-highlight-when-idle-p (if arg (> (prefix-numeric-value arg) 0) (not col-highlight-when-idle-p))) (cond (col-highlight-when-idle-p (timer-activate-when-idle col-highlight-idle-timer) (add-hook 'pre-command-hook #'col-highlight-unhighlight) (message "Turned ON highlighting current column when Emacs is idle.")) (t (cancel-timer col-highlight-idle-timer) (col-highlight-unhighlight) (remove-hook 'pre-command-hook #'col-highlight-unhighlight) (message "Turned OFF highlighting current column when Emacs is idle.")))) ;;;###autoload (defun col-highlight-set-interval (secs) "Set wait until highlight current column when Emacs is idle. Whenever Emacs is idle for this many seconds, the current column will be highlighted in the face that is the value of variable `col-highlight-face'. To turn on or off automatically highlighting the current column when Emacs is idle, use `\\[toggle-highlight-column-when-idle]." (interactive "nSeconds to idle, before highlighting current column: ") (timer-set-idle-time col-highlight-idle-timer (setq col-highlight-idle-interval secs) t)) ;;;###autoload (defalias 'flash-column-highlight 'col-highlight-flash) ;;;###autoload (defun col-highlight-flash (&optional arg) "Highlight the current column for `col-highlight-period' seconds. With a prefix argument, highlight for that many seconds." (interactive) (col-highlight-highlight) (let ((column-period col-highlight-period)) (when current-prefix-arg (setq column-period (prefix-numeric-value current-prefix-arg))) (run-at-time column-period nil #'col-highlight-unhighlight))) (defun col-highlight-highlight (&optional minibuffer-also-p) "Highlight current column." (unless (and (minibufferp) (not minibuffer-also-p)) (let ((vline-current-window-only t)) (if col-highlight-vline-face-flag (let ((vline-style 'face) (vline-face col-highlight-face)) (vline-show)) (vline-show))))) (defun col-highlight-unhighlight (&optional minibuffer-also-p) "Turn off highlighting of current column. If optional arg MINIBUFFER-ALSO-P is nil, then do nothing if the current buffer is the minibuffer. " (unless (and (minibufferp) (not minibuffer-also-p)) (if col-highlight-vline-face-flag (let ((vline-style 'face) (vline-face col-highlight-face)) (vline-clear)) (vline-clear)))) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; (provide 'col-highlight) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; ;;; col-highlight.el ends here