Mercurial > emacs
annotate lisp/ruler-mode.el @ 106768:21fd634f447a
Make line<->pixel_y conversion macros aware of native menu/tool bars.
They are placed above the internal border. This supersedes special
treatment of native tool bars in the display code.
This fixes wrong display position of native menu bars and bogus mouse
highlighting of native tool bars, both of which can be found when
internal border width is large. Also it fixes wrong flashed part on
visible bell with native menu bars.
* frame.h (FRAME_TOP_MARGIN_HEIGHT): New macro.
(FRAME_LINE_TO_PIXEL_Y, FRAME_PIXEL_Y_TO_LINE): Take account of pseudo
windows above internal border.
* window.h (WINDOW_MENU_BAR_P, WINDOW_TOOL_BAR_P): New macros.
(WINDOW_TOP_EDGE_Y, WINDOW_BOTTOM_EDGE_Y): Take account of pseudo
windows above internal border.
* xdisp.c (get_glyph_string_clip_rects, init_glyph_string): Don't treat
tool bar windows specially.
* xfns.c (x_set_tool_bar_lines): Take account of menu bar height.
* xterm.c (x_after_update_window_line): Don't treat tool bar windows
specially.
(XTflash): Take account of menu bar height.
* w32term.c (x_after_update_window_line): Don't treat tool bar windows
specially.
author | YAMAMOTO Mitsuharu <mituharu@math.s.chiba-u.ac.jp> |
---|---|
date | Sat, 09 Jan 2010 13:16:32 +0900 |
parents | a9dc0e7c3f2b |
children | 1d1d5d9bd884 |
rev | line source |
---|---|
42836
c6bcb27e426f
(ruler-mode): New keyword. Fix :version.
Pavel Janík <Pavel@Janik.cz>
parents:
42706
diff
changeset
|
1 ;;; ruler-mode.el --- display a ruler in the header line |
39731 | 2 |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
3 ;; Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, |
100908 | 4 ;; 2008, 2009 Free Software Foundation, Inc. |
39731 | 5 |
6 ;; Author: David Ponce <david@dponce.com> | |
7 ;; Maintainer: David Ponce <david@dponce.com> | |
8 ;; Created: 24 Mar 2001 | |
51389 | 9 ;; Version: 1.6 |
47183
865837df3fe7
(defgroup ruler-mode): Use `convenience' as parent.
Richard M. Stallman <rms@gnu.org>
parents:
45255
diff
changeset
|
10 ;; Keywords: convenience |
39731 | 11 |
12 ;; This file is part of GNU Emacs. | |
13 | |
94693
9276b559433c
Standardize permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94678
diff
changeset
|
14 ;; GNU Emacs is free software: you can redistribute it and/or modify |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
15 ;; it under the terms of the GNU General Public License as published by |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
16 ;; the Free Software Foundation, either version 3 of the License, or |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
17 ;; (at your option) any later version. |
39731 | 18 |
94693
9276b559433c
Standardize permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94678
diff
changeset
|
19 ;; GNU Emacs is distributed in the hope that it will be useful, |
94678
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
ee5932bf781d
Switch to recommended form of GPLv3 permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
93975
diff
changeset
|
22 ;; GNU General Public License for more details. |
39731 | 23 |
24 ;; You should have received a copy of the GNU General Public License | |
94693
9276b559433c
Standardize permissions notice.
Glenn Morris <rgm@gnu.org>
parents:
94678
diff
changeset
|
25 ;; along with GNU Emacs. If not, see <http://www.gnu.org/licenses/>. |
39731 | 26 |
27 ;;; Commentary: | |
28 | |
29 ;; This library provides a minor mode to display a ruler in the header | |
78041
5872a3a471bd
(ruler-mode): Prevent clobbering the original `header-line-format'
Juanma Barranquero <lekktu@gmail.com>
parents:
75229
diff
changeset
|
30 ;; line. It works from Emacs 21 onwards. |
39731 | 31 ;; |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
32 ;; You can use the mouse to change the `fill-column' `comment-column', |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
33 ;; `goal-column', `window-margins' and `tab-stop-list' settings: |
39731 | 34 ;; |
51389 | 35 ;; [header-line (shift down-mouse-1)] set left margin end to the ruler |
39731 | 36 ;; graduation where the mouse pointer is on. |
37 ;; | |
51389 | 38 ;; [header-line (shift down-mouse-3)] set right margin beginning to |
39 ;; the ruler graduation where the mouse pointer is on. | |
39731 | 40 ;; |
51389 | 41 ;; [header-line down-mouse-2] Drag the `fill-column', `comment-column' |
42 ;; or `goal-column' to a ruler graduation. | |
39731 | 43 ;; |
44 ;; [header-line (control down-mouse-1)] add a tab stop to the ruler | |
45 ;; graduation where the mouse pointer is on. | |
46 ;; | |
47 ;; [header-line (control down-mouse-3)] remove the tab stop at the | |
48 ;; ruler graduation where the mouse pointer is on. | |
49 ;; | |
50 ;; [header-line (control down-mouse-2)] or M-x | |
51 ;; `ruler-mode-toggle-show-tab-stops' toggle showing and visually | |
52 ;; editing `tab-stop-list' setting. The `ruler-mode-show-tab-stops' | |
53 ;; option controls if the ruler shows tab stops by default. | |
54 ;; | |
55 ;; In the ruler the character `ruler-mode-current-column-char' shows | |
56 ;; the `current-column' location, `ruler-mode-fill-column-char' shows | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
57 ;; the `fill-column' location, `ruler-mode-comment-column-char' shows |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
58 ;; the `comment-column' location, `ruler-mode-goal-column-char' shows |
51389 | 59 ;; the `goal-column' and `ruler-mode-tab-stop-char' shows tab stop |
60 ;; locations. Graduations in `window-margins' and `window-fringes' | |
61 ;; areas are shown with a different foreground color. | |
39731 | 62 ;; |
63 ;; It is also possible to customize the following characters: | |
64 ;; | |
65 ;; - `ruler-mode-basic-graduation-char' character used for basic | |
66 ;; graduations ('.' by default). | |
67 ;; - `ruler-mode-inter-graduation-char' character used for | |
68 ;; intermediate graduations ('!' by default). | |
69 ;; | |
70 ;; The following faces are customizable: | |
71 ;; | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
72 ;; - `ruler-mode-default' the ruler default face. |
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
73 ;; - `ruler-mode-fill-column' the face used to highlight the |
39731 | 74 ;; `fill-column' character. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
75 ;; - `ruler-mode-comment-column' the face used to highlight the |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
76 ;; `comment-column' character. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
77 ;; - `ruler-mode-goal-column' the face used to highlight the |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
78 ;; `goal-column' character. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
79 ;; - `ruler-mode-current-column' the face used to highlight the |
39731 | 80 ;; `current-column' character. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
81 ;; - `ruler-mode-tab-stop' the face used to highlight tab stop |
39731 | 82 ;; characters. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
83 ;; - `ruler-mode-margins' the face used to highlight graduations |
51389 | 84 ;; in the `window-margins' areas. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
85 ;; - `ruler-mode-fringes' the face used to highlight graduations |
51389 | 86 ;; in the `window-fringes' areas. |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
87 ;; - `ruler-mode-column-number' the face used to highlight the |
51389 | 88 ;; numbered graduations. |
39731 | 89 ;; |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
90 ;; `ruler-mode-default' inherits from the built-in `default' face. |
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
91 ;; All `ruler-mode' faces inherit from `ruler-mode-default'. |
39731 | 92 ;; |
93 ;; WARNING: To keep ruler graduations aligned on text columns it is | |
94 ;; important to use the same font family and size for ruler and text | |
95 ;; areas. | |
54399
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
96 ;; |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
97 ;; You can override the ruler format by defining an appropriate |
54399
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
98 ;; function as the buffer-local value of `ruler-mode-ruler-function'. |
39731 | 99 |
100 ;; Installation | |
101 ;; | |
102 ;; To automatically display the ruler in specific major modes use: | |
103 ;; | |
104 ;; (add-hook '<major-mode>-hook 'ruler-mode) | |
105 ;; | |
106 | |
107 ;;; History: | |
108 ;; | |
41461 | 109 |
39731 | 110 ;;; Code: |
111 (eval-when-compile | |
112 (require 'wid-edit)) | |
54399
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
113 (require 'scroll-bar) |
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
114 (require 'fringe) |
39731 | 115 |
116 (defgroup ruler-mode nil | |
117 "Display a ruler in the header line." | |
59996
aac0a33f5772
Change release version from 21.4 to 22.1 throughout.
Kim F. Storm <storm@cua.dk>
parents:
54440
diff
changeset
|
118 :version "22.1" |
47183
865837df3fe7
(defgroup ruler-mode): Use `convenience' as parent.
Richard M. Stallman <rms@gnu.org>
parents:
45255
diff
changeset
|
119 :group 'convenience) |
39731 | 120 |
121 (defcustom ruler-mode-show-tab-stops nil | |
100171 | 122 "If non-nil the ruler shows tab stop positions. |
39731 | 123 Also allowing to visually change `tab-stop-list' setting using |
124 <C-down-mouse-1> and <C-down-mouse-3> on the ruler to respectively add | |
125 or remove a tab stop. \\[ruler-mode-toggle-show-tab-stops] or | |
126 <C-down-mouse-2> on the ruler toggles showing/editing of tab stops." | |
127 :group 'ruler-mode | |
128 :type 'boolean) | |
129 | |
130 ;; IMPORTANT: This function must be defined before the following | |
131 ;; defcustoms because it is used in their :validate clause. | |
132 (defun ruler-mode-character-validate (widget) | |
133 "Ensure WIDGET value is a valid character value." | |
134 (save-excursion | |
135 (let ((value (widget-value widget))) | |
88997
71bcf52caa3b
(ruler-mode-character-validate): Use characterp.
Dave Love <fx@gnu.org>
parents:
42836
diff
changeset
|
136 (unless (characterp value) |
39731 | 137 (widget-put widget :error |
138 (format "Invalid character value: %S" value)) | |
139 widget)))) | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
140 |
52430 | 141 (defcustom ruler-mode-fill-column-char (if (char-displayable-p ?¶) |
39731 | 142 ?\¶ |
143 ?\|) | |
100171 | 144 "Character used at the `fill-column' location." |
39731 | 145 :group 'ruler-mode |
146 :type '(choice | |
147 (character :tag "Character") | |
148 (integer :tag "Integer char value" | |
149 :validate ruler-mode-character-validate))) | |
150 | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
151 (defcustom ruler-mode-comment-column-char ?\# |
100171 | 152 "Character used at the `comment-column' location." |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
153 :group 'ruler-mode |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
154 :type '(choice |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
155 (character :tag "Character") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
156 (integer :tag "Integer char value" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
157 :validate ruler-mode-character-validate))) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
158 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
159 (defcustom ruler-mode-goal-column-char ?G |
100171 | 160 "Character used at the `goal-column' location." |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
161 :group 'ruler-mode |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
162 :type '(choice |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
163 (character :tag "Character") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
164 (integer :tag "Integer char value" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
165 :validate ruler-mode-character-validate))) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
166 |
52430 | 167 (defcustom ruler-mode-current-column-char (if (char-displayable-p ?¦) |
39731 | 168 ?\¦ |
169 ?\@) | |
100171 | 170 "Character used at the `current-column' location." |
39731 | 171 :group 'ruler-mode |
172 :type '(choice | |
173 (character :tag "Character") | |
174 (integer :tag "Integer char value" | |
175 :validate ruler-mode-character-validate))) | |
176 | |
177 (defcustom ruler-mode-tab-stop-char ?\T | |
100171 | 178 "Character used at `tab-stop-list' locations." |
39731 | 179 :group 'ruler-mode |
180 :type '(choice | |
181 (character :tag "Character") | |
182 (integer :tag "Integer char value" | |
183 :validate ruler-mode-character-validate))) | |
184 | |
185 (defcustom ruler-mode-basic-graduation-char ?\. | |
100171 | 186 "Character used for basic graduations." |
39731 | 187 :group 'ruler-mode |
188 :type '(choice | |
189 (character :tag "Character") | |
190 (integer :tag "Integer char value" | |
191 :validate ruler-mode-character-validate))) | |
192 | |
193 (defcustom ruler-mode-inter-graduation-char ?\! | |
100171 | 194 "Character used for intermediate graduations." |
39731 | 195 :group 'ruler-mode |
196 :type '(choice | |
197 (character :tag "Character") | |
198 (integer :tag "Integer char value" | |
199 :validate ruler-mode-character-validate))) | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
200 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
201 (defcustom ruler-mode-set-goal-column-ding-flag t |
100171 | 202 "Non-nil means do `ding' when `goal-column' is set." |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
203 :group 'ruler-mode |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
204 :type 'boolean) |
41461 | 205 |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
206 (defface ruler-mode-default |
39731 | 207 '((((type tty)) |
208 (:inherit default | |
209 :background "grey64" | |
210 :foreground "grey50" | |
211 )) | |
212 (t | |
213 (:inherit default | |
214 :background "grey76" | |
215 :foreground "grey64" | |
216 :box (:color "grey76" | |
217 :line-width 1 | |
218 :style released-button) | |
219 ))) | |
220 "Default face used by the ruler." | |
221 :group 'ruler-mode) | |
222 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
223 (defface ruler-mode-pad |
51389 | 224 '((((type tty)) |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
225 (:inherit ruler-mode-default |
51389 | 226 :background "grey50" |
227 )) | |
228 (t | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
229 (:inherit ruler-mode-default |
51389 | 230 :background "grey64" |
231 ))) | |
232 "Face used to pad inactive ruler areas." | |
233 :group 'ruler-mode) | |
234 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
235 (defface ruler-mode-margins |
51389 | 236 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
237 (:inherit ruler-mode-default |
51389 | 238 :foreground "white" |
239 ))) | |
240 "Face used to highlight margin areas." | |
241 :group 'ruler-mode) | |
242 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
243 (defface ruler-mode-fringes |
51389 | 244 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
245 (:inherit ruler-mode-default |
51389 | 246 :foreground "green" |
247 ))) | |
248 "Face used to highlight fringes areas." | |
249 :group 'ruler-mode) | |
250 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
251 (defface ruler-mode-column-number |
39731 | 252 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
253 (:inherit ruler-mode-default |
39731 | 254 :foreground "black" |
255 ))) | |
256 "Face used to highlight number graduations." | |
257 :group 'ruler-mode) | |
258 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
259 (defface ruler-mode-fill-column |
39731 | 260 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
261 (:inherit ruler-mode-default |
39731 | 262 :foreground "red" |
263 ))) | |
264 "Face used to highlight the fill column character." | |
265 :group 'ruler-mode) | |
266 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
267 (defface ruler-mode-comment-column |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
268 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
269 (:inherit ruler-mode-default |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
270 :foreground "red" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
271 ))) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
272 "Face used to highlight the comment column character." |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
273 :group 'ruler-mode) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
274 |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
275 (defface ruler-mode-goal-column |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
276 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
277 (:inherit ruler-mode-default |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
278 :foreground "red" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
279 ))) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
280 "Face used to highlight the goal column character." |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
281 :group 'ruler-mode) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
282 |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
283 (defface ruler-mode-tab-stop |
39731 | 284 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
285 (:inherit ruler-mode-default |
39731 | 286 :foreground "steelblue" |
287 ))) | |
288 "Face used to highlight tab stop characters." | |
289 :group 'ruler-mode) | |
290 | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
291 (defface ruler-mode-current-column |
39731 | 292 '((t |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
293 (:inherit ruler-mode-default |
39731 | 294 :weight bold |
295 :foreground "yellow" | |
296 ))) | |
297 "Face used to highlight the `current-column' character." | |
298 :group 'ruler-mode) | |
41461 | 299 |
51389 | 300 |
301 (defsubst ruler-mode-full-window-width () | |
302 "Return the full width of the selected window." | |
303 (let ((edges (window-edges))) | |
304 (- (nth 2 edges) (nth 0 edges)))) | |
305 | |
306 (defsubst ruler-mode-window-col (n) | |
307 "Return a column number relative to the selected window. | |
308 N is a column number relative to selected frame." | |
309 (- n | |
310 (car (window-edges)) | |
311 (or (car (window-margins)) 0) | |
54401
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
312 (fringe-columns 'left) |
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
313 (scroll-bar-columns 'left))) |
51389 | 314 |
39731 | 315 (defun ruler-mode-mouse-set-left-margin (start-event) |
51389 | 316 "Set left margin end to the graduation where the mouse pointer is on. |
39731 | 317 START-EVENT is the mouse click event." |
318 (interactive "e") | |
319 (let* ((start (event-start start-event)) | |
320 (end (event-end start-event)) | |
51389 | 321 col w lm rm) |
322 (when (eq start end) ;; mouse click | |
323 (save-selected-window | |
324 (select-window (posn-window start)) | |
325 (setq col (- (car (posn-col-row start)) (car (window-edges)) | |
54401
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
326 (scroll-bar-columns 'left)) |
51389 | 327 w (- (ruler-mode-full-window-width) |
54401
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
328 (scroll-bar-columns 'left) |
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
329 (scroll-bar-columns 'right))) |
51389 | 330 (when (and (>= col 0) (< col w)) |
331 (setq lm (window-margins) | |
332 rm (or (cdr lm) 0) | |
333 lm (or (car lm) 0)) | |
334 (message "Left margin set to %d (was %d)" col lm) | |
335 (set-window-margins nil col rm)))))) | |
39731 | 336 |
337 (defun ruler-mode-mouse-set-right-margin (start-event) | |
51389 | 338 "Set right margin beginning to the graduation where the mouse pointer is on. |
39731 | 339 START-EVENT is the mouse click event." |
340 (interactive "e") | |
341 (let* ((start (event-start start-event)) | |
342 (end (event-end start-event)) | |
51389 | 343 col w lm rm) |
344 (when (eq start end) ;; mouse click | |
345 (save-selected-window | |
346 (select-window (posn-window start)) | |
347 (setq col (- (car (posn-col-row start)) (car (window-edges)) | |
54401
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
348 (scroll-bar-columns 'left)) |
51389 | 349 w (- (ruler-mode-full-window-width) |
54401
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
350 (scroll-bar-columns 'left) |
7f6dab15e141
2004-03-15 David Ponce <david@dponce.com>
Masatake YAMATO <jet@gyve.org>
parents:
54399
diff
changeset
|
351 (scroll-bar-columns 'right))) |
51389 | 352 (when (and (>= col 0) (< col w)) |
353 (setq lm (window-margins) | |
354 rm (or (cdr lm) 0) | |
355 lm (or (car lm) 0) | |
356 col (- w col 1)) | |
357 (message "Right margin set to %d (was %d)" col rm) | |
358 (set-window-margins nil lm col)))))) | |
39731 | 359 |
51389 | 360 (defvar ruler-mode-dragged-symbol nil |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
361 "Column symbol dragged in the ruler. |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
362 That is `fill-column', `comment-column', `goal-column', or nil when |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
363 nothing is dragged.") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
364 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
365 (defun ruler-mode-mouse-grab-any-column (start-event) |
51389 | 366 "Drag a column symbol on the ruler. |
367 Start dragging on mouse down event START-EVENT, and update the column | |
368 symbol value with the current value of the ruler graduation while | |
369 dragging. See also the variable `ruler-mode-dragged-symbol'." | |
39731 | 370 (interactive "e") |
51389 | 371 (setq ruler-mode-dragged-symbol nil) |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
372 (let* ((start (event-start start-event)) |
51389 | 373 col newc oldc) |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
374 (save-selected-window |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
375 (select-window (posn-window start)) |
51389 | 376 (setq col (ruler-mode-window-col (car (posn-col-row start))) |
377 newc (+ col (window-hscroll))) | |
378 (and | |
379 (>= col 0) (< col (window-width)) | |
380 (cond | |
381 | |
382 ;; Handle the fill column. | |
383 ((eq newc fill-column) | |
384 (setq oldc fill-column | |
385 ruler-mode-dragged-symbol 'fill-column) | |
386 t) ;; Start dragging | |
387 | |
388 ;; Handle the comment column. | |
389 ((eq newc comment-column) | |
390 (setq oldc comment-column | |
391 ruler-mode-dragged-symbol 'comment-column) | |
392 t) ;; Start dragging | |
393 | |
394 ;; Handle the goal column. | |
395 ;; A. On mouse down on the goal column character on the ruler, | |
396 ;; update the `goal-column' value while dragging. | |
397 ;; B. If `goal-column' is nil, set the goal column where the | |
398 ;; mouse is clicked. | |
399 ;; C. On mouse click on the goal column character on the | |
400 ;; ruler, unset the goal column. | |
401 ((eq newc goal-column) ; A. Drag the goal column. | |
402 (setq oldc goal-column | |
403 ruler-mode-dragged-symbol 'goal-column) | |
404 t) ;; Start dragging | |
405 | |
406 ((null goal-column) ; B. Set the goal column. | |
407 (setq oldc goal-column | |
408 goal-column newc) | |
409 ;; mouse-2 coming AFTER drag-mouse-2 invokes `ding'. This | |
410 ;; `ding' flushes the next messages about setting goal | |
411 ;; column. So here I force fetch the event(mouse-2) and | |
412 ;; throw away. | |
413 (read-event) | |
414 ;; Ding BEFORE `message' is OK. | |
415 (when ruler-mode-set-goal-column-ding-flag | |
416 (ding)) | |
417 (message "Goal column set to %d (click on %s again to unset it)" | |
418 newc | |
419 (propertize (char-to-string ruler-mode-goal-column-char) | |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
420 'face 'ruler-mode-goal-column)) |
51389 | 421 nil) ;; Don't start dragging. |
422 ) | |
423 (if (eq 'click (ruler-mode-mouse-drag-any-column-iteration | |
424 (posn-window start))) | |
425 (when (eq 'goal-column ruler-mode-dragged-symbol) | |
426 ;; C. Unset the goal column. | |
427 (set-goal-column t)) | |
428 ;; At end of dragging, report the updated column symbol. | |
429 (message "%s is set to %d (was %d)" | |
430 ruler-mode-dragged-symbol | |
431 (symbol-value ruler-mode-dragged-symbol) | |
432 oldc)))))) | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
433 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
434 (defun ruler-mode-mouse-drag-any-column-iteration (window) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
435 "Update the ruler while dragging the mouse. |
51389 | 436 WINDOW is the window where occurred the last down-mouse event. |
437 Return the symbol `drag' if the mouse has been dragged, or `click' if | |
438 the mouse has been clicked." | |
439 (let ((drags 0) | |
440 event) | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
441 (track-mouse |
51389 | 442 (while (mouse-movement-p (setq event (read-event))) |
443 (setq drags (1+ drags)) | |
444 (when (eq window (posn-window (event-end event))) | |
445 (ruler-mode-mouse-drag-any-column event) | |
446 (force-mode-line-update)))) | |
447 (if (and (zerop drags) (eq 'click (car (event-modifiers event)))) | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
448 'click |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
449 'drag))) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
450 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
451 (defun ruler-mode-mouse-drag-any-column (start-event) |
51389 | 452 "Update the value of the symbol dragged on the ruler. |
453 Called on each mouse motion event START-EVENT." | |
39731 | 454 (let* ((start (event-start start-event)) |
455 (end (event-end start-event)) | |
51389 | 456 col newc) |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
457 (save-selected-window |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
458 (select-window (posn-window start)) |
51389 | 459 (setq col (ruler-mode-window-col (car (posn-col-row end))) |
460 newc (+ col (window-hscroll))) | |
461 (when (and (>= col 0) (< col (window-width))) | |
462 (set ruler-mode-dragged-symbol newc))))) | |
41461 | 463 |
39731 | 464 (defun ruler-mode-mouse-add-tab-stop (start-event) |
465 "Add a tab stop to the graduation where the mouse pointer is on. | |
466 START-EVENT is the mouse click event." | |
467 (interactive "e") | |
51389 | 468 (when ruler-mode-show-tab-stops |
469 (let* ((start (event-start start-event)) | |
470 (end (event-end start-event)) | |
471 col ts) | |
472 (when (eq start end) ;; mouse click | |
473 (save-selected-window | |
474 (select-window (posn-window start)) | |
475 (setq col (ruler-mode-window-col (car (posn-col-row start))) | |
476 ts (+ col (window-hscroll))) | |
477 (and (>= col 0) (< col (window-width)) | |
478 (not (member ts tab-stop-list)) | |
479 (progn | |
480 (message "Tab stop set to %d" ts) | |
481 (setq tab-stop-list (sort (cons ts tab-stop-list) | |
482 #'<))))))))) | |
39731 | 483 |
484 (defun ruler-mode-mouse-del-tab-stop (start-event) | |
485 "Delete tab stop at the graduation where the mouse pointer is on. | |
486 START-EVENT is the mouse click event." | |
487 (interactive "e") | |
51389 | 488 (when ruler-mode-show-tab-stops |
489 (let* ((start (event-start start-event)) | |
490 (end (event-end start-event)) | |
491 col ts) | |
492 (when (eq start end) ;; mouse click | |
493 (save-selected-window | |
494 (select-window (posn-window start)) | |
495 (setq col (ruler-mode-window-col (car (posn-col-row start))) | |
496 ts (+ col (window-hscroll))) | |
497 (and (>= col 0) (< col (window-width)) | |
498 (member ts tab-stop-list) | |
499 (progn | |
500 (message "Tab stop at %d deleted" ts) | |
501 (setq tab-stop-list (delete ts tab-stop-list))))))))) | |
39731 | 502 |
503 (defun ruler-mode-toggle-show-tab-stops () | |
504 "Toggle showing of tab stops on the ruler." | |
505 (interactive) | |
41461 | 506 (setq ruler-mode-show-tab-stops (not ruler-mode-show-tab-stops)) |
507 (force-mode-line-update)) | |
508 | |
39731 | 509 (defvar ruler-mode-map |
510 (let ((km (make-sparse-keymap))) | |
511 (define-key km [header-line down-mouse-1] | |
512 #'ignore) | |
513 (define-key km [header-line down-mouse-3] | |
514 #'ignore) | |
515 (define-key km [header-line down-mouse-2] | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
516 #'ruler-mode-mouse-grab-any-column) |
39731 | 517 (define-key km [header-line (shift down-mouse-1)] |
518 #'ruler-mode-mouse-set-left-margin) | |
519 (define-key km [header-line (shift down-mouse-3)] | |
520 #'ruler-mode-mouse-set-right-margin) | |
521 (define-key km [header-line (control down-mouse-1)] | |
522 #'ruler-mode-mouse-add-tab-stop) | |
523 (define-key km [header-line (control down-mouse-3)] | |
524 #'ruler-mode-mouse-del-tab-stop) | |
525 (define-key km [header-line (control down-mouse-2)] | |
526 #'ruler-mode-toggle-show-tab-stops) | |
73777
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
527 (define-key km [header-line (shift mouse-1)] |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
528 'ignore) |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
529 (define-key km [header-line (shift mouse-3)] |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
530 'ignore) |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
531 (define-key km [header-line (control mouse-1)] |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
532 'ignore) |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
533 (define-key km [header-line (control mouse-3)] |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
534 'ignore) |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
535 (define-key km [header-line (control mouse-2)] |
461d1ed79b75
(ruler-mode-map): Add bindings for up-events so that they aren't undefined.
Richard M. Stallman <rms@gnu.org>
parents:
68651
diff
changeset
|
536 'ignore) |
39731 | 537 km) |
538 "Keymap for ruler minor mode.") | |
539 | |
540 (defvar ruler-mode-header-line-format-old nil | |
541 "Hold previous value of `header-line-format'.") | |
542 | |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
543 (defvar ruler-mode-ruler-function 'ruler-mode-ruler |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
544 "Function to call to return ruler header line format. |
54399
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
545 This variable is expected to be made buffer-local by modes.") |
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
546 |
39731 | 547 (defconst ruler-mode-header-line-format |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
548 '(:eval (funcall ruler-mode-ruler-function)) |
54399
ad02f6299e9a
2004-03-15 Masatake YAMATO <jet@gyve.org>
Masatake YAMATO <jet@gyve.org>
parents:
52889
diff
changeset
|
549 "`header-line-format' used in ruler mode. |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
550 Call `ruler-mode-ruler-function' to compute the ruler value.") |
39731 | 551 |
552 ;;;###autoload | |
553 (define-minor-mode ruler-mode | |
554 "Display a ruler in the header line if ARG > 0." | |
555 nil nil | |
556 ruler-mode-map | |
557 :group 'ruler-mode | |
558 (if ruler-mode | |
559 (progn | |
560 ;; When `ruler-mode' is on save previous header line format | |
561 ;; and install the ruler header line format. | |
78041
5872a3a471bd
(ruler-mode): Prevent clobbering the original `header-line-format'
Juanma Barranquero <lekktu@gmail.com>
parents:
75229
diff
changeset
|
562 (when (and (local-variable-p 'header-line-format) |
5872a3a471bd
(ruler-mode): Prevent clobbering the original `header-line-format'
Juanma Barranquero <lekktu@gmail.com>
parents:
75229
diff
changeset
|
563 (not (local-variable-p 'ruler-mode-header-line-format-old))) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
564 (set (make-local-variable 'ruler-mode-header-line-format-old) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
565 header-line-format)) |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
566 (setq header-line-format ruler-mode-header-line-format) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
567 (add-hook 'post-command-hook 'force-mode-line-update nil t)) |
39731 | 568 ;; When `ruler-mode' is off restore previous header line format if |
569 ;; the current one is the ruler header line format. | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
570 (when (eq header-line-format ruler-mode-header-line-format) |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
571 (kill-local-variable 'header-line-format) |
51389 | 572 (when (local-variable-p 'ruler-mode-header-line-format-old) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
573 (setq header-line-format ruler-mode-header-line-format-old) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
574 (kill-local-variable 'ruler-mode-header-line-format-old))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
575 (remove-hook 'post-command-hook 'force-mode-line-update t))) |
41461 | 576 |
42706 | 577 ;; Add ruler-mode to the minor mode menu in the mode line |
39731 | 578 (define-key mode-line-mode-menu [ruler-mode] |
579 `(menu-item "Ruler" ruler-mode | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
580 :button (:toggle . ruler-mode))) |
39731 | 581 |
582 (defconst ruler-mode-ruler-help-echo | |
583 "\ | |
584 S-mouse-1/3: set L/R margin, \ | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
585 mouse-2: set goal column, \ |
39731 | 586 C-mouse-2: show tabs" |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
587 "Help string shown when mouse is over the ruler. |
39731 | 588 `ruler-mode-show-tab-stops' is nil.") |
589 | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
590 (defconst ruler-mode-ruler-help-echo-when-goal-column |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
591 "\ |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
592 S-mouse-1/3: set L/R margin, \ |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
593 C-mouse-2: show tabs" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
594 "Help string shown when mouse is over the ruler. |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
595 `goal-column' is set and `ruler-mode-show-tab-stops' is nil.") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
596 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
597 (defconst ruler-mode-ruler-help-echo-when-tab-stops |
39731 | 598 "\ |
599 C-mouse1/3: set/unset tab, \ | |
600 C-mouse-2: hide tabs" | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
601 "Help string shown when mouse is over the ruler. |
39731 | 602 `ruler-mode-show-tab-stops' is non-nil.") |
603 | |
49195
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
604 (defconst ruler-mode-fill-column-help-echo |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
605 "drag-mouse-2: set fill column" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
606 "Help string shown when mouse is on the fill column character.") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
607 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
608 (defconst ruler-mode-comment-column-help-echo |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
609 "drag-mouse-2: set comment column" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
610 "Help string shown when mouse is on the comment column character.") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
611 |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
612 (defconst ruler-mode-goal-column-help-echo |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
613 "\ |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
614 drag-mouse-2: set goal column, \ |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
615 mouse-2: unset goal column" |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
616 "Help string shown when mouse is on the goal column character.") |
c297d31ef382
(ruler-mode-comment-column-char, ruler-mode-goal-column-char)
Juanma Barranquero <lekktu@gmail.com>
parents:
47425
diff
changeset
|
617 |
51389 | 618 (defconst ruler-mode-margin-help-echo |
619 "%s margin %S" | |
620 "Help string shown when mouse is over a margin area.") | |
42020
6e891121e1cc
(ruler-mode-extra-left-cols): Removed.
Richard M. Stallman <rms@gnu.org>
parents:
42003
diff
changeset
|
621 |
51389 | 622 (defconst ruler-mode-fringe-help-echo |
623 "%s fringe %S" | |
624 "Help string shown when mouse is over a fringe area.") | |
52889
615ebe291578
(ruler-mode-left-fringe-cols): Add new optional
Richard M. Stallman <rms@gnu.org>
parents:
52430
diff
changeset
|
625 |
615ebe291578
(ruler-mode-left-fringe-cols): Add new optional
Richard M. Stallman <rms@gnu.org>
parents:
52430
diff
changeset
|
626 (defsubst ruler-mode-space (width &rest props) |
615ebe291578
(ruler-mode-left-fringe-cols): Add new optional
Richard M. Stallman <rms@gnu.org>
parents:
52430
diff
changeset
|
627 "Return a single space string of WIDTH times the normal character width. |
615ebe291578
(ruler-mode-left-fringe-cols): Add new optional
Richard M. Stallman <rms@gnu.org>
parents:
52430
diff
changeset
|
628 Optional argument PROPS specifies other text properties to apply." |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
629 (apply 'propertize " " 'display (list 'space :width width) props)) |
41461 | 630 |
39731 | 631 (defun ruler-mode-ruler () |
75229
26181d6e6a87
(ruler-mode-ruler): Fix typo in docstring.
Juanma Barranquero <lekktu@gmail.com>
parents:
73777
diff
changeset
|
632 "Compute and return a header line ruler." |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
633 (let* ((w (window-width)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
634 (m (window-margins)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
635 (f (window-fringes)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
636 (i 0) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
637 (j (window-hscroll)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
638 ;; Setup the scrollbar, fringes, and margins areas. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
639 (lf (ruler-mode-space |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
640 'left-fringe |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
641 'face 'ruler-mode-fringes |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
642 'help-echo (format ruler-mode-fringe-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
643 "Left" (or (car f) 0)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
644 (rf (ruler-mode-space |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
645 'right-fringe |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
646 'face 'ruler-mode-fringes |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
647 'help-echo (format ruler-mode-fringe-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
648 "Right" (or (cadr f) 0)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
649 (lm (ruler-mode-space |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
650 'left-margin |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
651 'face 'ruler-mode-margins |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
652 'help-echo (format ruler-mode-margin-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
653 "Left" (or (car m) 0)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
654 (rm (ruler-mode-space |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
655 'right-margin |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
656 'face 'ruler-mode-margins |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
657 'help-echo (format ruler-mode-margin-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
658 "Right" (or (cdr m) 0)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
659 (sb (ruler-mode-space |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
660 'scroll-bar |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
661 'face 'ruler-mode-pad)) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
662 ;; Remember the scrollbar vertical type. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
663 (sbvt (car (window-current-scroll-bars))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
664 ;; Create an "clean" ruler. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
665 (ruler |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
666 (propertize |
100171 | 667 (string-to-multibyte |
90660
242b6dccacc1
(ruler-mode-ruler): Make the string `ruler'
Kenichi Handa <handa@m17n.org>
parents:
90650
diff
changeset
|
668 (make-string w ruler-mode-basic-graduation-char)) |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
669 'face 'ruler-mode-default |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
670 'local-map ruler-mode-map |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
671 'help-echo (cond |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
672 (ruler-mode-show-tab-stops |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
673 ruler-mode-ruler-help-echo-when-tab-stops) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
674 (goal-column |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
675 ruler-mode-ruler-help-echo-when-goal-column) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
676 (ruler-mode-ruler-help-echo)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
677 k c) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
678 ;; Setup the active area. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
679 (while (< i w) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
680 ;; Graduations. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
681 (cond |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
682 ;; Show a number graduation. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
683 ((= (mod j 10) 0) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
684 (setq c (number-to-string (/ j 10)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
685 m (length c) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
686 k i) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
687 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
688 i (1+ i) 'face 'ruler-mode-column-number |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
689 ruler) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
690 (while (and (> m 0) (>= k 0)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
691 (aset ruler k (aref c (setq m (1- m)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
692 (setq k (1- k)))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
693 ;; Show an intermediate graduation. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
694 ((= (mod j 5) 0) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
695 (aset ruler i ruler-mode-inter-graduation-char))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
696 ;; Special columns. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
697 (cond |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
698 ;; Show the `current-column' marker. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
699 ((= j (current-column)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
700 (aset ruler i ruler-mode-current-column-char) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
701 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
702 i (1+ i) 'face 'ruler-mode-current-column |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
703 ruler)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
704 ;; Show the `goal-column' marker. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
705 ((and goal-column (= j goal-column)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
706 (aset ruler i ruler-mode-goal-column-char) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
707 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
708 i (1+ i) 'face 'ruler-mode-goal-column |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
709 ruler) |
62651
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
710 (put-text-property |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
711 i (1+ i) 'mouse-face 'mode-line-highlight |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
712 ruler) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
713 (put-text-property |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
714 i (1+ i) 'help-echo ruler-mode-goal-column-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
715 ruler)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
716 ;; Show the `comment-column' marker. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
717 ((= j comment-column) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
718 (aset ruler i ruler-mode-comment-column-char) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
719 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
720 i (1+ i) 'face 'ruler-mode-comment-column |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
721 ruler) |
62651
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
722 (put-text-property |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
723 i (1+ i) 'mouse-face 'mode-line-highlight |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
724 ruler) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
725 (put-text-property |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
726 i (1+ i) 'help-echo ruler-mode-comment-column-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
727 ruler)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
728 ;; Show the `fill-column' marker. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
729 ((= j fill-column) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
730 (aset ruler i ruler-mode-fill-column-char) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
731 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
732 i (1+ i) 'face 'ruler-mode-fill-column |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
733 ruler) |
62651
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
734 (put-text-property |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
735 i (1+ i) 'mouse-face 'mode-line-highlight |
8d965863dd8c
Supprot mouse-face on mode-line.
Masatake YAMATO <jet@gyve.org>
parents:
59996
diff
changeset
|
736 ruler) |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
737 (put-text-property |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
738 i (1+ i) 'help-echo ruler-mode-fill-column-help-echo |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
739 ruler)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
740 ;; Show the `tab-stop-list' markers. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
741 ((and ruler-mode-show-tab-stops (member j tab-stop-list)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
742 (aset ruler i ruler-mode-tab-stop-char) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
743 (put-text-property |
63201
c1af317747bc
Revision: miles@gnu.org--gnu-2005/emacs--cvs-trunk--0--patch-372
Miles Bader <miles@gnu.org>
parents:
62651
diff
changeset
|
744 i (1+ i) 'face 'ruler-mode-tab-stop |
54440
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
745 ruler))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
746 (setq i (1+ i) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
747 j (1+ j))) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
748 ;; Return the ruler propertized string. Using list here, |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
749 ;; instead of concat visually separate the different areas. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
750 (if (nth 2 (window-fringes)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
751 ;; fringes outside margins. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
752 (list "" (and (eq 'left sbvt) sb) lf lm |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
753 ruler rm rf (and (eq 'right sbvt) sb)) |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
754 ;; fringes inside margins. |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
755 (list "" (and (eq 'left sbvt) sb) lm lf |
aabf30299e6c
From David Ponce <david@dponce.com>
Kim F. Storm <storm@cua.dk>
parents:
54401
diff
changeset
|
756 ruler rf rm (and (eq 'right sbvt) sb))))) |
39731 | 757 |
758 (provide 'ruler-mode) | |
759 | |
760 ;; Local Variables: | |
761 ;; coding: iso-latin-1 | |
762 ;; End: | |
763 | |
93975
1e3a407766b9
Fix up comment convention on the arch-tag lines.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
91327
diff
changeset
|
764 ;; arch-tag: b2f24546-5605-44c4-b67b-c9a4eeba3ee8 |
39731 | 765 ;;; ruler-mode.el ends here |