Mercurial > emacs
annotate lisp/msb.el @ 42811:cf0c0ef57504
*** empty log message ***
| author | Jason Rumney <jasonr@gnu.org> |
|---|---|
| date | Thu, 17 Jan 2002 19:29:24 +0000 |
| parents | 0f4506820432 |
| children | 964839c0844c |
| rev | line source |
|---|---|
|
38412
253f761ad37b
Some fixes to follow coding conventions in files maintained by FSF.
Pavel Jan?k <Pavel@Janik.cz>
parents:
36229
diff
changeset
|
1 ;;; msb.el --- customizable buffer-selection with multiple menus |
| 14169 | 2 |
| 35715 | 3 ;; Copyright (C) 1993, 94, 95, 97, 98, 99, 2000, 2001 |
| 4 ;; Free Software Foundation, Inc. | |
| 14169 | 5 |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
6 ;; Author: Lars Lindberg <Lars.G.Lindberg@capgemini.se> |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
7 ;; Maintainer: FSF |
| 10228 | 8 ;; Created: 8 Oct 1993 |
| 20901 | 9 ;; Lindberg's last update version: 3.34 |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
10 ;; Keywords: mouse buffer menu |
| 14169 | 11 |
| 12 ;; This file is part of GNU Emacs. | |
| 13 | |
| 14 ;; GNU Emacs is free software; you can redistribute it and/or modify | |
| 10228 | 15 ;; it under the terms of the GNU General Public License as published by |
| 14169 | 16 ;; the Free Software Foundation; either version 2, or (at your option) |
| 17 ;; any later version. | |
| 18 | |
| 19 ;; GNU Emacs is distributed in the hope that it will be useful, | |
| 10228 | 20 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of |
| 21 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
| 22 ;; GNU General Public License for more details. | |
| 14169 | 23 |
| 10228 | 24 ;; You should have received a copy of the GNU General Public License |
| 14169 | 25 ;; along with GNU Emacs; see the file COPYING. If not, write to the |
| 26 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
| 27 ;; Boston, MA 02111-1307, USA. | |
| 10228 | 28 |
| 29 ;;; Commentary: | |
| 14169 | 30 |
| 10228 | 31 ;; Purpose of this package: |
| 32 ;; 1. Offer a function for letting the user choose buffer, | |
| 33 ;; not necessarily for switching to it. | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
34 ;; 2. Make a better mouse-buffer-menu. This is done as a global |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
35 ;; minor mode, msb-mode. |
| 10228 | 36 ;; |
| 37 ;; Customization: | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
38 ;; Look at the variable `msb-menu-cond' for deciding what menus you |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
39 ;; want. It's not that hard to customize, despite my not-so-good |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
40 ;; doc-string. Feel free to send me a better doc-string. |
| 10228 | 41 ;; There are some constants for you to try here: |
| 42 ;; msb--few-menus | |
| 43 ;; msb--very-many-menus (default) | |
| 20901 | 44 ;; |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
45 ;; Look at the variable `msb-item-handling-function' for customization |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
46 ;; of the appearance of every menu item. Try for instance setting |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
47 ;; it to `msb-alon-item-handler'. |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
48 ;; |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
49 ;; Look at the variable `msb-item-sort-function' for customization |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
50 ;; of sorting the menus. Set it to t for instance, which means no |
| 10228 | 51 ;; sorting - you will get latest used buffer first. |
| 52 ;; | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
53 ;; Also check out the variable `msb-display-invisible-buffers-p'. |
| 10228 | 54 |
| 55 ;; Known bugs: | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
56 ;; - Files-by-directory |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
57 ;; + No possibility to show client/changed buffers separately. |
| 20901 | 58 ;; + All file buffers only appear in a file sub-menu, they will |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
59 ;; for instance not appear in the Mail sub-menu. |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
60 |
| 10228 | 61 ;; Future enhancements: |
| 62 | |
| 63 ;;; Thanks goes to | |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
64 ;; Mark Brader <msb@sq.com> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
65 ;; Jim Berry <m1jhb00@FRB.GOV> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
66 ;; Hans Chalupsky <hans@cs.Buffalo.EDU> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
67 ;; Larry Rosenberg <ljr@ictv.com> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
68 ;; Will Henney <will@astroscu.unam.mx> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
69 ;; Jari Aalto <jaalto@tre.tele.nokia.fi> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
70 ;; Michael Kifer <kifer@sbkifer.cs.sunysb.edu> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
71 ;; Gael Marziou <gael@gnlab030.grenoble.hp.com> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
72 ;; Dave Gillespie <daveg@thymus.synaptics.com> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
73 ;; Alon Albert <alon@milcse.rtsg.mot.com> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
74 ;; Kevin Broadey, <KevinB@bartley.demon.co.uk> |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
75 ;; Ake Stenhof <ake@cadpoint.se> |
| 25278 | 76 ;; Richard Stallman <rms@gnu.org> |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
77 ;; Steve Fisk <fisk@medved.bowdoin.edu> |
| 10228 | 78 |
| 25095 | 79 ;; This version turned into a global minor mode and subsequently |
| 80 ;; hacked on by Dave Love. | |
| 10228 | 81 ;;; Code: |
| 82 | |
| 25095 | 83 (eval-when-compile (require 'cl)) |
| 10228 | 84 |
| 85 ;;; | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
86 ;;; Some example constants to be used for `msb-menu-cond'. See that |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
87 ;;; variable for more information. Please note that if the condition |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
88 ;;; returns `multi', then the buffer can appear in several menus. |
| 10228 | 89 ;;; |
| 90 (defconst msb--few-menus | |
| 91 '(((and (boundp 'server-buffer-clients) | |
| 92 server-buffer-clients | |
| 93 'multi) | |
| 94 3030 | |
| 95 "Clients (%d)") | |
| 96 ((and msb-display-invisible-buffers-p | |
| 97 (msb-invisible-buffer-p) | |
| 98 'multi) | |
| 99 3090 | |
| 100 "Invisible buffers (%d)") | |
| 101 ((eq major-mode 'dired-mode) | |
| 102 2010 | |
| 103 "Dired (%d)" | |
| 104 msb-dired-item-handler | |
| 105 msb-sort-by-directory) | |
| 106 ((eq major-mode 'Man-mode) | |
| 107 4090 | |
| 108 "Manuals (%d)") | |
| 109 ((eq major-mode 'w3-mode) | |
| 110 4020 | |
| 111 "WWW (%d)") | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
112 ((or (memq major-mode |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
113 '(rmail-mode rmail-edit-mode vm-summary-mode vm-mode mail-mode)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
114 (memq major-mode '(mh-letter-mode mh-show-mode mh-folder-mode)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
115 (memq major-mode |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
116 '(gnus-summary-mode message-mode gnus-group-mode |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
117 gnus-article-mode score-mode gnus-browse-killed-mode))) |
| 10228 | 118 4010 |
| 119 "Mail (%d)") | |
| 120 ((not buffer-file-name) | |
| 121 4099 | |
| 122 "Buffers (%d)") | |
| 123 ('no-multi | |
| 124 1099 | |
| 125 "Files (%d)"))) | |
| 126 | |
| 127 (defconst msb--very-many-menus | |
| 128 '(((and (boundp 'server-buffer-clients) | |
| 129 server-buffer-clients | |
| 130 'multi) | |
| 131 1010 | |
| 132 "Clients (%d)") | |
| 133 ((and (boundp 'vc-mode) vc-mode 'multi) | |
| 134 1020 | |
| 135 "Version Control (%d)") | |
| 136 ((and buffer-file-name | |
| 137 (buffer-modified-p) | |
| 138 'multi) | |
| 139 1030 | |
| 140 "Changed files (%d)") | |
| 141 ((and (get-buffer-process (current-buffer)) | |
| 142 'multi) | |
| 143 1040 | |
| 144 "Processes (%d)") | |
| 145 ((and msb-display-invisible-buffers-p | |
| 146 (msb-invisible-buffer-p) | |
| 147 'multi) | |
| 148 1090 | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
149 "Invisible buffers (%d)") |
| 10228 | 150 ((eq major-mode 'dired-mode) |
| 151 2010 | |
| 152 "Dired (%d)" | |
| 153 ;; Note this different menu-handler | |
| 154 msb-dired-item-handler | |
| 155 ;; Also note this item-sorter | |
| 156 msb-sort-by-directory) | |
| 157 ((eq major-mode 'Man-mode) | |
| 20901 | 158 5030 |
| 10228 | 159 "Manuals (%d)") |
| 160 ((eq major-mode 'w3-mode) | |
| 20901 | 161 5020 |
| 10228 | 162 "WWW (%d)") |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
163 ((or (memq major-mode |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
164 '(rmail-mode rmail-edit-mode vm-summary-mode vm-mode mail-mode)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
165 (memq major-mode '(mh-letter-mode mh-show-mode mh-folder-mode)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
166 (memq major-mode '(gnus-summary-mode message-mode gnus-group-mode |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
167 gnus-article-mode score-mode |
| 10228 | 168 gnus-browse-killed-mode))) |
| 20901 | 169 5010 |
| 10228 | 170 "Mail (%d)") |
| 171 ;; Catchup for all non-file buffers | |
| 172 ((and (not buffer-file-name) | |
| 173 'no-multi) | |
| 20901 | 174 5099 |
| 10228 | 175 "Other non-file buffers (%d)") |
| 176 ((and (string-match "/\\.[^/]*$" buffer-file-name) | |
| 177 'multi) | |
| 178 3090 | |
| 179 "Hidden Files (%d)") | |
| 180 ((memq major-mode '(c-mode c++-mode)) | |
| 181 3010 | |
| 182 "C/C++ Files (%d)") | |
| 183 ((eq major-mode 'emacs-lisp-mode) | |
| 184 3020 | |
| 185 "Elisp Files (%d)") | |
| 186 ((eq major-mode 'latex-mode) | |
| 187 3030 | |
| 188 "LaTex Files (%d)") | |
| 189 ('no-multi | |
| 190 3099 | |
| 191 "Other files (%d)"))) | |
| 192 | |
| 193 ;; msb--many-menus is obsolete | |
| 194 (defvar msb--many-menus msb--very-many-menus) | |
| 195 | |
| 196 ;;; | |
| 197 ;;; Customizable variables | |
| 198 ;;; | |
| 199 | |
| 20901 | 200 (defgroup msb nil |
| 201 "Customizable buffer-selection with multiple menus." | |
| 202 :prefix "msb-" | |
| 203 :group 'mouse) | |
| 10228 | 204 |
| 20901 | 205 (defun msb-custom-set (symbol value) |
| 206 "Set the value of custom variables for msb." | |
| 207 (set symbol value) | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
208 (if (and (featurep 'msb) msb-mode) |
| 20901 | 209 ;; wait until package has been loaded before bothering to update |
| 210 ;; the buffer lists. | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
211 (msb-menu-bar-update-buffers t))) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
212 |
| 20901 | 213 (defcustom msb-menu-cond msb--very-many-menus |
|
13998
2f2d3995b57f
(msb-max-file-menu-items, msb-menu-cond): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
13372
diff
changeset
|
214 "*List of criteria for splitting the mouse buffer menu. |
| 10228 | 215 The elements in the list should be of this type: |
| 216 (CONDITION MENU-SORT-KEY MENU-TITLE ITEM-HANDLING-FN ITEM-SORT-FN). | |
| 217 | |
| 218 When making the split, the buffers are tested one by one against the | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
219 CONDITION, just like a Lisp cond: When hitting a true condition, the |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
220 other criteria are *not* tested and the buffer name will appear in the |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
221 menu with the menu-title corresponding to the true condition. |
| 10228 | 222 |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
223 If the condition returns the symbol `multi', then the buffer will be |
| 10228 | 224 added to this menu *and* tested for other menus too. If it returns |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
225 `no-multi', then the buffer will only be added if it hasn't been added |
| 10228 | 226 to any other menu. |
| 227 | |
| 228 During this test, the buffer in question is the current buffer, and | |
| 229 the test is surrounded by calls to `save-excursion' and | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
230 `save-match-data'. |
| 10228 | 231 |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
232 The categories are sorted by MENU-SORT-KEY. Smaller keys are on top. |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
233 nil means don't display this menu. |
| 10228 | 234 |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
235 MENU-TITLE is really a format. If you add %d in it, the %d is |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
236 replaced with the number of items in that menu. |
| 10228 | 237 |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
238 ITEM-HANDLING-FN, is optional. If it is supplied and is a function, |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
239 than it is used for displaying the items in that particular buffer |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
240 menu, otherwise the function pointed out by |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
241 `msb-item-handling-function' is used. |
| 10228 | 242 |
| 243 ITEM-SORT-FN, is also optional. | |
| 244 If it is not supplied, the function pointed out by | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
245 `msb-item-sort-function' is used. |
| 10228 | 246 If it is nil, then no sort takes place and the buffers are presented |
| 247 in least-recently-used order. | |
| 248 If it is t, then no sort takes place and the buffers are presented in | |
| 249 most-recently-used order. | |
| 250 If it is supplied and non-nil and not t than it is used for sorting | |
| 251 the items in that particular buffer menu. | |
| 252 | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
253 Note1: There should always be a `catch-all' as last element, in this |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
254 list. That is an element like (t TITLE ITEM-HANDLING-FUNCTION). |
| 10228 | 255 Note2: A buffer menu appears only if it has at least one buffer in it. |
| 256 Note3: If you have a CONDITION that can't be evaluated you will get an | |
| 20901 | 257 error every time you do \\[msb]." |
| 258 :type `(choice (const :tag "long" :value ,msb--very-many-menus) | |
|
28977
7322c22e17b0
(msb-menu-cond): Add choice `user'.
Gerd Moellmann <gerd@gnu.org>
parents:
28300
diff
changeset
|
259 (const :tag "short" :value ,msb--few-menus) |
|
7322c22e17b0
(msb-menu-cond): Add choice `user'.
Gerd Moellmann <gerd@gnu.org>
parents:
28300
diff
changeset
|
260 (sexp :tag "user")) |
| 20901 | 261 :set 'msb-custom-set |
| 262 :group 'msb) | |
| 263 | |
| 264 (defcustom msb-modes-key 4000 | |
| 265 "The sort key for files sorted by mode." | |
| 266 :type 'integer | |
| 267 :set 'msb-custom-set | |
|
21670
808ecc2eaa84
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20901
diff
changeset
|
268 :group 'msb |
|
808ecc2eaa84
*** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents:
20901
diff
changeset
|
269 :version "20.3") |
| 20901 | 270 |
| 271 (defcustom msb-separator-diff 100 | |
| 272 "*Non-nil means use separators. | |
| 273 The separators will appear between all menus that have a sorting key | |
| 274 that differs by this value or more." | |
| 275 :type '(choice integer (const nil)) | |
| 276 :set 'msb-custom-set | |
| 277 :group 'msb) | |
| 278 | |
| 279 (defvar msb-files-by-directory-sort-key 0 | |
| 280 "*The sort key for files sorted by directory.") | |
| 281 | |
| 282 (defcustom msb-max-menu-items 15 | |
| 283 "*The maximum number of items in a menu. | |
| 284 If this variable is set to 15 for instance, then the submenu will be | |
| 42206 | 285 split up in minor parts, 15 items each. nil means no limit." |
| 20901 | 286 :type '(choice integer (const nil)) |
| 287 :set 'msb-custom-set | |
| 288 :group 'msb) | |
| 289 | |
| 290 (defcustom msb-max-file-menu-items 10 | |
| 291 "*The maximum number of items from different directories. | |
| 292 | |
| 293 When the menu is of type `file by directory', this is the maximum | |
| 294 number of buffers that are clumped together from different | |
| 295 directories. | |
| 296 | |
| 297 Set this to 1 if you want one menu per directory instead of clumping | |
| 298 them together. | |
| 299 | |
| 300 If the value is not a number, then the value 10 is used." | |
| 301 :type 'integer | |
| 302 :set 'msb-custom-set | |
| 303 :group 'msb) | |
| 304 | |
| 305 (defcustom msb-most-recently-used-sort-key -1010 | |
| 306 "*Where should the menu with the most recently used buffers be placed?" | |
| 307 :type 'integer | |
| 308 :set 'msb-custom-set | |
| 309 :group 'msb) | |
| 310 | |
| 311 (defcustom msb-display-most-recently-used 15 | |
| 312 "*How many buffers should be in the most-recently-used menu. | |
| 313 No buffers at all if less than 1 or nil (or any non-number)." | |
| 314 :type 'integer | |
| 315 :set 'msb-custom-set | |
| 316 :group 'msb) | |
| 10228 | 317 |
| 20901 | 318 (defcustom msb-most-recently-used-title "Most recently used (%d)" |
| 319 "*The title for the most-recently-used menu." | |
| 320 :type 'string | |
| 321 :set 'msb-custom-set | |
| 322 :group 'msb) | |
| 323 | |
| 324 (defvar msb-horizontal-shift-function '(lambda () 0) | |
| 325 "*Function that specifies how many pixels to shift the top menu leftwards.") | |
| 326 | |
| 327 (defcustom msb-display-invisible-buffers-p nil | |
| 328 "*Show invisible buffers or not. | |
| 329 Non-nil means that the buffer menu should include buffers that have | |
| 330 names that starts with a space character." | |
| 331 :type 'boolean | |
| 332 :set 'msb-custom-set | |
| 333 :group 'msb) | |
| 334 | |
| 335 (defvar msb-item-handling-function 'msb-item-handler | |
| 336 "*The appearance of a buffer menu. | |
| 337 | |
| 338 The default function to call for handling the appearance of a menu | |
| 339 item. It should take to arguments, BUFFER and MAX-BUFFER-NAME-LENGTH, | |
| 340 where the latter is the max length of all buffer names. | |
| 341 | |
| 342 The function should return the string to use in the menu. | |
| 343 | |
| 344 When the function is called, BUFFER is the current buffer. This | |
| 345 function is called for items in the variable `msb-menu-cond' that have | |
| 346 nil as ITEM-HANDLING-FUNCTION. See `msb-menu-cond' for more | |
| 347 information.") | |
| 348 | |
| 349 (defcustom msb-item-sort-function 'msb-sort-by-name | |
| 350 "*The order of items in a buffer menu. | |
| 351 | |
| 352 The default function to call for handling the order of items in a menu | |
| 353 item. This function is called like a sort function. The items look | |
| 354 like (ITEM-NAME . BUFFER). | |
| 355 | |
| 356 ITEM-NAME is the name of the item that will appear in the menu. | |
| 357 BUFFER is the buffer, this is not necessarily the current buffer. | |
| 358 | |
| 359 Set this to nil or t if you don't want any sorting (faster)." | |
| 360 :type '(choice (const msb-sort-by-name) | |
| 361 (const :tag "Newest first" t) | |
| 362 (const :tag "Oldest first" nil)) | |
| 363 :set 'msb-custom-set | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
364 :group 'msb) |
| 20901 | 365 |
| 366 (defcustom msb-files-by-directory nil | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
367 "*Non-nil means that files should be sorted by directory. |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
368 This is instead of the groups in `msb-menu-cond'." |
| 20901 | 369 :type 'boolean |
| 370 :set 'msb-custom-set | |
| 371 :group 'msb) | |
| 372 | |
|
33192
76b47f37d61c
(msb-mode): Drop unneeded positional args.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31812
diff
changeset
|
373 (defcustom msb-after-load-hook nil |
|
76b47f37d61c
(msb-mode): Drop unneeded positional args.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
31812
diff
changeset
|
374 "Hook run after the msb package has been loaded." |
| 20901 | 375 :type 'hook |
| 376 :set 'msb-custom-set | |
| 377 :group 'msb) | |
| 10228 | 378 |
| 379 ;;; | |
| 380 ;;; Internal variables | |
| 381 ;;; | |
| 382 | |
| 383 ;; The last calculated menu. | |
| 384 (defvar msb--last-buffer-menu nil) | |
| 385 | |
| 386 ;; If this is non-nil, then it is a string that describes the error. | |
| 387 (defvar msb--error nil) | |
| 388 | |
| 389 ;;; | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
390 ;;; Some example function to be used for `msb-item-handling-function'. |
| 10228 | 391 ;;; |
| 392 (defun msb-item-handler (buffer &optional maxbuf) | |
| 393 "Create one string item, concerning BUFFER, for the buffer menu. | |
| 394 The item looks like: | |
| 395 *% <buffer-name> | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
396 The `*' appears only if the buffer is marked as modified. |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
397 The `%' appears only if the buffer is read-only. |
| 10228 | 398 Optional second argument MAXBUF is completely ignored." |
| 399 (let ((name (buffer-name)) | |
| 400 (modified (if (buffer-modified-p) "*" " ")) | |
| 401 (read-only (if buffer-read-only "%" " "))) | |
| 402 (format "%s%s %s" modified read-only name))) | |
| 403 | |
| 404 | |
| 405 (eval-when-compile (require 'dired)) | |
| 406 | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
407 ;; `dired' can be called with a list of the form (directory file1 file2 ...) |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
408 ;; which causes `dired-directory' to be in the same form. |
| 10228 | 409 (defun msb--dired-directory () |
| 410 (cond ((stringp dired-directory) | |
| 411 (abbreviate-file-name (expand-file-name dired-directory))) | |
| 412 ((consp dired-directory) | |
| 413 (abbreviate-file-name (expand-file-name (car dired-directory)))) | |
| 414 (t | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
415 (error "Unknown type of `dired-directory' in buffer %s" |
| 10228 | 416 (buffer-name))))) |
| 417 | |
| 418 (defun msb-dired-item-handler (buffer &optional maxbuf) | |
| 419 "Create one string item, concerning a dired BUFFER, for the buffer menu. | |
| 420 The item looks like: | |
| 421 *% <buffer-name> | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
422 The `*' appears only if the buffer is marked as modified. |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
423 The `%' appears only if the buffer is read-only. |
| 10228 | 424 Optional second argument MAXBUF is completely ignored." |
| 425 (let ((name (msb--dired-directory)) | |
| 426 (modified (if (buffer-modified-p) "*" " ")) | |
| 427 (read-only (if buffer-read-only "%" " "))) | |
| 428 (format "%s%s %s" modified read-only name))) | |
| 429 | |
| 430 (defun msb-alon-item-handler (buffer maxbuf) | |
| 431 "Create one string item for the buffer menu. | |
| 432 The item looks like: | |
| 433 <buffer-name> *%# <file-name> | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
434 The `*' appears only if the buffer is marked as modified. |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
435 The `%' appears only if the buffer is read-only. |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
436 The `#' appears only version control file (SCCS/RCS)." |
| 10228 | 437 (format (format "%%%ds %%s%%s%%s %%s" maxbuf) |
| 438 (buffer-name buffer) | |
| 439 (if (buffer-modified-p) "*" " ") | |
| 440 (if buffer-read-only "%" " ") | |
| 441 (if (and (boundp 'vc-mode) vc-mode) "#" " ") | |
| 442 (or buffer-file-name ""))) | |
| 443 | |
| 444 ;;; | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
445 ;;; Some example function to be used for `msb-item-sort-function'. |
| 10228 | 446 ;;; |
| 447 (defun msb-sort-by-name (item1 item2) | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
448 "Sort the items ITEM1 and ITEM2 by their `buffer-name'. |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
449 An item looks like (NAME . BUFFER)." |
| 10228 | 450 (string-lessp (buffer-name (cdr item1)) |
| 451 (buffer-name (cdr item2)))) | |
| 452 | |
| 453 | |
| 454 (defun msb-sort-by-directory (item1 item2) | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
455 "Sort the items ITEM1 and ITEM2 by directory name. Made for dired. |
| 10228 | 456 An item look like (NAME . BUFFER)." |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
457 (string-lessp (save-excursion (set-buffer (cdr item1)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
458 (msb--dired-directory)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
459 (save-excursion (set-buffer (cdr item2)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
460 (msb--dired-directory)))) |
| 10228 | 461 |
| 462 ;;; | |
| 463 ;;; msb | |
| 464 ;;; | |
| 465 ;;; This function can be used instead of (mouse-buffer-menu EVENT) | |
| 466 ;;; function in "mouse.el". | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
467 ;;; |
| 10228 | 468 (defun msb (event) |
| 469 "Pop up several menus of buffers for selection with the mouse. | |
| 470 This command switches buffers in the window that you clicked on, and | |
| 471 selects that window. | |
| 472 | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
473 See the function `mouse-select-buffer' and the variable |
|
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
474 `msb-menu-cond' for more information about how the menus are split." |
| 10228 | 475 (interactive "e") |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
476 (let ((old-window (selected-window)) |
| 10228 | 477 (window (posn-window (event-start event)))) |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
478 (unless (framep window) (select-window window)) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
479 (let ((buffer (mouse-select-buffer event))) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
480 (if buffer |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
481 (switch-to-buffer buffer) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
482 (select-window old-window)))) |
| 10228 | 483 nil) |
| 484 | |
| 485 ;;; | |
| 486 ;;; Some supportive functions | |
| 487 ;;; | |
| 488 (defun msb-invisible-buffer-p (&optional buffer) | |
| 489 "Return t if optional BUFFER is an \"invisible\" buffer. | |
| 490 If the argument is left out or nil, then the current buffer is considered." | |
| 491 (and (> (length (buffer-name buffer)) 0) | |
| 492 (eq ?\ (aref (buffer-name buffer) 0)))) | |
| 493 | |
| 20505 | 494 (defun msb--strip-dir (dir) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
495 "Strip one hierarchy level from the end of DIR." |
|
20758
f5a113b108ff
(msb--strip-dir): Use Emacs filename primitives, not regexps.
Richard M. Stallman <rms@gnu.org>
parents:
20506
diff
changeset
|
496 (file-name-directory (directory-file-name dir))) |
| 10228 | 497 |
| 498 ;; Create an alist with all buffers from LIST that lies under the same | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
499 ;; directory will be in the same item as the directory string. |
|
20506
c096aa581013
Fix mailer-introduced garbling.
Richard M. Stallman <rms@gnu.org>
parents:
20505
diff
changeset
|
500 ;; ((PATH1 . (BUFFER-1 BUFFER-2 ...)) (PATH2 . (BUFFER-K BUFFER-K+1...)) ...) |
| 10228 | 501 (defun msb--init-file-alist (list) |
| 502 (let ((buffer-alist | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
503 ;; Make alist that looks like |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
504 ;; ((PATH-1 BUFFER-1) (PATH-2 BUFFER-2) ...) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
505 ;; sorted on PATH-x |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
506 (sort |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
507 (apply #'nconc |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
508 (mapcar |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
509 (lambda (buffer) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
510 (let ((file-name (expand-file-name |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
511 (buffer-file-name buffer)))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
512 (when file-name |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
513 (list (cons (msb--strip-dir file-name) buffer))))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
514 list)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
515 (lambda (item1 item2) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
516 (string< (car item1) (car item2)))))) |
|
20884
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
517 ;; Now clump buffers together that have the same path |
| 10228 | 518 ;; Make alist that looks like |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
519 ;; ((PATH1 . (BUFFER-1 BUFFER-2 ...)) (PATH2 . (BUFFER-K)) ...) |
| 10228 | 520 (let ((path nil) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
521 (buffers nil)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
522 (nconc |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
523 (apply |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
524 #'nconc |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
525 (mapcar (lambda (item) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
526 (cond |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
527 ((equal path (car item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
528 ;; The same path as earlier: Add to current list of |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
529 ;; buffers. |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
530 (push (cdr item) buffers) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
531 ;; This item should not be added to list |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
532 nil) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
533 (t |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
534 ;; New path |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
535 (let ((result (and path (cons path buffers)))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
536 (setq path (car item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
537 (setq buffers (list (cdr item))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
538 ;; Add the last result the list. |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
539 (and result (list result)))))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
540 buffer-alist)) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
541 ;; Add the last result to the list |
| 10228 | 542 (list (cons path buffers)))))) |
| 543 | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
544 (defun msb--format-title (top-found-p path number-of-items) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
545 "Format a suitable title for the menu item." |
| 25095 | 546 (format (if top-found-p "%s... (%d)" "%s (%d)") |
| 547 (abbreviate-file-name path) number-of-items)) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
548 |
|
20884
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
549 ;; Variables for debugging. |
|
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
550 (defvar msb--choose-file-menu-list) |
|
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
551 (defvar msb--choose-file-menu-arg-list) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
552 |
| 10228 | 553 (defun msb--choose-file-menu (list) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
554 "Choose file-menu with respect to directory for every buffer in LIST." |
|
20884
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
555 (setq msb--choose-file-menu-arg-list list) |
| 10228 | 556 (let ((buffer-alist (msb--init-file-alist list)) |
| 557 (final-list nil) | |
| 558 (max-clumped-together (if (numberp msb-max-file-menu-items) | |
| 559 msb-max-file-menu-items | |
| 560 10)) | |
| 561 (top-found-p nil) | |
| 562 (last-path nil) | |
| 20901 | 563 first rest path buffers old-path) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
564 ;; Prepare for looping over all items in buffer-alist |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
565 (setq first (car buffer-alist) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
566 rest (cdr buffer-alist) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
567 path (car first) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
568 buffers (cdr first)) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
569 (setq msb--choose-file-menu-list (copy-sequence rest)) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
570 ;; This big loop tries to clump buffers together that have a |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
571 ;; similar name. Remember that buffer-alist is sorted based on the |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
572 ;; path for the buffers. |
| 10228 | 573 (while rest |
| 574 (let ((found-p nil) | |
| 575 (tmp-rest rest) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
576 result |
| 10228 | 577 new-path item) |
| 578 (setq item (car tmp-rest)) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
579 ;; Clump together the "rest"-buffers that have a path that is |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
580 ;; a subpath of the current one. |
| 10228 | 581 (while (and tmp-rest |
| 582 (<= (length buffers) max-clumped-together) | |
| 583 (>= (length (car item)) (length path)) | |
|
25281
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
584 ;; `completion-ignore-case' seems to default to t |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
585 ;; on the systems with case-insensitive file names. |
|
25123
abf35a5606f6
(msb--choose-file-menu): Fix previous change.
Dave Love <fx@gnu.org>
parents:
25095
diff
changeset
|
586 (eq t (compare-strings path 0 nil |
|
25281
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
587 (car item) 0 (length path) |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
588 completion-ignore-case))) |
| 10228 | 589 (setq found-p t) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
590 (setq buffers (append buffers (cdr item))) ;nconc is faster than append |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
591 (setq tmp-rest (cdr tmp-rest) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
592 item (car tmp-rest))) |
| 10228 | 593 (cond |
| 594 ((> (length buffers) max-clumped-together) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
595 ;; Oh, we failed. Too many buffers clumped together. |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
596 ;; Just use the original ones for the result. |
| 10228 | 597 (setq last-path (car first)) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
598 (push (cons (msb--format-title top-found-p |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
599 (car first) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
600 (length (cdr first))) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
601 (cdr first)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
602 final-list) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
603 (setq top-found-p nil) |
| 10228 | 604 (setq first (car rest) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
605 rest (cdr rest) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
606 path (car first) |
| 10228 | 607 buffers (cdr first))) |
| 608 (t | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
609 ;; The first pass of clumping together worked out, go ahead |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
610 ;; with this result. |
| 10228 | 611 (when found-p |
| 612 (setq top-found-p t) | |
| 613 (setq first (cons path buffers) | |
| 614 rest tmp-rest)) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
615 ;; Now see if we can clump more buffers together if we go up |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
616 ;; one step in the file hierarchy. |
| 20901 | 617 ;; If path isn't changed by msb--strip-dir, we are looking |
| 618 ;; at the machine name component of an ange-ftp filename. | |
| 619 (setq old-path path) | |
| 20505 | 620 (setq path (msb--strip-dir path) |
| 10228 | 621 buffers (cdr first)) |
| 20901 | 622 (if (equal old-path path) |
| 623 (setq last-path path)) | |
| 10228 | 624 (when (and last-path |
| 625 (or (and (>= (length path) (length last-path)) | |
|
25281
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
626 (eq t (compare-strings |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
627 last-path 0 nil path 0 |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
628 (length last-path) |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
629 completion-ignore-case))) |
| 10228 | 630 (and (< (length path) (length last-path)) |
|
25281
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
631 (eq t (compare-strings |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
632 path 0 nil last-path 0 (length path) |
|
26430a2408d5
(msb--choose-file-menu): Use `completion-ignore-case' in name
Dave Love <fx@gnu.org>
parents:
25278
diff
changeset
|
633 completion-ignore-case))))) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
634 ;; We have reached the same place in the file hierarchy as |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
635 ;; the last result, so we should quit at this point and |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
636 ;; take what we have as result. |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
637 (push (cons (msb--format-title top-found-p |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
638 (car first) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
639 (length (cdr first))) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
640 (cdr first)) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
641 final-list) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
642 (setq top-found-p nil) |
| 10228 | 643 (setq first (car rest) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
644 rest (cdr rest) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
645 path (car first) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
646 buffers (cdr first))))))) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
647 ;; Now take care of the last item. |
| 20901 | 648 (when first |
| 649 (push (cons (msb--format-title top-found-p | |
| 650 (car first) | |
| 651 (length (cdr first))) | |
| 652 (cdr first)) | |
| 653 final-list)) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
654 (setq top-found-p nil) |
| 10228 | 655 (nreverse final-list))) |
| 656 | |
| 657 (defun msb--create-function-info (menu-cond-elt) | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
658 "Create a vector from an element MENU-COND-ELT of `msb-menu-cond'. |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
659 This takes the form: |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
660 \]BUFFER-LIST-VARIABLE CONDITION MENU-SORT-KEY MENU-TITLE ITEM-HANDLER SORTER) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
661 See `msb-menu-cond' for a description of its elements." |
| 10228 | 662 (let* ((list-symbol (make-symbol "-msb-buffer-list")) |
| 663 (tmp-ih (and (> (length menu-cond-elt) 3) | |
| 664 (nth 3 menu-cond-elt))) | |
| 665 (item-handler (if (and tmp-ih (fboundp tmp-ih)) | |
| 666 tmp-ih | |
| 667 msb-item-handling-function)) | |
| 668 (tmp-s (if (> (length menu-cond-elt) 4) | |
| 669 (nth 4 menu-cond-elt) | |
| 670 msb-item-sort-function)) | |
| 671 (sorter (if (or (fboundp tmp-s) | |
| 672 (null tmp-s) | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
673 (eq tmp-s t)) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
674 tmp-s |
| 10228 | 675 msb-item-sort-function))) |
| 676 (when (< (length menu-cond-elt) 3) | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
677 (error "Wrong format of msb-menu-cond")) |
| 10228 | 678 (when (and (> (length menu-cond-elt) 3) |
| 679 (not (fboundp tmp-ih))) | |
| 680 (signal 'invalid-function (list tmp-ih))) | |
| 681 (when (and (> (length menu-cond-elt) 4) | |
| 682 tmp-s | |
| 683 (not (fboundp tmp-s)) | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
684 (not (eq tmp-s t))) |
| 10228 | 685 (signal 'invalid-function (list tmp-s))) |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
686 (set list-symbol ()) |
| 10228 | 687 (vector list-symbol ;BUFFER-LIST-VARIABLE |
| 688 (nth 0 menu-cond-elt) ;CONDITION | |
| 689 (nth 1 menu-cond-elt) ;SORT-KEY | |
| 690 (nth 2 menu-cond-elt) ;MENU-TITLE | |
| 691 item-handler ;ITEM-HANDLER | |
| 692 sorter) ;SORTER | |
| 693 )) | |
| 694 | |
| 695 ;; This defsubst is only used in `msb--choose-menu' below. It was | |
| 20901 | 696 ;; pulled out merely to make the code somewhat clearer. The indentation |
| 10228 | 697 ;; level was too big. |
| 698 (defsubst msb--collect (function-info-vector) | |
| 699 (let ((result nil) | |
| 700 (multi-flag nil) | |
| 701 function-info-list) | |
| 702 (setq function-info-list | |
| 703 (loop for fi | |
| 704 across function-info-vector | |
| 705 if (and (setq result | |
| 706 (eval (aref fi 1))) ;Test CONDITION | |
| 707 (not (and (eq result 'no-multi) | |
| 708 multi-flag)) | |
| 709 (progn (when (eq result 'multi) | |
| 710 (setq multi-flag t)) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
711 t)) |
| 10228 | 712 collect fi |
| 713 until (and result | |
| 714 (not (eq result 'multi))))) | |
| 715 (when (and (not function-info-list) | |
| 716 (not result)) | |
| 717 (error "No catch-all in msb-menu-cond!")) | |
| 718 function-info-list)) | |
| 719 | |
| 720 (defun msb--add-to-menu (buffer function-info max-buffer-name-length) | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
721 "Add BUFFER to the menu depicted by FUNCTION-INFO. |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
722 All side-effects. Adds an element of form (BUFFER-TITLE . BUFFER) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
723 to the buffer-list variable in function-info." |
| 10228 | 724 (let ((list-symbol (aref function-info 0))) ;BUFFER-LIST-VARIABLE |
| 725 ;; Here comes the hairy side-effect! | |
| 726 (set list-symbol | |
| 727 (cons (cons (funcall (aref function-info 4) ;ITEM-HANDLER | |
| 728 buffer | |
| 729 max-buffer-name-length) | |
| 730 buffer) | |
| 731 (eval list-symbol))))) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
732 |
| 10228 | 733 (defsubst msb--choose-menu (buffer function-info-vector max-buffer-name-length) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
734 "Select the appropriate menu for BUFFER." |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
735 ;; This is all side-effects, folks! |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
736 ;; This should be optimized. |
| 10228 | 737 (unless (and (not msb-display-invisible-buffers-p) |
| 738 (msb-invisible-buffer-p buffer)) | |
| 739 (condition-case nil | |
| 740 (save-excursion | |
| 741 (set-buffer buffer) | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
742 ;; Menu found. Add to this menu |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
743 (dolist (info (msb--collect function-info-vector)) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
744 (msb--add-to-menu buffer info max-buffer-name-length))) |
| 10228 | 745 (error (unless msb--error |
| 746 (setq msb--error | |
| 747 (format | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
748 "In msb-menu-cond, error for buffer `%s'." |
| 10228 | 749 (buffer-name buffer))) |
|
14427
ac3101efc47e
(msb--choose-menu): Fix error format string.
Karl Heuer <kwzh@gnu.org>
parents:
14292
diff
changeset
|
750 (error "%s" msb--error)))))) |
| 10228 | 751 |
| 752 (defun msb--create-sort-item (function-info) | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
753 "Return (SORT-KEY TITLE . BUFFER-LIST) or nil if the buffer-list is empty." |
| 10228 | 754 (let ((buffer-list (eval (aref function-info 0)))) |
| 755 (when buffer-list | |
| 756 (let ((sorter (aref function-info 5)) ;SORTER | |
| 757 (sort-key (aref function-info 2))) ;MENU-SORT-KEY | |
| 758 (when sort-key | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
759 (cons sort-key |
| 10228 | 760 (cons (format (aref function-info 3) ;MENU-TITLE |
| 761 (length buffer-list)) | |
| 762 (cond | |
| 763 ((null sorter) | |
| 764 buffer-list) | |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
765 ((eq sorter t) |
| 10228 | 766 (nreverse buffer-list)) |
| 767 (t | |
| 768 (sort buffer-list sorter)))))))))) | |
| 769 | |
| 20901 | 770 (defun msb--aggregate-alist (alist same-predicate sort-predicate) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
771 "Return ALIST as a sorted, aggregated alist. |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
772 |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
773 In the result all items with the same car element (according to |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
774 SAME-PREDICATE) are aggregated together. The alist is first sorted by |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
775 SORT-PREDICATE. |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
776 |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
777 Example: |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
778 \(msb--aggregate-alist |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
779 '((a . a1) (a . a2) (b . b1) (c . c3) (a . a4) (a . a3) (b . b3) (b . b2)) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
780 (function string=) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
781 (lambda (item1 item2) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
782 (string< (symbol-name item1) (symbol-name item2)))) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
783 results in |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
784 \((a a1 a2 a4 a3) (b b1 b3 b2) (c c3))" |
| 20901 | 785 (when (not (null alist)) |
| 786 (let (result | |
| 787 same | |
| 788 tmp-old-car | |
| 789 tmp-same | |
| 790 (first-time-p t) | |
| 791 old-car) | |
| 792 (nconc | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
793 (apply #'nconc |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
794 (mapcar |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
795 (lambda (item) |
| 20901 | 796 (cond |
| 797 (first-time-p | |
| 798 (push (cdr item) same) | |
| 799 (setq first-time-p nil) | |
| 800 (setq old-car (car item)) | |
| 801 nil) | |
| 802 ((funcall same-predicate (car item) old-car) | |
| 803 (push (cdr item) same) | |
| 804 nil) | |
| 805 (t | |
| 806 (setq tmp-same same | |
| 807 tmp-old-car old-car) | |
| 808 (setq same (list (cdr item)) | |
| 809 old-car (car item)) | |
| 810 (list (cons tmp-old-car (nreverse tmp-same)))))) | |
| 811 (sort alist (lambda (item1 item2) | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
812 (funcall sort-predicate (car item1) (car item2)))))) |
| 20901 | 813 (list (cons old-car (nreverse same))))))) |
| 814 | |
| 815 | |
| 816 (defun msb--mode-menu-cond () | |
| 817 (let ((key msb-modes-key)) | |
| 818 (mapcar (lambda (item) | |
| 819 (incf key) | |
| 820 (list `( eq major-mode (quote ,(car item))) | |
| 821 key | |
| 822 (concat (cdr item) " (%d)"))) | |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
823 (sort |
| 20901 | 824 (let ((mode-list nil)) |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
825 (dolist (buffer (cdr (buffer-list))) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
826 (save-excursion |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
827 (set-buffer buffer) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
828 (when (and (not (msb-invisible-buffer-p)) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
829 (not (assq major-mode mode-list))) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
830 (push (cons major-mode mode-name) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
831 mode-list)))) |
| 20901 | 832 mode-list) |
| 833 (lambda (item1 item2) | |
| 834 (string< (cdr item1) (cdr item2))))))) | |
| 835 | |
| 10228 | 836 (defun msb--most-recently-used-menu (max-buffer-name-length) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
837 "Return a list for the most recently used buffers. |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
838 It takes the form ((TITLE . BUFFER-LIST)...)." |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
839 (when (and (numberp msb-display-most-recently-used) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
840 (> msb-display-most-recently-used 0)) |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
841 (let* ((buffers (cdr (buffer-list))) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
842 (most-recently-used |
| 10228 | 843 (loop with n = 0 |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
844 for buffer in buffers |
| 10228 | 845 if (save-excursion |
| 846 (set-buffer buffer) | |
| 847 (and (not (msb-invisible-buffer-p)) | |
| 848 (not (eq major-mode 'dired-mode)))) | |
| 849 collect (save-excursion | |
| 850 (set-buffer buffer) | |
| 851 (cons (funcall msb-item-handling-function | |
| 852 buffer | |
| 853 max-buffer-name-length) | |
| 854 buffer)) | |
| 855 and do (incf n) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
856 until (>= n msb-display-most-recently-used)))) |
| 10228 | 857 (cons (if (stringp msb-most-recently-used-title) |
| 858 (format msb-most-recently-used-title | |
| 859 (length most-recently-used)) | |
| 860 (signal 'wrong-type-argument (list msb-most-recently-used-title))) | |
| 861 most-recently-used)))) | |
| 862 | |
| 863 (defun msb--create-buffer-menu-2 () | |
| 864 (let ((max-buffer-name-length 0) | |
| 865 file-buffers | |
| 866 function-info-vector) | |
| 867 ;; Calculate the longest buffer name. | |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
868 (dolist (buffer (buffer-list)) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
869 (when (or msb-display-invisible-buffers-p |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
870 (not (msb-invisible-buffer-p))) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
871 (setq max-buffer-name-length |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
872 (max max-buffer-name-length (length (buffer-name buffer)))))) |
| 10228 | 873 ;; Make a list with elements of type |
| 874 ;; (BUFFER-LIST-VARIABLE | |
| 875 ;; CONDITION | |
| 876 ;; MENU-SORT-KEY | |
| 877 ;; MENU-TITLE | |
| 878 ;; ITEM-HANDLER | |
| 879 ;; SORTER) | |
| 880 ;; Uses "function-global" variables: | |
| 881 ;; function-info-vector | |
| 882 (setq function-info-vector | |
| 883 (apply (function vector) | |
| 884 (mapcar (function msb--create-function-info) | |
| 20901 | 885 (append msb-menu-cond (msb--mode-menu-cond))))) |
| 10228 | 886 ;; Split the buffer-list into several lists; one list for each |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
887 ;; criteria. This is the most critical part with respect to time. |
|
28300
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
888 (dolist (buffer (buffer-list)) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
889 (cond ((and msb-files-by-directory |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
890 (buffer-file-name buffer) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
891 ;; exclude ange-ftp buffers |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
892 ;;(not (string-match "\\/[^/:]+:" |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
893 ;; (buffer-file-name buffer))) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
894 ) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
895 (push buffer file-buffers)) |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
896 (t |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
897 (msb--choose-menu buffer |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
898 function-info-vector |
|
4a7a0fc36977
(msb--choose-file-menu): Use `(apply #'list ...)'
Gerd Moellmann <gerd@gnu.org>
parents:
25281
diff
changeset
|
899 max-buffer-name-length)))) |
| 10228 | 900 (when file-buffers |
| 901 (setq file-buffers | |
| 20901 | 902 (mapcar (lambda (buffer-list) |
| 903 (cons msb-files-by-directory-sort-key | |
| 904 (cons (car buffer-list) | |
| 905 (sort | |
| 906 (mapcar (function | |
| 907 (lambda (buffer) | |
| 908 (cons (save-excursion | |
| 909 (set-buffer buffer) | |
| 910 (funcall msb-item-handling-function | |
| 911 buffer | |
| 912 max-buffer-name-length)) | |
| 913 buffer))) | |
| 914 (cdr buffer-list)) | |
| 915 (function | |
| 916 (lambda (item1 item2) | |
| 917 (string< (car item1) (car item2)))))))) | |
| 10228 | 918 (msb--choose-file-menu file-buffers)))) |
| 919 ;; Now make the menu - a list of (TITLE . BUFFER-LIST) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
920 (let* (menu |
| 10228 | 921 (most-recently-used |
| 922 (msb--most-recently-used-menu max-buffer-name-length)) | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
923 (others (nconc file-buffers |
| 10228 | 924 (loop for elt |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
925 across function-info-vector |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
926 for value = (msb--create-sort-item elt) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
927 if value collect value)))) |
| 10228 | 928 (setq menu |
| 929 (mapcar 'cdr ;Remove the SORT-KEY | |
| 930 ;; Sort the menus - not the items. | |
| 931 (msb--add-separators | |
| 932 (sort | |
| 933 ;; Get a list of (SORT-KEY TITLE . BUFFER-LIST) | |
| 934 ;; Also sorts the items within the menus. | |
| 935 (if (cdr most-recently-used) | |
| 936 (cons | |
| 937 ;; Add most recent used buffers | |
| 938 (cons msb-most-recently-used-sort-key | |
| 939 most-recently-used) | |
| 940 others) | |
| 941 others) | |
| 20901 | 942 (lambda (elt1 elt2) |
| 943 (< (car elt1) (car elt2))))))) | |
| 10228 | 944 ;; Now make it a keymap menu |
| 945 (append | |
| 946 '(keymap "Select Buffer") | |
| 947 (msb--make-keymap-menu menu) | |
| 948 (when msb-separator-diff | |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
949 (list (list 'separator "--"))) |
|
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
950 (list (cons 'toggle |
| 10228 | 951 (cons |
| 952 (if msb-files-by-directory | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
953 "*Files by type*" |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
954 "*Files by directory*") |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
955 'msb--toggle-menu-type))))))) |
| 10228 | 956 |
| 957 (defun msb--create-buffer-menu () | |
| 958 (save-match-data | |
| 959 (save-excursion | |
| 960 (msb--create-buffer-menu-2)))) | |
| 961 | |
| 962 (defun msb--toggle-menu-type () | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
963 "Multi purpose function for selecting a buffer with the mouse." |
| 10228 | 964 (interactive) |
| 965 (setq msb-files-by-directory (not msb-files-by-directory)) | |
|
20884
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
966 ;; This gets a warning, but it is correct, |
|
91f9c828fc1a
(msb--choose-file-menu): Save some debugging info.
Richard M. Stallman <rms@gnu.org>
parents:
20758
diff
changeset
|
967 ;; because this file redefines menu-bar-update-buffers. |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
968 (msb-menu-bar-update-buffers t)) |
| 10228 | 969 |
| 970 (defun mouse-select-buffer (event) | |
| 971 "Pop up several menus of buffers, for selection with the mouse. | |
| 972 Returns the selected buffer or nil if no buffer is selected. | |
| 973 | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
974 The way the buffers are split is conveniently handled with the |
|
10239
52a1e5ef144c
Fix quoting conventions and spaces at end of sentence.
Richard M. Stallman <rms@gnu.org>
parents:
10228
diff
changeset
|
975 variable `msb-menu-cond'." |
| 10228 | 976 ;; Popup the menu and return the selected buffer. |
| 977 (when (or msb--error | |
| 978 (not msb--last-buffer-menu) | |
| 979 (not (fboundp 'frame-or-buffer-changed-p)) | |
| 980 (frame-or-buffer-changed-p)) | |
| 981 (setq msb--error nil) | |
| 982 (setq msb--last-buffer-menu (msb--create-buffer-menu))) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
983 (let ((position event) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
984 choice) |
| 10228 | 985 (when (and (fboundp 'posn-x-y) |
| 986 (fboundp 'posn-window)) | |
| 987 (let ((posX (car (posn-x-y (event-start event)))) | |
| 988 (posY (cdr (posn-x-y (event-start event)))) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
989 (posWind (posn-window (event-start event)))) |
| 10228 | 990 ;; adjust position |
| 991 (setq posX (- posX (funcall msb-horizontal-shift-function)) | |
| 992 position (list (list posX posY) posWind)))) | |
|
10823
abd2a268ed88
(mouse-select-buffer): Do sit-for before x-popup-menu.
Richard M. Stallman <rms@gnu.org>
parents:
10821
diff
changeset
|
993 ;; This `sit-for' magically makes the menu stay up if the mouse |
|
13998
2f2d3995b57f
(msb-max-file-menu-items, msb-menu-cond): Doc fix.
Karl Heuer <kwzh@gnu.org>
parents:
13372
diff
changeset
|
994 ;; button is released within 0.1 second. |
|
10823
abd2a268ed88
(mouse-select-buffer): Do sit-for before x-popup-menu.
Richard M. Stallman <rms@gnu.org>
parents:
10821
diff
changeset
|
995 (sit-for 0 100) |
|
abd2a268ed88
(mouse-select-buffer): Do sit-for before x-popup-menu.
Richard M. Stallman <rms@gnu.org>
parents:
10821
diff
changeset
|
996 ;; Popup the menu |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
997 (setq choice (x-popup-menu position msb--last-buffer-menu)) |
| 10228 | 998 (cond |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
999 ((eq (car choice) 'toggle) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1000 ;; Bring up the menu again with type toggled. |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1001 (msb--toggle-menu-type) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1002 (mouse-select-buffer event)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1003 ((and (numberp (car choice)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1004 (null (cdr choice))) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1005 (let ((msb--last-buffer-menu (nthcdr 3 (assq (car choice) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1006 msb--last-buffer-menu)))) |
| 10228 | 1007 (mouse-select-buffer event))) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1008 ((while (numberp (car choice)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1009 (setq choice (cdr choice)))) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1010 ((and (stringp (car choice)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1011 (null (cdr choice))) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1012 (car choice)) |
|
10403
c0e27466fb3f
(mouse-select-buffer) Handle an aborted selection.
Richard M. Stallman <rms@gnu.org>
parents:
10371
diff
changeset
|
1013 ((null choice) |
|
c0e27466fb3f
(mouse-select-buffer) Handle an aborted selection.
Richard M. Stallman <rms@gnu.org>
parents:
10371
diff
changeset
|
1014 choice) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1015 (t |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1016 (error "Unknown form for buffer: %s" choice))))) |
| 20901 | 1017 |
| 10228 | 1018 ;; Add separators |
| 1019 (defun msb--add-separators (sorted-list) | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1020 (if (or (not msb-separator-diff) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1021 (not (numberp msb-separator-diff))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1022 sorted-list |
| 10228 | 1023 (let ((last-key nil)) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1024 (apply #'nconc |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1025 (mapcar |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1026 (lambda (item) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1027 (cond |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1028 ((and msb-separator-diff |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1029 last-key |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1030 (> (- (car item) last-key) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1031 msb-separator-diff)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1032 (setq last-key (car item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1033 (list (cons last-key 'separator) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1034 item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1035 (t |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1036 (setq last-key (car item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1037 (list item)))) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1038 sorted-list))))) |
| 10228 | 1039 |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1040 (defun msb--split-menus-2 (list mcount result) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1041 (cond |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1042 ((> (length list) msb-max-menu-items) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1043 (let ((count 0) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1044 sub-name |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1045 (tmp-list nil)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1046 (while (< count msb-max-menu-items) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1047 (push (pop list) tmp-list) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1048 (incf count)) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1049 (setq tmp-list (nreverse tmp-list)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1050 (setq sub-name (concat (car (car tmp-list)) "...")) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1051 (push (nconc (list mcount sub-name |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1052 'keymap sub-name) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1053 tmp-list) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1054 result)) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1055 (msb--split-menus-2 list (1+ mcount) result)) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1056 ((null result) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1057 list) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1058 (t |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1059 (let (sub-name) |
|
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1060 (setq sub-name (concat (car (car list)) "...")) |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1061 (push (nconc (list mcount sub-name 'keymap sub-name) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1062 list) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1063 result)) |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1064 (nreverse result)))) |
| 20901 | 1065 |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1066 (defun msb--split-menus (list) |
| 20901 | 1067 (if (and (integerp msb-max-menu-items) |
| 1068 (> msb-max-menu-items 0)) | |
| 1069 (msb--split-menus-2 list 0 nil) | |
| 1070 list)) | |
|
10371
629821e2b42e
Better format of files-by-directory menus.
Richard M. Stallman <rms@gnu.org>
parents:
10239
diff
changeset
|
1071 |
| 10228 | 1072 (defun msb--make-keymap-menu (raw-menu) |
| 1073 (let ((end (cons '(nil) 'menu-bar-select-buffer)) | |
| 1074 (mcount 0)) | |
| 1075 (mapcar | |
| 20901 | 1076 (lambda (sub-menu) |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1077 (cond |
| 20901 | 1078 ((eq 'separator sub-menu) |
| 1079 (list 'separator "--")) | |
| 1080 (t | |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1081 (let ((buffers (mapcar (lambda (item) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1082 (cons (buffer-name (cdr item)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1083 (cons (car item) end))) |
| 20901 | 1084 (cdr sub-menu)))) |
| 1085 (nconc (list (incf mcount) (car sub-menu) | |
| 1086 'keymap (car sub-menu)) | |
| 1087 (msb--split-menus buffers)))))) | |
| 10228 | 1088 raw-menu))) |
| 1089 | |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
1090 (defun msb-menu-bar-update-buffers (&optional arg) |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
1091 "A re-written version of `menu-bar-update-buffers'." |
| 10228 | 1092 ;; If user discards the Buffers item, play along. |
| 1093 (when (and (lookup-key (current-global-map) [menu-bar buffer]) | |
| 1094 (or (not (fboundp 'frame-or-buffer-changed-p)) | |
| 1095 (frame-or-buffer-changed-p) | |
| 1096 arg)) | |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1097 (let ((frames (frame-list)) |
| 10228 | 1098 buffers-menu frames-menu) |
| 1099 ;; Make the menu of buffers proper. | |
| 1100 (setq msb--last-buffer-menu (msb--create-buffer-menu)) | |
| 1101 (setq buffers-menu msb--last-buffer-menu) | |
| 1102 ;; Make a Frames menu if we have more than one frame. | |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1103 (when (cdr frames) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1104 (let* ((frame-length (length frames)) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1105 (f-title (format "Frames (%d)" frame-length))) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1106 ;; List only the N most recently selected frames |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1107 (when (and (integerp msb-max-menu-items) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1108 (> msb-max-menu-items 1) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1109 (> frame-length msb-max-menu-items)) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1110 (setcdr (nthcdr msb-max-menu-items frames) nil)) |
| 10228 | 1111 (setq frames-menu |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1112 (nconc |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1113 (list 'frame f-title '(nil) 'keymap f-title) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1114 (mapcar |
| 20901 | 1115 (lambda (frame) |
| 1116 (nconc | |
| 1117 (list frame | |
| 1118 (cdr (assq 'name | |
| 1119 (frame-parameters frame))) | |
| 1120 (cons nil nil)) | |
| 1121 'menu-bar-select-frame)) | |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1122 frames))))) |
| 10228 | 1123 (define-key (current-global-map) [menu-bar buffer] |
| 1124 (cons "Buffers" | |
| 1125 (if (and buffers-menu frames-menu) | |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1126 ;; Combine Frame and Buffers menus with separator between |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1127 (nconc (list 'keymap "Buffers and Frames" frames-menu |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
1128 (and msb-separator-diff '(separator "--"))) |
|
10821
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1129 (cddr buffers-menu)) |
|
1ff0ed96a4c0
(msb): Select the window that the mouse is in before
Richard M. Stallman <rms@gnu.org>
parents:
10403
diff
changeset
|
1130 (or buffers-menu 'undefined))))))) |
| 10228 | 1131 |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1132 ;; Snarf current bindings of `mouse-buffer-menu' (normally |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1133 ;; C-down-mouse-1). |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1134 (defvar msb-mode-map |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1135 (let ((map (make-sparse-keymap "Msb"))) |
|
31812
9214cf65b24b
(msb-mode-map): Use substitute-key-definition.
Dave Love <fx@gnu.org>
parents:
30864
diff
changeset
|
1136 (substitute-key-definition 'mouse-buffer-menu 'msb map global-map) |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1137 map)) |
|
20504
1b8aec1c12f1
Doc fixes. Changed `append' to `nconc'
Richard M. Stallman <rms@gnu.org>
parents:
16833
diff
changeset
|
1138 |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1139 ;;;###autoload |
|
30864
904dafa7e039
(msb-mode): Define it in terms of define-minor-mode.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
30800
diff
changeset
|
1140 (define-minor-mode msb-mode |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1141 "Toggle Msb mode. |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1142 With arg, turn Msb mode on if and only if arg is positive. |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1143 This mode overrides the binding(s) of `mouse-buffer-menu' to provide a |
|
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1144 different buffer menu using the function `msb'." |
|
31812
9214cf65b24b
(msb-mode-map): Use substitute-key-definition.
Dave Love <fx@gnu.org>
parents:
30864
diff
changeset
|
1145 :global t |
|
24796
19424321d8e1
Add to minor-mode-map-alist. Remove hook installation
Dave Love <fx@gnu.org>
parents:
21670
diff
changeset
|
1146 (if msb-mode |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
1147 (progn |
|
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
1148 (add-hook 'menu-bar-update-hook 'msb-menu-bar-update-buffers) |
|
36229
779e2936512e
(msb-mode): Call the update-buffers function explicitly
Gerd Moellmann <gerd@gnu.org>
parents:
35815
diff
changeset
|
1149 (remove-hook 'menu-bar-update-hook 'menu-bar-update-buffers) |
|
779e2936512e
(msb-mode): Call the update-buffers function explicitly
Gerd Moellmann <gerd@gnu.org>
parents:
35815
diff
changeset
|
1150 (msb-menu-bar-update-buffers t)) |
|
25050
1539c0070dd3
(msb-menu-bar-update-buffers): Renamed from
Dave Love <fx@gnu.org>
parents:
24796
diff
changeset
|
1151 (remove-hook 'menu-bar-update-hook 'msb-menu-bar-update-buffers) |
|
36229
779e2936512e
(msb-mode): Call the update-buffers function explicitly
Gerd Moellmann <gerd@gnu.org>
parents:
35815
diff
changeset
|
1152 (add-hook 'menu-bar-update-hook 'menu-bar-update-buffers) |
|
779e2936512e
(msb-mode): Call the update-buffers function explicitly
Gerd Moellmann <gerd@gnu.org>
parents:
35815
diff
changeset
|
1153 (menu-bar-update-buffers t))) |
| 10228 | 1154 |
|
30800
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1155 (defun msb-unload-hook () |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1156 (msb-mode 0)) |
|
aa5afea93d8a
(msb--few-menus, msb--very-many-menus): Use current Gnus
Dave Love <fx@gnu.org>
parents:
28977
diff
changeset
|
1157 |
| 10228 | 1158 (provide 'msb) |
|
35815
6ad253d733d5
(toplevel): Quote hook symbols.
Gerd Moellmann <gerd@gnu.org>
parents:
35715
diff
changeset
|
1159 (eval-after-load "msb" '(run-hooks 'msb-after-load-hook 'msb-after-load-hooks)) |
|
16833
052a9f2e21e5
(frame-or-buffer-changed-p): Definition deleted.
Richard M. Stallman <rms@gnu.org>
parents:
16428
diff
changeset
|
1160 |
| 10228 | 1161 ;;; msb.el ends here |
