annotate lisp/speedbar.el @ 26515:9f3d02d7daa8

term/internal.el (IT-display-table-setup): Don't overstep character code 255.
author Eli Zaretskii <eliz@gnu.org>
date Sun, 21 Nov 1999 11:29:25 +0000
parents 7de24bd78e93
children 98c01a50be97
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1 ;;; speedbar --- quick access to files and tags in a frame
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3 ;;; Copyright (C) 1996, 97, 98, 99 Free Software Foundation
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
4
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
5 ;; Author: Eric M. Ludlam <zappo@gnu.org>
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
6 ;; Version: 0.8.1
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
7 ;; Keywords: file, tags, tools
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
8
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
9 ;; This file is part of GNU Emacs.
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
10
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
11 ;; GNU Emacs is free software; you can redistribute it and/or modify
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
12 ;; it under the terms of the GNU General Public License as published by
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
14 ;; any later version.
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
15
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
16 ;; GNU Emacs is distributed in the hope that it will be useful,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
17 ;; but WITHOUT ANY WARRANTY; without even the implied warranty of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
19 ;; GNU General Public License for more details.
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
20
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
21 ;; You should have received a copy of the GNU General Public License
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
22 ;; along with GNU Emacs; see the file COPYING. If not, write to the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
23 ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
24 ;; Boston, MA 02111-1307, USA.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
25
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
26 ;;; Commentary:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
27 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
28 ;; The speedbar provides a frame in which files, and locations in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
29 ;; files are displayed. These items can be clicked on with mouse-2
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
30 ;; in order to make the last active frame display that file location.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
31 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
32 ;; Starting Speedbar:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
33 ;;
26491
7de24bd78e93 Clean up comment at the start of the file.
Gerd Moellmann <gerd@gnu.org>
parents: 25432
diff changeset
34 ;; Simply type `M-x speedbar', and it will be autoloaded for you.
7de24bd78e93 Clean up comment at the start of the file.
Gerd Moellmann <gerd@gnu.org>
parents: 25432
diff changeset
35
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
36 ;; If you want to choose it from a menu, such as "Tools", you can do this:
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
37 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
38 ;; (define-key-after (lookup-key global-map [menu-bar tools])
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
39 ;; [speedbar] '("Speedbar" . speedbar-frame-mode) [calendar])
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
40 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
41 ;; If you want to access speedbar using only the keyboard, do this:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
42 ;;
26491
7de24bd78e93 Clean up comment at the start of the file.
Gerd Moellmann <gerd@gnu.org>
parents: 25432
diff changeset
43 ;; (global-set-key [f4] 'speedbar-get-focus)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
44 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
45 ;; This will let you hit f4 (or whatever key you choose) to jump
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
46 ;; focus to the speedbar frame. Pressing it again will bring you back
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
47 ;; to the attached frame. Pressing RET or e to jump to a file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
48 ;; or tag will move you back to the attached frame. The command
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
49 ;; `speedbar-get-focus' will also create a speedbar frame if it does
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
50 ;; not exist.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
51 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
52 ;; Customizing Speedbar:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
53 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
54 ;; Once a speedbar frame is active, it takes advantage of idle time
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
55 ;; to keep its contents updated. The contents is usually a list of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
56 ;; files in the directory of the currently active buffer. When
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
57 ;; applicable, tags in the active file can be expanded.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
58 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
59 ;; To add new supported files types into speedbar, use the function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
60 ;; `speedbar-add-supported-extension' If speedbar complains that the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
61 ;; file type is not supported, that means there is no built in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
62 ;; support from imenu, and the etags part wasn't set up correctly. You
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
63 ;; may add elements to `speedbar-supported-extension-expressions' as long
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
64 ;; as it is done before speedbar is loaded.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
65 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
66 ;; To prevent speedbar from following you into certain directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
67 ;; use the function `speedbar-add-ignored-path-regexp' too add a new
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
68 ;; regular expression matching a type of path. You may add list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
69 ;; elements to `speedbar-ignored-path-expressions' as long as it is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
70 ;; done before speedbar is loaded.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
71 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
72 ;; To add new file types to imenu, see the documentation in the
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
73 ;; file imenu.el that comes with Emacs. To add new file types which
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
74 ;; etags supports, you need to modify the variable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
75 ;; `speedbar-fetch-etags-parse-list'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
76 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
77 ;; If the updates are going too slow for you, modify the variable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
78 ;; `speedbar-update-speed' to a longer idle time before updates.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
79 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
80 ;; If you navigate directories, you will probably notice that you
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
81 ;; will navigate to a directory which is eventually replaced after
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
82 ;; you go back to editing a file (unless you pull up a new file.)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
83 ;; The delay time before this happens is in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
84 ;; `speedbar-navigating-speed', and defaults to 10 seconds.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
85 ;;
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
86 ;; To enable mouse tracking with information in the minibuffer of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
87 ;; the attached frame, use the variable `speedbar-track-mouse-flag'.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
88 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
89 ;; Tag layout can be modified through `speedbar-tag-hierarchy-method',
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
90 ;; which controls how tags are layed out. It is actually a list of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
91 ;; functions that filter the data. The default groups large tag lists
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
92 ;; into sub-lists. A long flat list can be used instead if needed.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
93 ;; Other filters could be easily added.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
94 ;;
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
95 ;; AUC-TEX users: The imenu tags for AUC-TEX mode don't work very
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
96 ;; well. Use the imenu keywords from tex-mode.el for better results.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
97 ;;
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
98 ;;; Developing for speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
99 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
100 ;; Adding a speedbar specialized display mode:
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
101 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
102 ;; Speedbar can be configured to create a special display for certain
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
103 ;; modes that do not display tradition file/tag data. Rmail, Info,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
104 ;; and the debugger are examples. These modes can, however, benefit
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
105 ;; from a speedbar style display in their own way.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
106 ;;
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
107 ;; If your `major-mode' is `foo-mode', the only requirement is to
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
108 ;; create a function called `foo-speedbar-buttons' which takes one
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
109 ;; argument, BUFFER. BUFFER will be the buffer speedbar wants filled.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
110 ;; In `foo-speedbar-buttons' there are several functions that make
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
111 ;; building a speedbar display easy. See the documentation for
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
112 ;; `speedbar-with-writable' (needed because the buffer is usually
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
113 ;; read-only) `speedbar-make-tag-line', `speedbar-insert-button', and
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
114 ;; `speedbar-insert-generic-list'. If you use
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
115 ;; `speedbar-insert-generic-list', also read the doc for
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
116 ;; `speedbar-tag-hierarchy-method' in case you wish to override it.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
117 ;; The function `speedbar-with-attached-buffer' brings you back to the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
118 ;; buffer speedbar is displaying for.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
119 ;;
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
120 ;; For those functions that make buttons, the "function" should be a
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
121 ;; symbol that is the function to call when clicked on. The "token"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
122 ;; is extra data you can pass along. The "function" must take three
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
123 ;; parameters. They are (TEXT TOKEN INDENT). TEXT is the text of the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
124 ;; button clicked on. TOKEN is the data passed in when you create the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
125 ;; button. INDENT is an indentation level, or 0. You can store
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
126 ;; indentation levels with `speedbar-make-tag-line' which creates a
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
127 ;; line with an expander (eg. [+]) and a text button.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
128 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
129 ;; Some useful functions when writing expand functions, and click
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
130 ;; functions are `speedbar-change-expand-button-char',
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
131 ;; `speedbar-delete-subblock', and `speedbar-center-buffer-smartly'.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
132 ;; The variable `speedbar-power-click' is set to t in your functions
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
133 ;; when the user shift-clicks. This indications anything from
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
134 ;; refreshing cached data to making a buffer appear in a new frame.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
135 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
136 ;; If you wish to add to the default speedbar menu for the case of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
137 ;; `foo-mode', create a variable `foo-speedbar-menu-items'. This
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
138 ;; should be a list compatible with the `easymenu' package. It will
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
139 ;; be spliced into the main menu. (Available with click-mouse-3). If
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
140 ;; you wish to have extra key bindings in your special mode, create a
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
141 ;; variable `foo-speedbar-key-map'. Instead of using `make-keymap',
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
142 ;; or `make-sparse-keymap', use the function
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
143 ;; `speedbar-make-specialized-keymap'. This lets you inherit all of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
144 ;; speedbar's default bindings with low overhead.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
145 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
146 ;; Adding a speedbar top-level display mode:
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
147 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
148 ;; Unlike the specialized modes, there are no name requirements,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
149 ;; however the methods for writing a button display, menu, and keymap
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
150 ;; are the same. Once you create these items, you can call the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
151 ;; function `speedbar-add-expansion-list'. It takes one parameter
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
152 ;; which is a list element of the form (NAME MENU KEYMAP &rest
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
153 ;; BUTTON-FUNCTIONS). NAME is a string that will show up in the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
154 ;; Displays menu item. MENU is a symbol containing the menu items to
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
155 ;; splice in. KEYMAP is a symbol holding the keymap to use, and
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
156 ;; BUTTON-FUNCTIONS are the function names to call, in order, to create
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
157 ;; the display.
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
158 ;; Another tweekable variable is `speedbar-stealthy-function-list'
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
159 ;; which is of the form (NAME &rest FUNCTION ...). NAME is the string
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
160 ;; name matching `speedbar-add-expansion-list'. (It does not need to
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
161 ;; exist.). This provides additional display info which might be
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
162 ;; time-consuming to calculate.
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
163 ;; Lastly, `speedbar-mode-functions-list' allows you to set special
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
164 ;; function overrides. At the moment very few functions are
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
165 ;; over ridable, but more will be added as the need is discovered.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
166
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
167 ;;; TODO:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
168 ;; - More functions to create buttons and options
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
169 ;; - Timeout directories we haven't visited in a while.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
170 ;; - Remeber tags when refreshing the display. (Refresh tags too?)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
171 ;; - More 'special mode support.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
172
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
173 (require 'assoc)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
174 (require 'easymenu)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
175
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
176 (defvar speedbar-xemacsp (string-match "XEmacs" emacs-version)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
177 "Non-nil if we are running in the XEmacs environment.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
178 (defvar speedbar-xemacs20p (and speedbar-xemacsp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
179 (= emacs-major-version 20)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
180
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
181 ;; From custom web page for compatibility between versions of custom:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
182 (eval-and-compile
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
183 (condition-case ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
184 (require 'custom)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
185 (error nil))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
186 (if (and (featurep 'custom) (fboundp 'custom-declare-variable)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
187 ;; Some XEmacsen w/ custom don't have :set keyword.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
188 ;; This protects them against custom.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
189 (fboundp 'custom-initialize-set))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
190 nil ;; We've got what we needed
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
191 ;; We have the old custom-library, hack around it!
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
192 (defmacro defgroup (&rest args)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
193 nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
194 (defmacro defface (var values doc &rest args)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
195 (` (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
196 (defvar (, var) (quote (, var)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
197 ;; To make colors for your faces you need to set your .Xdefaults
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
198 ;; or set them up ahead of time in your .emacs file.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
199 (make-face (, var))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
200 )))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
201 (defmacro defcustom (var value doc &rest args)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
202 (` (defvar (, var) (, value) (, doc))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
203
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
204 ;; customization stuff
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
205 (defgroup speedbar nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
206 "File and tag browser frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
207 :group 'tags
21658
d8a81542dbf9 *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 21650
diff changeset
208 :group 'tools
22250
a77d473867b8 *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 21658
diff changeset
209 :group 'convenience
21658
d8a81542dbf9 *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 21650
diff changeset
210 :version "20.3")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
211
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
212 (defgroup speedbar-faces nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
213 "Faces used in speedbar."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
214 :prefix "speedbar-"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
215 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
216 :group 'faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
217
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
218 (defgroup speedbar-vc nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
219 "Version control display in speedbar."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
220 :prefix "speedbar-"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
221 :group 'speedbar)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
222
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
223 ;;; Code:
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
224 (defvar speedbar-initial-expansion-mode-alist
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
225 '(("buffers" speedbar-buffer-easymenu-definition speedbar-buffers-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
226 speedbar-buffer-buttons)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
227 ("quick buffers" speedbar-buffer-easymenu-definition speedbar-buffers-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
228 speedbar-buffer-buttons-temp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
229 ;; Files last, means first in the Displays menu
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
230 ("files" speedbar-easymenu-definition-special speedbar-file-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
231 speedbar-directory-buttons speedbar-default-directory-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
232 )
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
233 "List of named expansion elements for filling the speedbar frame.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
234 These expansion lists are only valid for regular files. Special modes
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
235 still get to override this list on a mode-by-mode basis. This list of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
236 lists is of the form (NAME MENU KEYMAP FN1 FN2 ...). NAME is a string
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
237 representing the types of things to be displayed. MENU is an easymenu
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
238 structure used when in this mode. KEYMAP is a local keymap to install
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
239 over the regular speedbar keymap. FN1 ... are functions that will be
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
240 called in order. These functions will always get the default
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
241 directory to use passed in as the first parameter, and a 0 as the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
242 second parameter. The 0 indicates the uppermost indentation level.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
243 They must assume that the cursor is at the position where they start
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
244 inserting buttons.")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
245
23372
64e80b07376b (speedbar-frame-mode): Check if cfx or cfy is a list, and make sure it
Eric M. Ludlam <zappo@gnu.org>
parents: 23275
diff changeset
246 (defvar speedbar-initial-expansion-list-name "files"
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
247 "A symbol name representing the expansion list to use.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
248 The expansion list `speedbar-initial-expansion-mode-alist' contains
23372
64e80b07376b (speedbar-frame-mode): Check if cfx or cfy is a list, and make sure it
Eric M. Ludlam <zappo@gnu.org>
parents: 23275
diff changeset
249 the names and associated functions to use for buttons in speedbar.")
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
250
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
251 (defvar speedbar-previously-used-expansion-list-name "files"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
252 "Save the last expansion list method.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
253 This is used for returning to a previous expansion list method when
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
254 the user is done with the current expansion list.")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
255
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
256 (defvar speedbar-stealthy-function-list
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
257 '(("files"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
258 speedbar-update-current-file speedbar-check-vc speedbar-check-objects)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
259 )
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
260 "List of functions to periodically call stealthily.
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
261 This list is of the form:
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
262 '( (\"NAME\" FUNCTION ...)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
263 ...)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
264 where NAME is the name of the major display mode these functions are
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
265 for, and the remaining elements FUNCTION are functions to call in order.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
266 Each function must return nil if interrupted, or t if completed.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
267 Stealthy functions which have a single operation should always return
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
268 t. Functions which take a long time should maintain a state (where
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
269 they are in their speedbar related calculations) and permit
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
270 interruption. See `speedbar-check-vc' as a good example.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
271
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
272 (defvar speedbar-mode-functions-list
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
273 '(("files" (speedbar-item-info . speedbar-files-item-info)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
274 (speedbar-line-path . speedbar-files-line-path))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
275 ("buffers" (speedbar-item-info . speedbar-buffers-item-info)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
276 (speedbar-line-path . speedbar-buffers-line-path))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
277 ("quick buffers" (speedbar-item-info . speedbar-buffers-item-info)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
278 (speedbar-line-path . speedbar-buffers-line-path))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
279 )
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
280 "List of function tables to use for different major display modes.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
281 It is not necessary to define any functions for a specialized mode.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
282 This just provides a simple way of adding lots of customizations.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
283 Each sublist is of the form:
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
284 (\"NAME\" (FUNCTIONSYMBOL . REPLACEMENTFUNCTION) ...)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
285 Where NAME is the name of the specialized mode. The rest of the list
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
286 is a set of dotted pairs of the form FUNCTIONSYMBOL, which is the name
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
287 of a function you would like to replace, and REPLACEMENTFUNCTION,
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
288 which is a function you can call instead. Not all functions can be
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
289 replaced this way. Replaceable functions must provide that
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
290 functionality individually.")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
291
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
292 (defcustom speedbar-mode-specific-contents-flag t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
293 "*Non-nil means speedbar will show special mode contents.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
294 This permits some modes to create customized contents for the speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
295 frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
296 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
297 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
298
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
299 (defvar speedbar-special-mode-expansion-list nil
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
300 "Default function list for creating specialized button lists.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
301 This list is set by modes that wish to have special speedbar displays.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
302 The list is of function names. Each function is called with one
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
303 parameter BUFFER, the originating buffer. The current buffer is the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
304 speedbar buffer.")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
305
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
306 (defvar speedbar-special-mode-key-map nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
307 "Default keymap used when identifying a specialized display mode.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
308 This keymap is local to each buffer that wants to define special keybindings
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
309 effective when it's display is shown.")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
310
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
311 (defcustom speedbar-visiting-file-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
312 "Hooks run when speedbar visits a file in the selected frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
313 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
314 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
315
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
316 (defcustom speedbar-visiting-tag-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
317 "Hooks run when speedbar visits a tag in the selected frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
318 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
319 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
320
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
321 (defcustom speedbar-load-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
322 "Hooks run when speedbar is loaded."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
323 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
324 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
325
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
326 (defcustom speedbar-show-unknown-files nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
327 "*Non-nil show files we can't expand with a ? in the expand button.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
328 nil means don't show the file in the list."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
329 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
330 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
331
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
332 (defcustom speedbar-update-speed
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
333 (if speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
334 (if speedbar-xemacs20p
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
335 2 ; 1 is too obrusive in XEmacs
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
336 5) ; when no idleness, need long delay
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
337 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
338 "*Idle time in seconds needed before speedbar will update itself.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
339 Updates occur to allow speedbar to display directory information
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
340 relevant to the buffer you are currently editing."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
341 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
342 :type 'integer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
343
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
344 ;; When I moved to a repeating timer, I had the horrible missfortune
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
345 ;; of loosing the ability for adaptive speed choice. This update
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
346 ;; speed currently causes long delays when it should have been turned off.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
347 (defcustom speedbar-navigating-speed speedbar-update-speed
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
348 "*Idle time to wait after navigation commands in speedbar are executed.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
349 Navigation commands included expanding/contracting nodes, and moving
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
350 between different directories."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
351 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
352 :type 'integer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
353
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
354 (defcustom speedbar-frame-parameters '((minibuffer . nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
355 (width . 20)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
356 (border-width . 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
357 (menu-bar-lines . 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
358 (unsplittable . t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
359 "*Parameters to use when creating the speedbar frame in Emacs.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
360 Parameters not listed here which will be added automatically are
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
361 `height' which will be initialized to the height of the frame speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
362 is attached to."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
363 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
364 :type '(repeat (sexp :tag "Parameter:")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
365
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
366 ;; These values by Hrvoje Niksic <hniksic@srce.hr>
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
367 (defcustom speedbar-frame-plist
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
368 '(minibuffer nil width 20 border-width 0
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
369 internal-border-width 0 unsplittable t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
370 default-toolbar-visible-p nil has-modeline-p nil
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
371 menubar-visible-p nil)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
372 "*Parameters to use when creating the speedbar frame in XEmacs.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
373 Parameters not listed here which will be added automatically are
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
374 `height' which will be initialized to the height of the frame speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
375 is attached to."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
376 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
377 :type '(repeat (group :inline t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
378 (symbol :tag "Property")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
379 (sexp :tag "Value"))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
380
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
381 (defcustom speedbar-use-imenu-flag (stringp (locate-library "imenu"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
382 "*Non-nil means use imenu for file parsing. nil to use etags.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
383 XEmacs prior to 20.4 doesn't support imenu, therefore the default is to
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
384 use etags instead. Etags support is not as robust as imenu support."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
385 :tag "User Imenu"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
386 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
387 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
388
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
389 (defcustom speedbar-track-mouse-flag t
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
390 "*Non-nil means to display info about the line under the mouse."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
391 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
392 :type 'boolean)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
393
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
394 (defcustom speedbar-sort-tags nil
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
395 "*If Non-nil, sort tags in the speedbar display. *Obsolete*."
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
396 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
397 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
398
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
399 (defcustom speedbar-tag-hierarchy-method
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
400 '(prefix-group trim-words)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
401 "*List of methods which speedbar will use to organize tags into groups.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
402 Groups are defined as expandable meta-tags. Imenu supports such
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
403 things in some languages, such as separating variables from functions.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
404 Available methods are:
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
405 sort - Sort tags. (sometimes unnecessary)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
406 trim-words - Trim all tags by a common prefix, broken @ word sections.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
407 prefix-group - Try to guess groups by prefix.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
408 simple-group - If imenu already returned some meta groups, stick all
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
409 tags that are not in a group into a sub-group."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
410 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
411 :type '(repeat
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
412 (radio
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
413 (const :tag "Sort the tags." sort)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
414 (const :tag "Trim words to common prefix." trim-words)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
415 (const :tag "Create groups from common prefixes." prefix-group)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
416 (const :tag "Group loose tags into their own group." simple-group))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
417 ))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
418
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
419 (defcustom speedbar-tag-group-name-minimum-length 4
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
420 "*The minimum length of a prefix group name before expanding.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
421 Thus, if the `speedbar-tag-hierarchy-method' includes `prefix-group'
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
422 and one such groups common characters is less than this number of
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
423 characters, then the group name will be changed to the form of:
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
424 worda to wordb
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
425 instead of just
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
426 word
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
427 This way we won't get silly looking listings."
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
428 :group 'speedbar
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
429 :type 'integer)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
430
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
431 (defcustom speedbar-tag-split-minimum-length 20
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
432 "*Minimum length before we stop trying to create sub-lists in tags.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
433 This is used by all tag-hierarchy methods that break large lists into
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
434 sub-lists."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
435 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
436 :type 'integer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
437
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
438 (defcustom speedbar-tag-regroup-maximum-length 10
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
439 "*Maximum length of submenus that are regrouped.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
440 If the regrouping option is used, then if two or more short subgroups
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
441 are next to each other, then they are combined until this number of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
442 items is reached."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
443 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
444 :type 'integer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
445
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
446 (defcustom speedbar-activity-change-focus-flag nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
447 "*Non-nil means the selected frame will change based on activity.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
448 Thus, if a file is selected for edit, the buffer will appear in the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
449 selected frame and the focus will change to that frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
450 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
451 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
452
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
453 (defcustom speedbar-directory-button-trim-method 'span
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
454 "*Indicates how the directory button will be displayed.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
455 Possible values are:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
456 'span - span large directories over multiple lines.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
457 'trim - trim large directories to only show the last few.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
458 nil - no trimming."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
459 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
460 :type '(radio (const :tag "Span large directories over mutiple lines."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
461 span)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
462 (const :tag "Trim large directories to only show the last few."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
463 trim)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
464 (const :tag "No trimming." nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
465
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
466 (defcustom speedbar-smart-directory-expand-flag t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
467 "*Non-nil means speedbar should use smart expansion.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
468 Smart expansion only affects when speedbar wants to display a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
469 directory for a file in the attached frame. When smart expansion is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
470 enabled, new directories which are children of a displayed directory
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
471 are expanded in the current framework. If nil, then the current
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
472 hierarchy would be replaced with the new directory."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
473 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
474 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
475
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
476 (defvar speedbar-hide-button-brackets-flag nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
477 "*Non-nil means speedbar will hide the brackets around the + or -.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
478
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
479 (defcustom speedbar-before-popup-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
480 "*Hooks called before popping up the speedbar frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
481 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
482 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
483
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
484 (defcustom speedbar-before-delete-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
485 "*Hooks called before deleting the speedbar frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
486 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
487 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
488
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
489 (defcustom speedbar-mode-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
490 "*Hooks called after creating a speedbar buffer."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
491 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
492 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
493
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
494 (defcustom speedbar-timer-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
495 "*Hooks called after running the speedbar timer function."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
496 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
497 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
498
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
499 (defcustom speedbar-verbosity-level 1
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
500 "*Verbosity level of the speedbar. 0 means say nothing.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
501 1 means medium level verbosity. 2 and higher are higher levels of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
502 verbosity."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
503 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
504 :type 'integer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
505
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
506 (defvar speedbar-indicator-separator " "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
507 "String separating file text from indicator characters.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
508
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
509 (defcustom speedbar-vc-do-check t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
510 "*Non-nil check all files in speedbar to see if they have been checked out.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
511 Any file checked out is marked with `speedbar-vc-indicator'"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
512 :group 'speedbar-vc
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
513 :type 'boolean)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
514
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
515 (defvar speedbar-vc-indicator "*"
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
516 "Text used to mark files which are currently checked out.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
517 Currently only RCS is supported. Other version control systems can be
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
518 added by examining the function `speedbar-this-file-in-vc' and
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
519 `speedbar-vc-check-dir-p'")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
520
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
521 (defcustom speedbar-vc-path-enable-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
522 "*Return non-nil if the current path should be checked for Version Control.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
523 Functions in this hook must accept one parameter which is the path
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
524 being checked."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
525 :group 'speedbar-vc
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
526 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
527
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
528 (defcustom speedbar-vc-in-control-hook nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
529 "*Return non-nil if the specified file is under Version Control.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
530 Functions in this hook must accept two parameters. The PATH of the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
531 current file, and the FILENAME of the file being checked."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
532 :group 'speedbar-vc
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
533 :type 'hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
534
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
535 (defvar speedbar-vc-to-do-point nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
536 "Local variable maintaining the current version control check position.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
537
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
538 (defcustom speedbar-obj-do-check t
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
539 "*Non-nil check all files in speedbar to see if they have an object file.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
540 Any file checked out is marked with `speedbar-obj-indicator', and the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
541 marking is based on `speedbar-obj-alist'"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
542 :group 'speedbar-vc
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
543 :type 'boolean)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
544
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
545 (defvar speedbar-obj-to-do-point nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
546 "Local variable maintaining the current version control check position.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
547
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
548 (defvar speedbar-obj-indicator '("#" . "!")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
549 "Text used to mark files that have a corresponding hidden object file.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
550 The car is for an up-to-date object. The cdr is for an out of date object.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
551 The expression `speedbar-obj-alist' defines who gets tagged.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
552
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
553 (defvar speedbar-obj-alist
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
554 '(("\\.\\([cpC]\\|cpp\\|cc\\)$" . ".o")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
555 ("\\.el$" . ".elc")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
556 ("\\.java$" . ".class")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
557 ("\\.f\\(or\\|90\\|77\\)?$" . ".o")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
558 ("\\.tex$" . ".dvi")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
559 ("\\.texi$" . ".info"))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
560 "Alist of file extensions, and their corresponding object file type.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
561
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
562 (defvar speedbar-indicator-regex
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
563 (concat (regexp-quote speedbar-indicator-separator)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
564 "\\("
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
565 (regexp-quote speedbar-vc-indicator)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
566 "\\|"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
567 (regexp-quote (car speedbar-obj-indicator))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
568 "\\|"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
569 (regexp-quote (cdr speedbar-obj-indicator))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
570 "\\)*")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
571 "Regular expression used when identifying files.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
572 Permits stripping of indicator characters from a line.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
573
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
574 (defcustom speedbar-scanner-reset-hook nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
575 "*Hook called whenever generic scanners are reset.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
576 Set this to implement your own scanning / rescan safe functions with
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
577 state data."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
578 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
579 :type 'hook)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
580
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
581 (defvar speedbar-ignored-modes nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
582 "*List of major modes which speedbar will not switch directories for.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
583
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
584 (defun speedbar-extension-list-to-regex (extlist)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
585 "Takes EXTLIST, a list of extensions and transforms it into regexp.
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
586 All the preceding `.' are stripped for an optimized expression starting
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
587 with `.' followed by extensions, followed by full-filenames."
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
588 (let ((regex1 nil) (regex2 nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
589 (while extlist
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
590 (if (= (string-to-char (car extlist)) ?.)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
591 (setq regex1 (concat regex1 (if regex1 "\\|" "")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
592 (substring (car extlist) 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
593 (setq regex2 (concat regex2 (if regex2 "\\|" "") (car extlist))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
594 (setq extlist (cdr extlist)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
595 ;; concat all the sub-exressions together, making sure all types
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
596 ;; of parts exist during concatination.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
597 (concat "\\("
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
598 (if regex1 (concat "\\(\\.\\(" regex1 "\\)\\)") "")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
599 (if (and regex1 regex2) "\\|" "")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
600 (if regex2 (concat "\\(" regex2 "\\)") "")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
601 "\\)$")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
602
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
603 (defvar speedbar-ignored-path-regexp nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
604 "Regular expression matching paths speedbar will not switch to.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
605 Created from `speedbar-ignored-path-expressions' with the function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
606 `speedbar-extension-list-to-regex' (A misnamed function in this case.)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
607 Use the function `speedbar-add-ignored-path-regexp', or customize the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
608 variable `speedbar-ignored-path-expressions' to modify this variable.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
609
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
610 (defcustom speedbar-ignored-path-expressions
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
611 '("/logs?/\\'")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
612 "*List of regular expressions matching directories speedbar will ignore.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
613 They should included paths to directories which are notoriously very
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
614 large and take a long time to load in. Use the function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
615 `speedbar-add-ignored-path-regexp' to add new items to this list after
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
616 speedbar is loaded. You may place anything you like in this list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
617 before speedbar has been loaded."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
618 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
619 :type '(repeat (regexp :tag "Path Regexp"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
620 :set (lambda (sym val)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
621 (setq speedbar-ignored-path-expressions val
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
622 speedbar-ignored-path-regexp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
623 (speedbar-extension-list-to-regex val))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
624
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
625 (defcustom speedbar-directory-unshown-regexp "^\\(CVS\\|RCS\\|SCCS\\)\\'"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
626 "*Regular expression matching directories not to show in speedbar.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
627 They should include commonly existing directories which are not
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
628 useful, such as version control."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
629 :group 'speedbar
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
630 :type 'string)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
631
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
632 (defvar speedbar-file-unshown-regexp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
633 (let ((nstr "") (noext completion-ignored-extensions))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
634 (while noext
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
635 (setq nstr (concat nstr (regexp-quote (car noext)) "\\'"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
636 (if (cdr noext) "\\|" ""))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
637 noext (cdr noext)))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
638 ;; backup refdir lockfile
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
639 (concat nstr "\\|#[^#]+#$\\|\\.\\.?\\'\\|\\.#"))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
640 "*Regexp matching files we don't want displayed in a speedbar buffer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
641 It is generated from the variable `completion-ignored-extensions'")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
642
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
643 ;; this is dangerous to customize, because the defaults will probably
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
644 ;; change in the future.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
645 (defcustom speedbar-supported-extension-expressions
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
646 (append '(".[ch]\\(\\+\\+\\|pp\\|c\\|h\\|xx\\)?" ".tex\\(i\\(nfo\\)?\\)?"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
647 ".el" ".emacs" ".l" ".lsp" ".p" ".java" ".f\\(90\\|77\\|or\\)?")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
648 (if speedbar-use-imenu-flag
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
649 '(".ada" ".pl" ".tcl" ".m" ".scm" ".pm" ".py"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
650 ;; html is not supported by default, but an imenu tags package
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
651 ;; is available. Also, html files are nice to be able to see.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
652 ".s?html"
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
653 "Makefile\\(\\.in\\)?")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
654 "*List of regular expressions which will match files supported by tagging.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
655 Do not prefix the `.' char with a double \\ to quote it, as the period
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
656 will be stripped by a simplified optimizer when compiled into a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
657 singular expression. This variable will be turned into
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
658 `speedbar-file-regexp' for use with speedbar. You should use the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
659 function `speedbar-add-supported-extension' to add a new extension at
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
660 runtime, or use the configuration dialog to set it in your .emacs
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
661 file."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
662 :group 'speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
663 :type '(repeat (regexp :tag "Extension Regexp"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
664 :set (lambda (sym val)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
665 (setq speedbar-supported-extension-expressions val
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
666 speedbar-file-regexp (speedbar-extension-list-to-regex val)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
667 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
668
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
669 (defvar speedbar-file-regexp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
670 (speedbar-extension-list-to-regex speedbar-supported-extension-expressions)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
671 "Regular expression matching files we know how to expand.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
672 Created from `speedbar-supported-extension-expression' with the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
673 function `speedbar-extension-list-to-regex'")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
674
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
675 (defun speedbar-add-supported-extension (extension)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
676 "Add EXTENSION as a new supported extension for speedbar tagging.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
677 This should start with a `.' if it is not a complete file name, and
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
678 the dot should NOT be quoted in with \\. Other regular expression
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
679 matchers are allowed however. EXTENSION may be a single string or a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
680 list of strings."
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
681 (interactive "sExtionsion: ")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
682 (if (not (listp extension)) (setq extension (list extension)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
683 (while extension
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
684 (if (member (car extension) speedbar-supported-extension-expressions)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
685 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
686 (setq speedbar-supported-extension-expressions
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
687 (cons (car extension) speedbar-supported-extension-expressions)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
688 (setq extension (cdr extension)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
689 (setq speedbar-file-regexp (speedbar-extension-list-to-regex
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
690 speedbar-supported-extension-expressions)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
691
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
692 (defun speedbar-add-ignored-path-regexp (path-expression)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
693 "Add PATH-EXPRESSION as a new ignored path for speedbar tracking.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
694 This function will modify `speedbar-ignored-path-regexp' and add
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
695 PATH-EXPRESSION to `speedbar-ignored-path-expressions'."
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
696 (interactive "sPath regex: ")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
697 (if (not (listp path-expression))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
698 (setq path-expression (list path-expression)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
699 (while path-expression
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
700 (if (member (car path-expression) speedbar-ignored-path-expressions)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
701 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
702 (setq speedbar-ignored-path-expressions
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
703 (cons (car path-expression) speedbar-ignored-path-expressions)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
704 (setq path-expression (cdr path-expression)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
705 (setq speedbar-ignored-path-regexp (speedbar-extension-list-to-regex
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
706 speedbar-ignored-path-expressions)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
707
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
708 ;; If we don't have custom, then we set it here by hand.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
709 (if (not (fboundp 'custom-declare-variable))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
710 (setq speedbar-file-regexp (speedbar-extension-list-to-regex
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
711 speedbar-supported-extension-expressions)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
712 speedbar-ignored-path-regexp (speedbar-extension-list-to-regex
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
713 speedbar-ignored-path-expressions)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
714
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
715 (defvar speedbar-update-flag (and
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
716 (or (fboundp 'run-with-idle-timer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
717 (fboundp 'start-itimer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
718 (boundp 'post-command-idle-hook))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
719 window-system)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
720 "*Non-nil means to automatically update the display.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
721 When this is nil then speedbar will not follow the attached frame's path.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
722 When speedbar is active, use:
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
723
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
724 \\<speedbar-key-map> `\\[speedbar-toggle-updates]'
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
725
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
726 to toggle this value.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
727
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
728 (defvar speedbar-syntax-table nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
729 "Syntax-table used on the speedbar.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
730
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
731 (if speedbar-syntax-table
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
732 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
733 (setq speedbar-syntax-table (make-syntax-table))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
734 ;; turn off paren matching around here.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
735 (modify-syntax-entry ?\' " " speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
736 (modify-syntax-entry ?\" " " speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
737 (modify-syntax-entry ?( " " speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
738 (modify-syntax-entry ?) " " speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
739 (modify-syntax-entry ?[ " " speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
740 (modify-syntax-entry ?] " " speedbar-syntax-table))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
741
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
742 (defvar speedbar-key-map nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
743 "Keymap used in speedbar buffer.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
744
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
745 (if speedbar-key-map
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
746 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
747 (setq speedbar-key-map (make-keymap))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
748 (suppress-keymap speedbar-key-map t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
749
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
750 ;; control
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
751 (define-key speedbar-key-map "g" 'speedbar-refresh)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
752 (define-key speedbar-key-map "t" 'speedbar-toggle-updates)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
753 (define-key speedbar-key-map "q" 'speedbar-close-frame)
23080
8b7bb810f362 *** empty log message ***
Dan Nicolaescu <done@ece.arizona.edu>
parents: 23073
diff changeset
754 (define-key speedbar-key-map "Q" 'delete-frame)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
755
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
756 ;; navigation
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
757 (define-key speedbar-key-map "n" 'speedbar-next)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
758 (define-key speedbar-key-map "p" 'speedbar-prev)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
759 (define-key speedbar-key-map "\M-n" 'speedbar-restricted-next)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
760 (define-key speedbar-key-map "\M-p" 'speedbar-restricted-prev)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
761 (define-key speedbar-key-map "\C-\M-n" 'speedbar-forward-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
762 (define-key speedbar-key-map "\C-\M-p" 'speedbar-backward-list)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
763 (define-key speedbar-key-map " " 'speedbar-scroll-up)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
764 (define-key speedbar-key-map [delete] 'speedbar-scroll-down)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
765
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
766 ;; Short cuts I happen to find useful
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
767 (define-key speedbar-key-map "r"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
768 (lambda () (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
769 (speedbar-change-initial-expansion-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
770 speedbar-previously-used-expansion-list-name)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
771 (define-key speedbar-key-map "b"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
772 (lambda () (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
773 (speedbar-change-initial-expansion-list "quick buffers")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
774 (define-key speedbar-key-map "f"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
775 (lambda () (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
776 (speedbar-change-initial-expansion-list "files")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
777
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
778 ;; Overrides
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
779 (substitute-key-definition 'switch-to-buffer
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
780 'speedbar-switch-buffer-attached-frame
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
781 speedbar-key-map global-map)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
782
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
783 (if speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
784 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
785 ;; mouse bindings so we can manipulate the items on each line
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
786 (define-key speedbar-key-map 'button2 'speedbar-click)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
787 (define-key speedbar-key-map '(shift button2) 'speedbar-power-click)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
788 ;; Info doc fix from Bob Weiner
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
789 (if (featurep 'infodoc)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
790 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
791 (define-key speedbar-key-map 'button3 'speedbar-xemacs-popup-kludge))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
792 (define-key speedbar-key-map '(meta button3) 'speedbar-mouse-item-info)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
793 )
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
794
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
795 ;; mouse bindings so we can manipulate the items on each line
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
796 (define-key speedbar-key-map [down-mouse-1] 'speedbar-double-click)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
797 (define-key speedbar-key-map [mouse-2] 'speedbar-click)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
798 ;; This is the power click for new frames, or refreshing a cache
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
799 (define-key speedbar-key-map [S-mouse-2] 'speedbar-power-click)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
800 ;; This adds a small unecessary visual effect
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
801 ;;(define-key speedbar-key-map [down-mouse-2] 'speedbar-quick-mouse)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
802 (define-key speedbar-key-map [M-mouse-2] 'speedbar-mouse-item-info)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
803
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
804 (define-key speedbar-key-map [down-mouse-3] 'speedbar-emacs-popup-kludge)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
805
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
806 ;; This lets the user scroll as if we had a scrollbar... well maybe not
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
807 (define-key speedbar-key-map [mode-line mouse-2] 'speedbar-mouse-hscroll)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
808 ;; another handy place users might click to get our menu.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
809 (define-key speedbar-key-map [mode-line down-mouse-1]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
810 'speedbar-emacs-popup-kludge)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
811
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
812 ;; We can't switch buffers with the buffer mouse menu. Lets hack it.
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
813 (define-key speedbar-key-map [C-down-mouse-1] 'speedbar-hack-buffer-menu)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
814
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
815 ;; Lastly, we want to track the mouse. Play here
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
816 (define-key speedbar-key-map [mouse-movement] 'speedbar-track-mouse)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
817 ))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
818
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
819 (defun speedbar-make-specialized-keymap ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
820 "Create a keymap for use w/ a speedbar major or minor display mode.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
821 This basically creates a sparse keymap, and makes it's parent be
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
822 `speedbar-key-map'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
823 (let ((k (make-sparse-keymap)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
824 (set-keymap-parent k speedbar-key-map)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
825 k))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
826
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
827 (defvar speedbar-file-key-map nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
828 "Keymap used in speedbar buffer while files are displayed.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
829
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
830 (if speedbar-file-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
831 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
832 (setq speedbar-file-key-map (speedbar-make-specialized-keymap))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
833
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
834 ;; Basic tree features
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
835 (define-key speedbar-file-key-map "e" 'speedbar-edit-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
836 (define-key speedbar-file-key-map "\C-m" 'speedbar-edit-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
837 (define-key speedbar-file-key-map "+" 'speedbar-expand-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
838 (define-key speedbar-file-key-map "-" 'speedbar-contract-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
839
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
840 ;; file based commands
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
841 (define-key speedbar-file-key-map "U" 'speedbar-up-directory)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
842 (define-key speedbar-file-key-map "I" 'speedbar-item-info)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
843 (define-key speedbar-file-key-map "B" 'speedbar-item-byte-compile)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
844 (define-key speedbar-file-key-map "L" 'speedbar-item-load)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
845 (define-key speedbar-file-key-map "C" 'speedbar-item-copy)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
846 (define-key speedbar-file-key-map "D" 'speedbar-item-delete)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
847 (define-key speedbar-file-key-map "O" 'speedbar-item-object-delete)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
848 (define-key speedbar-file-key-map "R" 'speedbar-item-rename)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
849 )
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
850
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
851 (defvar speedbar-easymenu-definition-base
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
852 '("Speedbar"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
853 ["Update" speedbar-refresh t]
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
854 ["Auto Update" speedbar-toggle-updates
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
855 :style toggle :selected speedbar-update-flag]
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
856 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
857 "Base part of the speedbar menu.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
858
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
859 (defvar speedbar-easymenu-definition-special
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
860 '(["Edit Item On Line" speedbar-edit-line t]
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
861 ["Show All Files" speedbar-toggle-show-all-files
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
862 :style toggle :selected speedbar-show-unknown-files]
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
863 ["Expand File Tags" speedbar-expand-line
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
864 (save-excursion (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
865 (looking-at "[0-9]+: *.\\+. "))]
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
866 ["Contract File Tags" speedbar-contract-line
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
867 (save-excursion (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
868 (looking-at "[0-9]+: *.-. "))]
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
869 ; ["Sort Tags" speedbar-toggle-sorting
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
870 ; :style toggle :selected speedbar-sort-tags]
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
871 "----"
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
872 ["File/Tag Information" speedbar-item-info t]
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
873 ["Load Lisp File" speedbar-item-load
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
874 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
875 (beginning-of-line)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
876 (looking-at "[0-9]+: *\\[[+-]\\] .+\\(\\.el\\)\\( \\|$\\)"))]
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
877 ["Byte Compile File" speedbar-item-byte-compile
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
878 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
879 (beginning-of-line)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
880 (looking-at "[0-9]+: *\\[[+-]\\] .+\\(\\.el\\)\\( \\|$\\)"))]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
881 ["Copy File" speedbar-item-copy
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
882 (save-excursion (beginning-of-line) (looking-at "[0-9]+: *\\["))]
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
883 ["Rename File" speedbar-item-rename
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
884 (save-excursion (beginning-of-line) (looking-at "[0-9]+: *[[<]"))]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
885 ["Delete File" speedbar-item-delete
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
886 (save-excursion (beginning-of-line) (looking-at "[0-9]+: *[[<]"))]
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
887 ["Delete Object" speedbar-item-object-delete
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
888 (save-excursion (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
889 (looking-at "[0-9]+: *\\[[+-]\\] [^ \n]+ \\*?[!#]$"))]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
890 )
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
891 "Additional menu items while in file-mode.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
892
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
893 (defvar speedbar-easymenu-definition-trailer
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
894 (append
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
895 (if (and (featurep 'custom) (fboundp 'custom-declare-variable))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
896 (list ["Customize..." speedbar-customize t]))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
897 (list
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
898 ["Close" speedbar-close-frame t]
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
899 ["Quit" delete-frame t] ))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
900 "Menu items appearing at the end of the speedbar menu.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
901
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
902 (defvar speedbar-desired-buffer nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
903 "Non-nil when speedbar is showing buttons specific a special mode.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
904 In this case it is the originating buffer.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
905 (defvar speedbar-buffer nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
906 "The buffer displaying the speedbar.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
907 (defvar speedbar-frame nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
908 "The frame displaying speedbar.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
909 (defvar speedbar-cached-frame nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
910 "The frame that was last created, then removed from the display.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
911 (defvar speedbar-full-text-cache nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
912 "The last open directory is saved in its entirety for ultra-fast switching.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
913 (defvar speedbar-timer nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
914 "The speedbar timer used for updating the buffer.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
915 (defvar speedbar-attached-frame nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
916 "The frame which started speedbar mode.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
917 This is the frame from which all data displayed in the speedbar is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
918 gathered, and in which files and such are displayed.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
919
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
920 (defvar speedbar-last-selected-file nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
921 "The last file which was selected in speedbar buffer.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
922
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
923 (defvar speedbar-shown-directories nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
924 "Maintain list of directories simultaneously open in the current speedbar.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
925
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
926 (defvar speedbar-directory-contents-alist nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
927 "An association list of directories and their contents.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
928 Each sublist was returned by `speedbar-file-lists'. This list is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
929 maintained to speed up the refresh rate when switching between
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
930 directories.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
931
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
932 (defvar speedbar-power-click nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
933 "Never set this by hand. Value is t when S-mouse activity occurs.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
934
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
935
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
936 ;;; Compatibility
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
937 ;;
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
938 (if (fboundp 'frame-parameter)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
939
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
940 (defalias 'speedbar-frame-parameter 'frame-parameter)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
941
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
942 (defun speedbar-frame-parameter (frame parameter)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
943 "Return FRAME's PARAMETER value."
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
944 (cdr (assoc parameter (frame-parameters frame)))))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
945
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
946 ;;; Mode definitions/ user commands
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
947 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
948
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
949 ;;;###autoload
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
950 (defalias 'speedbar 'speedbar-frame-mode)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
951 ;;;###autoload
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
952 (defun speedbar-frame-mode (&optional arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
953 "Enable or disable speedbar. Positive ARG means turn on, negative turn off.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
954 nil means toggle. Once the speedbar frame is activated, a buffer in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
955 `speedbar-mode' will be displayed. Currently, only one speedbar is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
956 supported at a time.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
957 `speedbar-before-popup-hook' is called before popping up the speedbar frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
958 `speedbar-before-delete-hook' is called before the frame is deleted."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
959 (interactive "P")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
960 ;; toggle frame on and off.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
961 (if (not arg) (if (and (frame-live-p speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
962 (frame-visible-p speedbar-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
963 (setq arg -1) (setq arg 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
964 ;; turn the frame off on neg number
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
965 (if (and (numberp arg) (< arg 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
966 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
967 (run-hooks 'speedbar-before-delete-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
968 (if (and speedbar-frame (frame-live-p speedbar-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
969 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
970 (setq speedbar-cached-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
971 (make-frame-invisible speedbar-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
972 (setq speedbar-frame nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
973 (speedbar-set-timer nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
974 ;; Used to delete the buffer. This has the annoying affect of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
975 ;; preventing whatever took its place from ever appearing
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
976 ;; as the default after a C-x b was typed
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
977 ;;(if (bufferp speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
978 ;; (kill-buffer speedbar-buffer))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
979 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
980 ;; Set this as our currently attached frame
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
981 (setq speedbar-attached-frame (selected-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
982 (run-hooks 'speedbar-before-popup-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
983 ;; Get the frame to work in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
984 (if (frame-live-p speedbar-cached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
985 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
986 (setq speedbar-frame speedbar-cached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
987 (make-frame-visible speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
988 ;; Get the buffer to play with
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
989 (speedbar-mode)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
990 (select-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
991 (if (not (eq (current-buffer) speedbar-buffer))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
992 (switch-to-buffer speedbar-buffer))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
993 (set-window-dedicated-p (selected-window) t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
994 (raise-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
995 (speedbar-set-timer speedbar-update-speed)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
996 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
997 (if (frame-live-p speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
998 (raise-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
999 (setq speedbar-frame
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1000 (if speedbar-xemacsp
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1001 ;; Only guess height if it is not specified.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1002 (if (member 'height speedbar-frame-plist)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1003 (make-frame speedbar-frame-plist)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1004 (make-frame (nconc (list 'height
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1005 (speedbar-needed-height))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1006 speedbar-frame-plist)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1007 (let* ((mh (speedbar-frame-parameter nil 'menu-bar-lines))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1008 (cfx (speedbar-frame-parameter nil 'left))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1009 (cfy (speedbar-frame-parameter nil 'top))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1010 (cfw (frame-pixel-width))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1011 (params
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1012 ;; Only add a guessed height if one is not specified
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1013 ;; in the input parameters.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1014 (if (assoc 'height speedbar-frame-parameters)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1015 speedbar-frame-parameters
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1016 (append
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1017 speedbar-frame-parameters
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1018 (list (cons 'height (+ mh (frame-height)))))))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1019 (frame
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1020 (if (or (< emacs-major-version 20)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1021 (not (eq window-system 'x)))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1022 (make-frame params)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1023 (let ((x-pointer-shape x-pointer-top-left-arrow)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1024 (x-sensitive-text-pointer-shape
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1025 x-pointer-hand2))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
1026 (make-frame params)))))
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1027 ;; Position speedbar frame.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1028 (if (or (not window-system) (eq window-system 'pc)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1029 (assoc 'left speedbar-frame-parameters)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1030 (assoc 'top speedbar-frame-parameters))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1031 ;; Do no positioning if not on a windowing system,
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1032 ;; or if left/top were specified in the parameters.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1033 frame
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1034 (let ((cfx
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1035 (if (not (consp cfx))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1036 cfx
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1037 ;; If cfx is a list, that means we grow
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1038 ;; from a specific edge of the display.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1039 ;; Convert that to the distance from the
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1040 ;; left side of the display.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1041 (if (eq (car cfx) '-)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1042 ;; A - means distance from the right edge
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1043 ;; of the display, or DW - cfx - framewidth
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1044 (- (x-display-pixel-width) (car (cdr cfx))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1045 (frame-pixel-width))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1046 (car (cdr cfx))))))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1047 (modify-frame-parameters
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1048 frame
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1049 (list
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1050 (cons
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1051 'left
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1052 ;; Decide which side to put it
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1053 ;; on. 200 is just a buffer
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1054 ;; for the left edge of the
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1055 ;; screen. The extra 10 is just
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1056 ;; dressings for window decorations.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1057 (let ((sfw (frame-pixel-width frame)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1058 (let ((left-guess (- cfx 10 sfw))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1059 (right-guess (+ cfx cfw 5)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1060 (let ((left-margin left-guess)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1061 (right-margin
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1062 (- (x-display-pixel-width)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1063 right-guess 5 sfw)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1064 (cond ((>= left-margin 0) left-guess)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1065 ((>= right-margin 0) right-guess)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1066 ;; otherwise choose side we overlap less
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1067 ((> left-margin right-margin) 0)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1068 (t (- (x-display-pixel-width) sfw 5)))))))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1069 (cons 'top cfy)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
1070 frame)))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1071 ;; reset the selection variable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1072 (setq speedbar-last-selected-file nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1073 ;; Put the buffer into the frame
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1074 (save-window-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1075 ;; Get the buffer to play with
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1076 (speedbar-mode)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1077 (select-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1078 (switch-to-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1079 (set-window-dedicated-p (selected-window) t))
23372
64e80b07376b (speedbar-frame-mode): Check if cfx or cfy is a list, and make sure it
Eric M. Ludlam <zappo@gnu.org>
parents: 23275
diff changeset
1080 (if (and (or (null window-system) (eq window-system 'pc))
64e80b07376b (speedbar-frame-mode): Check if cfx or cfy is a list, and make sure it
Eric M. Ludlam <zappo@gnu.org>
parents: 23275
diff changeset
1081 (fboundp 'set-frame-name))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1082 (progn
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1083 (select-frame speedbar-frame)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1084 (set-frame-name "Speedbar")))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1085 (speedbar-set-timer speedbar-update-speed)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1086
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1087 ;;;###autoload
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1088 (defun speedbar-get-focus ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1089 "Change frame focus to or from the speedbar frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1090 If the selected frame is not speedbar, then speedbar frame is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1091 selected. If the speedbar frame is active, then select the attached frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1092 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1093 (if (eq (selected-frame) speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1094 (if (frame-live-p speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1095 (select-frame speedbar-attached-frame))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1096 ;; If updates are off, then refresh the frame (they want it now...)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1097 (if (not speedbar-update-flag)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1098 (let ((speedbar-update-flag t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1099 (speedbar-timer-fn)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1100 ;; make sure we have a frame
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1101 (if (not (frame-live-p speedbar-frame)) (speedbar-frame-mode 1))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1102 ;; go there
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1103 (select-frame speedbar-frame)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1104 )
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1105 (other-frame 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1106
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1107 (defun speedbar-close-frame ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1108 "Turn off a currently active speedbar."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1109 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1110 (speedbar-frame-mode -1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1111 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1112 (other-frame 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1113
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1114 (defun speedbar-switch-buffer-attached-frame (&optional buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1115 "Switch to BUFFER in speedbar's attached frame, and raise that frame.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1116 This overrides the default behavior of `switch-to-buffer' which is
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1117 broken because of the dedicated speedbar frame."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1118 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1119 ;; Assume we are in the speedbar frame.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1120 (speedbar-get-focus)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1121 ;; Now switch buffers
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1122 (if buffer
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1123 (switch-to-buffer buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1124 (call-interactively 'switch-to-buffer nil nil)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1125
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1126 (defmacro speedbar-frame-width ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1127 "Return the width of the speedbar frame in characters.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1128 nil if it doesn't exist."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1129 '(frame-width speedbar-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1130
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1131 ;; XEmacs function only.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1132 (defun speedbar-needed-height (&optional frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1133 "The needed height for the tool bar FRAME (in characters)."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1134 (or frame (setq frame (selected-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1135 ;; The 1 is the missing modeline/minibuffer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1136 (+ 1 (/ (frame-pixel-height frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1137 (face-height 'default frame))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1138
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1139 (defun speedbar-mode ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1140 "Major mode for managing a display of directories and tags.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1141 \\<speedbar-key-map>
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1142 The first line represents the default path of the speedbar frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1143 Each directory segment is a button which jumps speedbar's default
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1144 directory to that path. Buttons are activated by clicking `\\[speedbar-click]'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1145 In some situations using `\\[speedbar-power-click]' is a `power click' which will
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1146 rescan cached items, or pop up new frames.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1147
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1148 Each line starting with <+> represents a directory. Click on the <+>
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1149 to insert the directory listing into the current tree. Click on the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1150 <-> to retract that list. Click on the directory name to go to that
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1151 directory as the default.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1152
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1153 Each line starting with [+] is a file. If the variable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1154 `speedbar-show-unknown-files' is t, the lines starting with [?] are
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1155 files which don't have imenu support, but are not expressly ignored.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1156 Files are completely ignored if they match `speedbar-file-unshown-regexp'
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1157 which is generated from `completion-ignored-extensions'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1158
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1159 Files with a `*' character after their name are files checked out of a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1160 version control system. (currently only RCS is supported.) New
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1161 version control systems can be added by examining the documentation
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1162 for `speedbar-this-file-in-vc' and `speedbar-vc-check-dir-p'
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1163
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1164 Files with a `#' or `!' character after them are source files that
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1165 have an object file associated with them. The `!' indicates that the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1166 files is out of date. You can control what source/object associations
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1167 exist through the variable `speedbar-obj-alist'.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1168
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1169 Click on the [+] to display a list of tags from that file. Click on
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1170 the [-] to retract the list. Click on the file name to edit the file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1171 in the attached frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1172
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1173 If you open tags, you might find a node starting with {+}, which is a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1174 category of tags. Click the {+} to expand the category. Jump-able
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1175 tags start with >. Click the name of the tag to go to that position
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1176 in the selected file.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1177
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1178 \\{speedbar-key-map}"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1179 ;; NOT interactive
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1180 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1181 (setq speedbar-buffer (set-buffer (get-buffer-create " SPEEDBAR")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1182 (kill-all-local-variables)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1183 (setq major-mode 'speedbar-mode)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1184 (setq mode-name "Speedbar")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1185 (set-syntax-table speedbar-syntax-table)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1186 (setq font-lock-keywords nil) ;; no font-locking please
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1187 (setq truncate-lines t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1188 (make-local-variable 'frame-title-format)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1189 (setq frame-title-format "Speedbar")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1190 ;; Set this up special just for the speedbar buffer
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1191 ;; Terminal minibuffer stuff does not require this.
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1192 (if (and window-system (not (eq window-system 'pc))
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1193 (null default-minibuffer-frame))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1194 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1195 (make-local-variable 'default-minibuffer-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1196 (setq default-minibuffer-frame speedbar-attached-frame)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1197 ;; Correct use of `temp-buffer-show-function': Bob Weiner
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1198 (if (and (boundp 'temp-buffer-show-hook)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1199 (boundp 'temp-buffer-show-function))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1200 (progn (make-local-variable 'temp-buffer-show-hook)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1201 (setq temp-buffer-show-hook temp-buffer-show-function)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1202 (make-local-variable 'temp-buffer-show-function)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1203 (setq temp-buffer-show-function 'speedbar-temp-buffer-show-function)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1204 (if speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1205 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1206 ;; Argh! mouse-track-click-hook doesn't understand the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1207 ;; make-local-hook conventions.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1208 (make-local-variable 'mouse-track-click-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1209 (add-hook 'mouse-track-click-hook
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1210 (lambda (event count)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1211 (if (/= (event-button event) 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1212 nil ; Do normal operations.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1213 (cond ((eq count 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1214 (speedbar-quick-mouse event))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1215 ((or (eq count 2)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1216 (eq count 3))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1217 (mouse-set-point event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1218 (speedbar-do-function-pointer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1219 (speedbar-quick-mouse event)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1220 ;; Don't do normal operations.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1221 t)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1222 (make-local-hook 'kill-buffer-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1223 (add-hook 'kill-buffer-hook (lambda () (let ((skilling (boundp 'skilling)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1224 (if skilling
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1225 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1226 (if (eq (current-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1227 speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1228 (speedbar-frame-mode -1)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1229 t t)
23083
2dea437fe88a (speedbar-with-writable): remove `toggle-read-only'.
Eric M. Ludlam <zappo@gnu.org>
parents: 23080
diff changeset
1230 (toggle-read-only 1)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1231 (speedbar-set-mode-line-format)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1232 (if speedbar-xemacsp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1233 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1234 (make-local-variable 'mouse-motion-handler)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1235 (setq mouse-motion-handler 'speedbar-track-mouse-xemacs))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1236 (if speedbar-track-mouse-flag
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1237 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1238 (make-local-variable 'track-mouse)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1239 (setq track-mouse t))) ;this could be messy.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1240 (setq auto-show-mode nil)) ;no auto-show for Emacs
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1241 (run-hooks 'speedbar-mode-hook))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1242 (speedbar-update-contents)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1243 speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1244
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1245 (defmacro speedbar-with-attached-buffer (&rest forms)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1246 "Execute FORMS in the attached frame's special buffer.
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1247 Optionally select that frame if necessary."
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1248 `(save-selected-window
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1249 (speedbar-set-timer speedbar-update-speed)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1250 (select-frame speedbar-attached-frame)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1251 ,@forms
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1252 (speedbar-maybee-jump-to-attached-frame)))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1253
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1254 (defun speedbar-message (fmt &rest args)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1255 "Like message, but for use in the speedbar frame.
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1256 Argument FMT is the format string, and ARGS are the arguments for message."
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1257 (save-selected-window
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1258 (select-frame speedbar-attached-frame)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1259 (apply 'message fmt args)))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1260
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1261 (defun speedbar-y-or-n-p (prompt)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1262 "Like `y-or-n-p', but for use in the speedbar frame.
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1263 Argument PROMPT is the prompt to use."
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1264 (save-selected-window
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1265 (if (and default-minibuffer-frame (not (eq default-minibuffer-frame
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1266 speedbar-attached-frame)))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1267 (select-frame speedbar-attached-frame))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1268 (y-or-n-p prompt)))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1269
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1270 (defun speedbar-show-info-under-mouse (&optional event)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1271 "Call the info function for the line under the mouse.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1272 Optional EVENT is currently not used."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1273 (let ((pos (mouse-position))) ; we ignore event until I use it later.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1274 (if (equal (car pos) speedbar-frame)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1275 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1276 (save-window-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1277 (apply 'set-mouse-position pos)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1278 (speedbar-item-info))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1279
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1280 (defun speedbar-set-mode-line-format ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1281 "Set the format of the mode line based on the current speedbar environment.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1282 This gives visual indications of what is up. It EXPECTS the speedbar
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1283 frame and window to be the currently active frame and window."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1284 (if (and (frame-live-p speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1285 (or (not speedbar-xemacsp)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1286 (specifier-instance has-modeline-p)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1287 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1288 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1289 (let* ((w (or (speedbar-frame-width) 20))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1290 (p1 "<<")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1291 (p5 ">>")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1292 (p3 (if speedbar-update-flag "SPEEDBAR" "SLOWBAR"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1293 (blank (- w (length p1) (length p3) (length p5)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1294 (if line-number-mode 4 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1295 (p2 (if (> blank 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1296 (make-string (/ blank 2) ? )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1297 ""))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1298 (p4 (if (> blank 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1299 (make-string (+ (/ blank 2) (% blank 2)) ? )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1300 ""))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1301 (tf
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1302 (if line-number-mode
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1303 (list (concat p1 p2 p3) '(line-number-mode " %3l")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1304 (concat p4 p5))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1305 (list (concat p1 p2 p3 p4 p5)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1306 (if (not (equal mode-line-format tf))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1307 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1308 (setq mode-line-format tf)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1309 (force-mode-line-update)))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1310
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1311 (defun speedbar-temp-buffer-show-function (buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1312 "Placed in the variable `temp-buffer-show-function' in `speedbar-mode'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1313 If a user requests help using \\[help-command] <Key> the temp BUFFER will be
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1314 redirected into a window on the attached frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1315 (if speedbar-attached-frame (select-frame speedbar-attached-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1316 (pop-to-buffer buffer nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1317 (other-window -1)
23084
e1613f1c52f8 (speedbar-temp-buffer-show-function): For emacs don't call hook
Eric M. Ludlam <zappo@gnu.org>
parents: 23083
diff changeset
1318 ;; Fix for using this hook on some platforms: Bob Weiner
e1613f1c52f8 (speedbar-temp-buffer-show-function): For emacs don't call hook
Eric M. Ludlam <zappo@gnu.org>
parents: 23083
diff changeset
1319 (cond ((not speedbar-xemacsp)
e1613f1c52f8 (speedbar-temp-buffer-show-function): For emacs don't call hook
Eric M. Ludlam <zappo@gnu.org>
parents: 23083
diff changeset
1320 (run-hooks 'temp-buffer-show-hook))
e1613f1c52f8 (speedbar-temp-buffer-show-function): For emacs don't call hook
Eric M. Ludlam <zappo@gnu.org>
parents: 23083
diff changeset
1321 ((fboundp 'run-hook-with-args)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1322 (run-hook-with-args 'temp-buffer-show-hook buffer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1323 ((and (boundp 'temp-buffer-show-hook)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1324 (listp temp-buffer-show-hook))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1325 (mapcar (function (lambda (hook) (funcall hook buffer)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1326 temp-buffer-show-hook))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1327
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1328 (defvar speedbar-previous-menu nil
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1329 "The menu before the last `speedbar-reconfigure-keymaps' was called.")
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1330
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1331 (defun speedbar-reconfigure-keymaps ()
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1332 "Reconfigure the menu-bar in a speedbar frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1333 Different menu items are displayed depending on the current display mode
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1334 and the existence of packages."
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1335 (let ((md (append
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1336 speedbar-easymenu-definition-base
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1337 (if speedbar-shown-directories
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1338 ;; file display mode version
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1339 (speedbar-initial-menu)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1340 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1341 (select-frame speedbar-attached-frame)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1342 (if (local-variable-p
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1343 'speedbar-easymenu-definition-special
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1344 (current-buffer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1345 ;; If bound locally, we can use it
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1346 speedbar-easymenu-definition-special)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1347 ;; Dynamic menu stuff
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1348 '("-")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1349 (list (cons "Displays"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1350 (let ((displays nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1351 (alist speedbar-initial-expansion-mode-alist))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1352 (while alist
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1353 (setq displays
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1354 (cons
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1355 (vector
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1356 (capitalize (car (car alist)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1357 (list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1358 'speedbar-change-initial-expansion-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1359 (car (car alist)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1360 t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1361 displays))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1362 (setq alist (cdr alist)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1363 displays)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1364 ;; The trailer
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1365 speedbar-easymenu-definition-trailer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1366 (localmap (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1367 (let ((cf (selected-frame)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1368 (prog2
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1369 (select-frame speedbar-attached-frame)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1370 (if (local-variable-p
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1371 'speedbar-special-mode-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1372 (current-buffer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1373 speedbar-special-mode-key-map)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1374 (select-frame cf))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1375 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1376 (set-buffer speedbar-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1377 (use-local-map (or localmap
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1378 (speedbar-initial-keymap)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1379 ;; This creates a small keymap we can glom the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1380 ;; menu adjustments into.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1381 (speedbar-make-specialized-keymap)))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1382 ;; Delete the old menu if applicable.
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1383 (if speedbar-previous-menu (easy-menu-remove speedbar-previous-menu))
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1384 (setq speedbar-previous-menu md)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1385 ;; Now add the new menu
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1386 (if (not speedbar-xemacsp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1387 (easy-menu-define speedbar-menu-map (current-local-map)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1388 "Speedbar menu" md)
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1389 (easy-menu-add md (current-local-map))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1390 (set-buffer-menubar (list md))))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1391
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1392
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1393 ;;; User Input stuff
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1394 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1395
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1396 ;; XEmacs: this can be implemented using modeline keymaps, but there
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1397 ;; is no use, as we have horizontal scrollbar (as the docstring
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1398 ;; hints.)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1399 (defun speedbar-mouse-hscroll (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1400 "Read a mouse event E from the mode line, and horizontally scroll.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1401 If the mouse is being clicked on the far left, or far right of the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1402 mode-line. This is only useful for non-XEmacs"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1403 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1404 (let* ((xp (car (nth 2 (car (cdr e)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1405 (cpw (/ (frame-pixel-width)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1406 (frame-width)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1407 (oc (1+ (/ xp cpw)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1408 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1409 (cond ((< oc 3)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1410 (scroll-left 2))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1411 ((> oc (- (window-width) 3))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1412 (scroll-right 2))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1413 (t (speedbar-message
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1414 "Click on the edge of the modeline to scroll left/right")))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1415 ;;(speedbar-message "X: Pixel %d Char Pixels %d On char %d" xp cpw oc)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1416 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1417
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1418 (defun speedbar-customize ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1419 "Customize speedbar using the Custom package."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1420 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1421 (let ((sf (selected-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1422 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1423 (customize-group 'speedbar)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1424 (select-frame sf))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1425 (speedbar-maybee-jump-to-attached-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1426
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1427 (defun speedbar-track-mouse (event)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1428 "For motion EVENT, display info about the current line."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1429 (interactive "e")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1430 (if (not speedbar-track-mouse-flag)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1431 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1432 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1433 (let ((char (nth 1 (car (cdr event)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1434 (if (not (numberp char))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1435 (speedbar-message nil)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1436 (goto-char char)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1437 ;; (speedbar-message "%S" event)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1438 (speedbar-item-info)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1439 )))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1440
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1441 (defun speedbar-track-mouse-xemacs (event)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1442 "For motion EVENT, display info about the current line."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1443 (if (functionp (default-value 'mouse-motion-handler))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1444 (funcall (default-value 'mouse-motion-handler) event))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1445 (if speedbar-track-mouse-flag
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1446 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1447 (save-window-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1448 (condition-case ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1449 (progn (mouse-set-point event)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1450 ;; Prevent focus-related bugs.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1451 (if (eq major-mode 'speedbar-mode)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1452 (speedbar-item-info)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1453 (error nil))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1454
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1455 ;; In XEmacs, we make popup menus work on the item over mouse (as
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1456 ;; opposed to where the point happens to be.) We attain this by
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1457 ;; temporarily moving the point to that place.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1458 ;; Hrvoje Niksic <hniksic@srce.hr>
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1459 (defun speedbar-xemacs-popup-kludge (event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1460 "Pop up a menu related to the clicked on item.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1461 Must be bound to EVENT."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1462 (interactive "e")
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1463 (select-frame speedbar-frame)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1464 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1465 (goto-char (event-closest-point event))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1466 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1467 (forward-char (min 5 (- (save-excursion (end-of-line) (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1468 (save-excursion (beginning-of-line) (point)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1469 (popup-mode-menu)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1470 ;; Wait for menu to bail out. `popup-mode-menu' (and other popup
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1471 ;; menu functions) return immediately.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1472 (let (new)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1473 (while (not (misc-user-event-p (setq new (next-event))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1474 (dispatch-event new))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1475 (dispatch-event new))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1476
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1477 (defun speedbar-emacs-popup-kludge (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1478 "Pop up a menu related to the clicked on item.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1479 Must be bound to event E."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1480 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1481 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1482 (mouse-set-point e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1483 ;; This gets the cursor where the user can see it.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1484 (if (not (bolp)) (forward-char -1))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1485 (sit-for 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1486 (if (< emacs-major-version 20)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1487 (mouse-major-mode-menu e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1488 (mouse-major-mode-menu e nil))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1489
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1490 (defun speedbar-hack-buffer-menu (e)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1491 "Control mouse 1 is buffer menu.
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1492 This hack overrides it so that the right thing happens in the main
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1493 Emacs frame, not in the speedbar frame.
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1494 Argument E is the event causing this activity."
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1495 (interactive "e")
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1496 (let ((fn (lookup-key global-map (if speedbar-xemacsp
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1497 '(control button1)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1498 [C-down-mouse-1])))
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1499 (newbuff nil))
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1500 (unwind-protect
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1501 (save-excursion
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1502 (set-window-dedicated-p (selected-window) nil)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1503 (call-interactively fn)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1504 (setq newbuff (current-buffer)))
24809
078e0b907e6e (speedbar-hack-buffer-menu): Fixed so if the user
Karl Heuer <kwzh@gnu.org>
parents: 24475
diff changeset
1505 (switch-to-buffer speedbar-buffer)
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1506 (set-window-dedicated-p (selected-window) t))
24809
078e0b907e6e (speedbar-hack-buffer-menu): Fixed so if the user
Karl Heuer <kwzh@gnu.org>
parents: 24475
diff changeset
1507 (if (not (eq newbuff speedbar-buffer))
078e0b907e6e (speedbar-hack-buffer-menu): Fixed so if the user
Karl Heuer <kwzh@gnu.org>
parents: 24475
diff changeset
1508 (speedbar-with-attached-buffer
078e0b907e6e (speedbar-hack-buffer-menu): Fixed so if the user
Karl Heuer <kwzh@gnu.org>
parents: 24475
diff changeset
1509 (switch-to-buffer newbuff)))))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1510
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1511 (defun speedbar-next (arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1512 "Move to the next ARGth line in a speedbar buffer."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1513 (interactive "p")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1514 (forward-line (or arg 1))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1515 (speedbar-item-info)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1516 (speedbar-position-cursor-on-line))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1517
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1518 (defun speedbar-prev (arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1519 "Move to the previous ARGth line in a speedbar buffer."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1520 (interactive "p")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1521 (speedbar-next (if arg (- arg) -1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1522
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1523 (defun speedbar-restricted-move (arg)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1524 "Move to the next ARGth line in a speedbar buffer at the same depth.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1525 This means that movement is restricted to a subnode, and that siblings
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1526 of intermediate nodes are skipped."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1527 (if (not (numberp arg)) (signal 'wrong-type-argument (list arg 'numberp)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1528 ;; First find the extent for which we are allowed to move.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1529 (let ((depth (save-excursion (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1530 (if (looking-at "[0-9]+:")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1531 (string-to-int (match-string 0))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1532 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1533 (crement (if (< arg 0) 1 -1)) ; decrement or increment
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1534 (lastmatch (point)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1535 (while (/= arg 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1536 (forward-line (- crement))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1537 (let ((subdepth (save-excursion (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1538 (if (looking-at "[0-9]+:")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1539 (string-to-int (match-string 0))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1540 0))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1541 (cond ((or (< subdepth depth)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1542 (progn (end-of-line) (eobp))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1543 (progn (beginning-of-line) (bobp)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1544 ;; We have reached the end of this block.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1545 (goto-char lastmatch)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1546 (setq arg 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1547 (error "End of sub-list"))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1548 ((= subdepth depth)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1549 (setq lastmatch (point)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1550 arg (+ arg crement))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1551 (speedbar-position-cursor-on-line)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1552
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1553 (defun speedbar-restricted-next (arg)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1554 "Move to the next ARGth line in a speedbar buffer at the same depth.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1555 This means that movement is restricted to a subnode, and that siblings
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1556 of intermediate nodes are skipped."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1557 (interactive "p")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1558 (speedbar-restricted-move (or arg 1))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1559 (speedbar-item-info))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1560
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1561
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1562 (defun speedbar-restricted-prev (arg)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1563 "Move to the previous ARGth line in a speedbar buffer at the same depth.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1564 This means that movement is restricted to a subnode, and that siblings
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1565 of intermediate nodes are skipped."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1566 (interactive "p")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1567 (speedbar-restricted-move (if arg (- arg) -1))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1568 (speedbar-item-info))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1569
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1570 (defun speedbar-navigate-list (arg)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1571 "Move across ARG groups of similarly typed items in speedbar.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1572 Stop on the first line of the next type of item, or on the last or first item
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1573 if we reach a buffer boundary."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1574 (interactive "p")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1575 (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1576 (if (looking-at "[0-9]+: *[[<{][-+?][]>}] ")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1577 (let ((str (regexp-quote (match-string 0))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1578 (while (looking-at str)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1579 (speedbar-restricted-move arg)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1580 (beginning-of-line))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1581 (speedbar-position-cursor-on-line))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1582
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1583 (defun speedbar-forward-list ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1584 "Move forward over the current list.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1585 A LIST in speedbar is a group of similarly typed items, such as directories,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1586 files, or the directory button."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1587 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1588 (speedbar-navigate-list 1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1589 (speedbar-item-info))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1590
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1591 (defun speedbar-backward-list ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1592 "Move backward over the current list.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1593 A LIST in speedbar is a group of similarly typed items, such as directories,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1594 files, or the directory button."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1595 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1596 (speedbar-navigate-list -1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1597 (speedbar-item-info))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1598
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1599 (defun speedbar-scroll-up (&optional arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1600 "Page down one screen-full of the speedbar, or ARG lines."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1601 (interactive "P")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1602 (scroll-up arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1603 (speedbar-position-cursor-on-line))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1604
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1605 (defun speedbar-scroll-down (&optional arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1606 "Page up one screen-full of the speedbar, or ARG lines."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1607 (interactive "P")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1608 (scroll-down arg)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1609 (speedbar-position-cursor-on-line))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1610
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1611 (defun speedbar-up-directory ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1612 "Keyboard accelerator for moving the default directory up one.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1613 Assumes that the current buffer is the speedbar buffer"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1614 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1615 (setq default-directory (expand-file-name (concat default-directory "../")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1616 (speedbar-update-contents))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1617
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1618 ;;; Speedbar file activity (aka creeping featurism)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1619 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1620 (defun speedbar-refresh ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1621 "Refresh the current speedbar display, disposing of any cached data."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1622 (interactive)
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1623 (let ((dl speedbar-shown-directories)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1624 (dm (and (boundp 'deactivate-mark) deactivate-mark)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1625 (while dl
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1626 (adelete 'speedbar-directory-contents-alist (car dl))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1627 (setq dl (cdr dl)))
22906
adfc04c48002 Updated refresh messages to clear themselves.
Eric M. Ludlam <zappo@gnu.org>
parents: 22893
diff changeset
1628 (if (<= 1 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1629 (speedbar-message "Refreshing speedbar..."))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1630 (speedbar-update-contents)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1631 (speedbar-stealthy-updates)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1632 ;; Reset the timer in case it got really hosed for some reason...
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1633 (speedbar-set-timer speedbar-update-speed)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1634 (if (<= 1 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1635 (speedbar-message "Refreshing speedbar...done"))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
1636 (if (boundp 'deactivate-mark) (setq deactivate-mark dm))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1637
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1638 (defun speedbar-item-load ()
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1639 "Load the item under the cursor or mouse if it is a Lisp file."
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1640 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1641 (let ((f (speedbar-line-file)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1642 (if (and (file-exists-p f) (string-match "\\.el\\'" f))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1643 (if (and (file-exists-p (concat f "c"))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1644 (speedbar-y-or-n-p (format "Load %sc? " f)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1645 ;; If the compiled version exists, load that instead...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1646 (load-file (concat f "c"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1647 (load-file f))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1648 (error "Not a loadable file"))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1649
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1650 (defun speedbar-item-byte-compile ()
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1651 "Byte compile the item under the cursor or mouse if it is a Lisp file."
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1652 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1653 (let ((f (speedbar-line-file))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1654 (sf (selected-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1655 (if (and (file-exists-p f) (string-match "\\.el\\'" f))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1656 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1657 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1658 (byte-compile-file f nil)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1659 (select-frame sf)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1660 (speedbar-reset-scanners)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1661 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1662
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1663 (defun speedbar-mouse-item-info (event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1664 "Provide information about what the user clicked on.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1665 This should be bound to a mouse EVENT."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1666 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1667 (mouse-set-point event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1668 (speedbar-item-info))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1669
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1670 (defun speedbar-generic-item-info ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1671 "Attempt to derive, and then display information about thils line item.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1672 File style information is displayed with `speedbar-item-info'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1673 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1674 (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1675 ;; Skip invisible number info.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1676 (if (looking-at "\\([0-9]+\\):") (goto-char (match-end 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1677 ;; Skip items in "folder" type text characters.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1678 (if (looking-at "\\s-*[[<({].[]>)}] ") (goto-char (match-end 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1679 ;; Get the text
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1680 (speedbar-message "Text: %s" (buffer-substring-no-properties
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1681 (point) (progn (end-of-line) (point))))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1682
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1683 (defun speedbar-item-info ()
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1684 "Display info in the mini-buffer about the button the mouse is over.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1685 This function can be replaced in `speedbar-mode-functions-list' as
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1686 `speedbar-item-info'"
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1687 (interactive)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1688 (let (message-log-max)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1689 (funcall (or (speedbar-fetch-replacement-function 'speedbar-item-info)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1690 'speedbar-generic-item-info))))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1691
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1692 (defun speedbar-item-info-file-helper (&optional filename)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1693 "Display info about a file that is on the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1694 nil if not applicable. If FILENAME, then use that instead of reading
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1695 it from the speedbar buffer."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1696 (let* ((item (or filename (speedbar-line-file)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1697 (attr (if item (file-attributes item) nil)))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1698 (if (and item attr) (speedbar-message "%s %-6d %s" (nth 8 attr)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1699 (nth 7 attr) item)
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1700 nil)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1701
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1702 (defun speedbar-item-info-tag-helper ()
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1703 "Display info about a tag that is on the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1704 nil if not applicable."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1705 (save-excursion
24321
0e5b7bb19ddc (speedbar-item-info-tag-helper): Scan the whole line.
Richard M. Stallman <rms@gnu.org>
parents: 24232
diff changeset
1706 (beginning-of-line)
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1707 (if (re-search-forward " > \\([^ ]+\\)$"
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1708 (save-excursion(end-of-line)(point)) t)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1709 (let ((tag (match-string 1))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1710 (attr (get-text-property (match-beginning 1)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1711 'speedbar-token))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1712 (item nil))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1713 (looking-at "\\([0-9]+\\):")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1714 (setq item (speedbar-line-path (string-to-int (match-string 1))))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1715 (speedbar-message "Tag: %s in %s @ %s"
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1716 tag item (if attr
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1717 (if (markerp attr)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1718 (marker-position attr)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1719 attr)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1720 0)))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1721 (if (re-search-forward "{[+-]} \\([^\n]+\\)$"
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1722 (save-excursion(end-of-line)(point)) t)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1723 (speedbar-message "Group of tags \"%s\"" (match-string 1))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1724 nil))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1725
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1726 (defun speedbar-files-item-info ()
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1727 "Display info in the mini-buffer about the button the mouse is over."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1728 (if (not speedbar-shown-directories)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1729 (speedbar-generic-item-info)
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1730 (or (speedbar-item-info-file-helper)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1731 (speedbar-item-info-tag-helper)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
1732 (speedbar-generic-item-info))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1733
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1734 (defun speedbar-item-copy ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1735 "Copy the item under the cursor.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1736 Files can be copied to new names or places."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1737 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1738 (let ((f (speedbar-line-file)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1739 (if (not f) (error "Not a file"))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1740 (if (file-directory-p f)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1741 (error "Cannot copy directory")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1742 (let* ((rt (read-file-name (format "Copy %s to: "
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1743 (file-name-nondirectory f))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1744 (file-name-directory f)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1745 (refresh (member (expand-file-name (file-name-directory rt))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1746 speedbar-shown-directories)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1747 ;; Create the right file name part
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1748 (if (file-directory-p rt)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1749 (setq rt
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1750 (concat (expand-file-name rt)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1751 (if (string-match "/$" rt) "" "/")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1752 (file-name-nondirectory f))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1753 (if (or (not (file-exists-p rt))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1754 (speedbar-y-or-n-p (format "Overwrite %s with %s? " rt f)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1755 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1756 (copy-file f rt t t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1757 ;; refresh display if the new place is currently displayed.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1758 (if refresh
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1759 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1760 (speedbar-refresh)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1761 (if (not (speedbar-goto-this-file rt))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1762 (speedbar-goto-this-file f))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1763 ))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1764
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1765 (defun speedbar-item-rename ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1766 "Rename the item under the cursor or mouse.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1767 Files can be renamed to new names or moved to new directories."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1768 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1769 (let ((f (speedbar-line-file)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1770 (if f
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1771 (let* ((rt (read-file-name (format "Rename %s to: "
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1772 (file-name-nondirectory f))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1773 (file-name-directory f)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1774 (refresh (member (expand-file-name (file-name-directory rt))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1775 speedbar-shown-directories)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1776 ;; Create the right file name part
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1777 (if (file-directory-p rt)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1778 (setq rt
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1779 (concat (expand-file-name rt)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1780 (if (string-match "/\\'" rt) "" "/")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1781 (file-name-nondirectory f))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1782 (if (or (not (file-exists-p rt))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1783 (speedbar-y-or-n-p (format "Overwrite %s with %s? " rt f)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1784 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1785 (rename-file f rt t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1786 ;; refresh display if the new place is currently displayed.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1787 (if refresh
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1788 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1789 (speedbar-refresh)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1790 (speedbar-goto-this-file rt)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1791 )))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1792 (error "Not a file"))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1793
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1794 (defun speedbar-item-delete ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1795 "Delete the item under the cursor. Files are removed from disk."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1796 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1797 (let ((f (speedbar-line-file)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1798 (if (not f) (error "Not a file"))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1799 (if (speedbar-y-or-n-p (format "Delete %s? " f))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1800 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1801 (if (file-directory-p f)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1802 (delete-directory f)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1803 (delete-file f))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1804 (speedbar-message "Okie dokie..")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1805 (let ((p (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1806 (speedbar-refresh)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1807 (goto-char p))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1808 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1809 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1810
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1811 (defun speedbar-item-object-delete ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1812 "Delete the object associated from the item under the cursor.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1813 The file is removed from disk. The object is determined from the
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1814 variable `speedbar-obj-alist'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1815 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1816 (let* ((f (speedbar-line-file))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1817 (obj nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1818 (oa speedbar-obj-alist))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1819 (if (not f) (error "Not a file"))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1820 (while (and oa (not (string-match (car (car oa)) f)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1821 (setq oa (cdr oa)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1822 (setq obj (concat (file-name-sans-extension f) (cdr (car oa))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1823 (if (and oa (file-exists-p obj)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
1824 (speedbar-y-or-n-p (format "Delete %s? " obj)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1825 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1826 (delete-file obj)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1827 (speedbar-reset-scanners)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1828
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1829 (defun speedbar-enable-update ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1830 "Enable automatic updating in speedbar via timers."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1831 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1832 (setq speedbar-update-flag t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1833 (speedbar-set-mode-line-format)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1834 (speedbar-set-timer speedbar-update-speed))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1835
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1836 (defun speedbar-disable-update ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1837 "Disable automatic updating and stop consuming resources."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1838 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1839 (setq speedbar-update-flag nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1840 (speedbar-set-mode-line-format)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1841 (speedbar-set-timer nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1842
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1843 (defun speedbar-toggle-updates ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1844 "Toggle automatic update for the speedbar frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1845 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1846 (if speedbar-update-flag
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1847 (speedbar-disable-update)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1848 (speedbar-enable-update)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1849
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1850 (defun speedbar-toggle-sorting ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1851 "Toggle automatic update for the speedbar frame."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1852 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1853 (setq speedbar-sort-tags (not speedbar-sort-tags)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1854
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1855 (defun speedbar-toggle-show-all-files ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1856 "Toggle display of files speedbar can not tag."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1857 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1858 (setq speedbar-show-unknown-files (not speedbar-show-unknown-files))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1859 (speedbar-refresh))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1860
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1861 ;;; Utility functions
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1862 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1863 (defun speedbar-set-timer (timeout)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1864 "Apply a timer with TIMEOUT, or remove a timer if TIMOUT is nil.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1865 TIMEOUT is the number of seconds until the speedbar timer is called
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1866 again. When TIMEOUT is nil, turn off all timeouts.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1867 This function will also enable or disable the `vc-checkin-hook' used
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1868 to track file check ins, and will change the mode line to match
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1869 `speedbar-update-flag'."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1870 (cond
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1871 ;; XEmacs
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1872 (speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1873 (if speedbar-timer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1874 (progn (delete-itimer speedbar-timer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1875 (setq speedbar-timer nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1876 (if timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1877 (if (and speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1878 (or (>= emacs-major-version 20)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1879 (>= emacs-minor-version 15)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1880 (setq speedbar-timer (start-itimer "speedbar"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1881 'speedbar-timer-fn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1882 timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1883 timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1884 t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1885 (setq speedbar-timer (start-itimer "speedbar"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1886 'speedbar-timer-fn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1887 timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1888 nil)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1889 ;; Post 19.31 Emacs
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1890 ((fboundp 'run-with-idle-timer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1891 (if speedbar-timer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1892 (progn (cancel-timer speedbar-timer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1893 (setq speedbar-timer nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1894 (if timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1895 (setq speedbar-timer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1896 (run-with-idle-timer timeout t 'speedbar-timer-fn))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1897 ;; Emacs 19.30 (Thanks twice: ptype@dra.hmg.gb)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1898 ((fboundp 'post-command-idle-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1899 (if timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1900 (add-hook 'post-command-idle-hook 'speedbar-timer-fn)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1901 (remove-hook 'post-command-idle-hook 'speedbar-timer-fn)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1902 ;; Older or other Emacsen with no timers. Set up so that its
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1903 ;; obvious this emacs can't handle the updates
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1904 (t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1905 (setq speedbar-update-flag nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1906 ;; Apply a revert hook that will reset the scanners. We attach to revert
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1907 ;; because most reverts occur during VC state change, and this lets our
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1908 ;; VC scanner fix itself.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1909 (if timeout
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1910 (add-hook 'after-revert-hook 'speedbar-reset-scanners)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1911 (remove-hook 'after-revert-hook 'speedbar-reset-scanners)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1912 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1913 ;; change this if it changed for some reason
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1914 (speedbar-set-mode-line-format))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1915
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1916 (defmacro speedbar-with-writable (&rest forms)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1917 "Allow the buffer to be writable and evaluate FORMS."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1918 (list 'let '((inhibit-read-only t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1919 (cons 'progn forms)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1920 (put 'speedbar-with-writable 'lisp-indent-function 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1921
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1922 (defun speedbar-select-window (buffer)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1923 "Select a window in which BUFFER is shown.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1924 If it is not shown, force it to appear in the default window."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1925 (let ((win (get-buffer-window buffer speedbar-attached-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1926 (if win
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1927 (select-window win)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1928 (set-window-buffer (selected-window) buffer))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1929
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1930 (defun speedbar-insert-button (text face mouse function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1931 &optional token prevline)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1932 "Insert TEXT as the next logical speedbar button.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1933 FACE is the face to put on the button, MOUSE is the highlight face to use.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1934 When the user clicks on TEXT, FUNCTION is called with the TOKEN parameter.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1935 This function assumes that the current buffer is the speedbar buffer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1936 If PREVLINE, then put this button on the previous line.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1937
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1938 This is a convenience function for special mode that create their own
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1939 specialized speedbar displays."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1940 (goto-char (point-max))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1941 (if (/= (current-column) 0) (insert "\n"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1942 (if prevline (progn (delete-char -1) (insert " "))) ;back up if desired...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1943 (let ((start (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1944 (insert text)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1945 (speedbar-make-button start (point) face mouse function token))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1946 (let ((start (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1947 (insert "\n")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1948 (put-text-property start (point) 'face nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1949 (put-text-property start (point) 'mouse-face nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1950
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1951 (defun speedbar-make-button (start end face mouse function &optional token)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1952 "Create a button from START to END, with FACE as the display face.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1953 MOUSE is the mouse face. When this button is clicked on FUNCTION
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1954 will be run with the TOKEN parameter (any Lisp object)"
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1955 (put-text-property start end 'face face)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1956 (put-text-property start end 'mouse-face mouse)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1957 (put-text-property start end 'invisible nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1958 (if function (put-text-property start end 'speedbar-function function))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1959 (if token (put-text-property start end 'speedbar-token token))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1960 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
1961
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1962 ;;; Initial Expansion list management
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1963 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1964 (defun speedbar-initial-expansion-list ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1965 "Return the current default expansion list.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1966 This is based on `speedbar-initial-expansion-list-name' referencing
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1967 `speedbar-initial-expansion-mode-alist'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1968 ;; cdr1 - name, cdr2 - menu
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1969 (cdr (cdr (cdr (assoc speedbar-initial-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1970 speedbar-initial-expansion-mode-alist)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1971
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1972 (defun speedbar-initial-menu ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1973 "Return the current default menu data.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1974 This is based on `speedbar-initial-expansion-list-name' referencing
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1975 `speedbar-initial-expansion-mode-alist'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1976 (symbol-value
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1977 (car (cdr (assoc speedbar-initial-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1978 speedbar-initial-expansion-mode-alist)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1979
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1980 (defun speedbar-initial-keymap ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1981 "Return the current default menu data.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1982 This is based on `speedbar-initial-expansion-list-name' referencing
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1983 `speedbar-initial-expansion-mode-alist'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1984 (symbol-value
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1985 (car (cdr (cdr (assoc speedbar-initial-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1986 speedbar-initial-expansion-mode-alist))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1987
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1988 (defun speedbar-initial-stealthy-functions ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1989 "Return a list of functions to call stealthily.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1990 This is based on `speedbar-initial-expansion-list-name' referencing
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1991 `speedbar-stealthy-function-list'."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1992 (cdr (assoc speedbar-initial-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1993 speedbar-stealthy-function-list)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1994
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1995 (defun speedbar-add-expansion-list (new-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1996 "Add NEW-LIST to the list of expansion lists."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1997 (add-to-list 'speedbar-initial-expansion-mode-alist new-list))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1998
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
1999 (defun speedbar-change-initial-expansion-list (new-default)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2000 "Change speedbar's default expansion list to NEW-DEFAULT."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2001 (interactive
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2002 (list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2003 (completing-read (format "Speedbar Mode (default %s): "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2004 speedbar-previously-used-expansion-list-name)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2005 speedbar-initial-expansion-mode-alist
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2006 nil t "" nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2007 speedbar-previously-used-expansion-list-name)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2008 (setq speedbar-previously-used-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2009 speedbar-initial-expansion-list-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2010 speedbar-initial-expansion-list-name new-default)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2011 (speedbar-refresh)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2012 (speedbar-reconfigure-keymaps))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2013
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2014 (defun speedbar-fetch-replacement-function (function)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2015 "Return a current mode specific replacement for function, or nil.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2016 Scans `speedbar-mode-functions-list' first for the current mode, then
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2017 for FUNCTION."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2018 (cdr (assoc function
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2019 (cdr (assoc speedbar-initial-expansion-list-name
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2020 speedbar-mode-functions-list)))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2021
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2022 (defun speedbar-add-mode-functions-list (new-list)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2023 "Add NEW-LIST to the list of mode functions.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2024 See `speedbar-mode-functions-list' for details."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2025 (add-to-list 'speedbar-mode-functions-list new-list))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
2026
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2027
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2028 ;;; Special speedbar display management
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2029 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2030 (defun speedbar-maybe-add-localized-support (buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2031 "Quick check function called on BUFFERs by the speedbar timer function.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2032 Maintains the value of local variables which control speedbars use
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2033 of the special mode functions."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2034 (or speedbar-special-mode-expansion-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2035 (speedbar-add-localized-speedbar-support buffer)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2036
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2037 (defun speedbar-add-localized-speedbar-support (buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2038 "Add localized speedbar support to BUFFER's mode if it is available."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2039 (interactive "bBuffer: ")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2040 (if (stringp buffer) (setq buffer (get-buffer buffer)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2041 (if (not (buffer-live-p buffer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2042 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2043 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2044 (set-buffer buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2045 (save-match-data
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2046 (let ((ms (symbol-name major-mode)) v)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2047 (if (not (string-match "-mode$" ms))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2048 nil ;; do nothing to broken mode
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2049 (setq ms (substring ms 0 (match-beginning 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2050 (setq v (intern-soft (concat ms "-speedbar-buttons")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2051 (make-local-variable 'speedbar-special-mode-expansion-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2052 (if (not v)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2053 (setq speedbar-special-mode-expansion-list t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2054 ;; If it is autoloaded, we need to load it now so that
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2055 ;; we have access to the varialbe -speedbar-menu-items.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2056 ;; Is this XEmacs safe?
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2057 (let ((sf (symbol-function v)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2058 (if (and (listp sf) (eq (car sf) 'autoload))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2059 (load-library (car (cdr sf)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2060 (setq speedbar-special-mode-expansion-list (list v))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2061 (setq v (intern-soft (concat ms "-speedbar-key-map")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2062 (if (not v)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2063 nil ;; don't add special keymap
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2064 (make-local-variable 'speedbar-special-mode-key-map)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2065 (setq speedbar-special-mode-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2066 (symbol-value v)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2067 (setq v (intern-soft (concat ms "-speedbar-menu-items")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2068 (if (not v)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2069 nil ;; don't add special menus
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2070 (make-local-variable 'speedbar-easymenu-definition-special)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2071 (setq speedbar-easymenu-definition-special
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2072 (symbol-value v)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2073 )))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2074
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2075 (defun speedbar-remove-localized-speedbar-support (buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2076 "Remove any traces that BUFFER supports speedbar in a specialized way."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2077 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2078 (set-buffer buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2079 (kill-local-variable 'speedbar-special-mode-expansion-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2080 (kill-local-variable 'speedbar-special-mode-key-map)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2081 (kill-local-variable 'speedbar-easymenu-definition-special)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2082
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2083 ;;; File button management
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2084 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2085 (defun speedbar-file-lists (directory)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2086 "Create file lists for DIRECTORY.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2087 The car is the list of directories, the cdr is list of files not
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2088 matching ignored headers. Cache any directory files found in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2089 `speedbar-directory-contents-alist' and use that cache before scanning
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2090 the file-system"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2091 (setq directory (expand-file-name directory))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2092 ;; If in powerclick mode, then the directory we are getting
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2093 ;; should be rescanned.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2094 (if speedbar-power-click
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2095 (adelete 'speedbar-directory-contents-alist directory))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2096 ;; find the directory, either in the cache, or build it.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2097 (or (cdr-safe (assoc directory speedbar-directory-contents-alist))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2098 (let ((default-directory directory)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2099 (dir (directory-files directory nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2100 (dirs nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2101 (files nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2102 (while dir
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2103 (if (not
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2104 (or (string-match speedbar-file-unshown-regexp (car dir))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2105 (string-match speedbar-directory-unshown-regexp (car dir))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2106 (if (file-directory-p (car dir))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2107 (setq dirs (cons (car dir) dirs))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2108 (setq files (cons (car dir) files))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2109 (setq dir (cdr dir)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2110 (let ((nl (cons (nreverse dirs) (list (nreverse files)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2111 (aput 'speedbar-directory-contents-alist directory nl)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2112 nl))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2113 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2114
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2115 (defun speedbar-directory-buttons (directory index)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2116 "Insert a single button group at point for DIRECTORY.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2117 Each directory path part is a different button. If part of the path
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2118 matches the user directory ~, then it is replaced with a ~.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2119 INDEX is not used, but is required by the caller."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2120 (let* ((tilde (expand-file-name "~"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2121 (dd (expand-file-name directory))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2122 (junk (string-match (regexp-quote tilde) dd))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2123 (displayme (if junk
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2124 (concat "~" (substring dd (match-end 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2125 dd))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2126 (p (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2127 (if (string-match "^~/?\\'" displayme) (setq displayme (concat tilde "/")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2128 (insert displayme)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2129 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2130 (goto-char p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2131 (while (re-search-forward "\\([^/]+\\)/" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2132 (speedbar-make-button (match-beginning 1) (match-end 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2133 'speedbar-directory-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2134 'speedbar-highlight-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2135 'speedbar-directory-buttons-follow
25432
07df7c764669 (speedbar-directory-buttons): Recognize
Richard M. Stallman <rms@gnu.org>
parents: 24809
diff changeset
2136 (if (and (= (match-beginning 1) p)
07df7c764669 (speedbar-directory-buttons): Recognize
Richard M. Stallman <rms@gnu.org>
parents: 24809
diff changeset
2137 (not (char-equal (char-after (+ p 1)) ?:)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2138 (expand-file-name "~/") ;the tilde
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2139 (buffer-substring-no-properties
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2140 p (match-end 0)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2141 ;; Nuke the beginning of the directory if it's too long...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2142 (cond ((eq speedbar-directory-button-trim-method 'span)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2143 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2144 (let ((ww (or (speedbar-frame-width) 20)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2145 (move-to-column ww nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2146 (while (>= (current-column) ww)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2147 (re-search-backward "/" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2148 (if (<= (current-column) 2)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2149 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2150 (re-search-forward "/" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2151 (if (< (current-column) 4)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2152 (re-search-forward "/" nil t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2153 (forward-char -1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2154 (if (looking-at "/?$")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2155 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2156 (insert "/...\n ")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2157 (move-to-column ww nil)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2158 ((eq speedbar-directory-button-trim-method 'trim)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2159 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2160 (let ((ww (or (speedbar-frame-width) 20))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2161 (tl (current-column)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2162 (if (< ww tl)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2163 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2164 (move-to-column (- tl ww))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2165 (if (re-search-backward "/" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2166 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2167 (delete-region (point-min) (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2168 (insert "$")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2169 )))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2170 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2171 (if (string-match "\\`/[^/]+/\\'" displayme)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2172 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2173 (insert " ")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2174 (let ((p (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2175 (insert "<root>")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2176 (speedbar-make-button p (point)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2177 'speedbar-directory-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2178 'speedbar-highlight-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2179 'speedbar-directory-buttons-follow
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2180 "/"))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2181 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2182 (insert-char ?\n 1 nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2183
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2184 (defun speedbar-make-tag-line (exp-button-type
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2185 exp-button-char exp-button-function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2186 exp-button-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2187 tag-button tag-button-function tag-button-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2188 tag-button-face depth)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2189 "Create a tag line with EXP-BUTTON-TYPE for the small expansion button.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2190 This is the button that expands or contracts a node (if applicable),
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2191 and EXP-BUTTON-CHAR the character in it (+, -, ?, etc). EXP-BUTTON-FUNCTION
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2192 is the function to call if it's clicked on. Button types are
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2193 'bracket, 'angle, 'curly, or nil. EXP-BUTTON-DATA is extra data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2194 attached to the text forming the expansion button.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2195
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2196 Next, TAG-BUTTON is the text of the tag. TAG-BUTTON-FUNCTION is the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2197 function to call if clicked on, and TAG-BUTTON-DATA is the data to
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2198 attach to the text field (such a tag positioning, etc).
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2199 TAG-BUTTON-FACE is a face used for this type of tag.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2200
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2201 Lastly, DEPTH shows the depth of expansion.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2202
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2203 This function assumes that the cursor is in the speedbar window at the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2204 position to insert a new item, and that the new item will end with a CR"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2205 (let ((start (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2206 (end (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2207 (insert (int-to-string depth) ":")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2208 (point))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2209 (put-text-property start end 'invisible t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2210 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2211 (insert-char ? depth nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2212 (put-text-property (- (point) depth) (point) 'invisible nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2213 (let* ((exp-button (cond ((eq exp-button-type 'bracket) "[%c]")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2214 ((eq exp-button-type 'angle) "<%c>")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2215 ((eq exp-button-type 'curly) "{%c}")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2216 (t ">")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2217 (buttxt (format exp-button exp-button-char))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2218 (start (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2219 (end (progn (insert buttxt) (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2220 (bf (if exp-button-type 'speedbar-button-face nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2221 (mf (if exp-button-function 'speedbar-highlight-face nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2222 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2223 (speedbar-make-button start end bf mf exp-button-function exp-button-data)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2224 (if speedbar-hide-button-brackets-flag
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2225 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2226 (put-text-property start (1+ start) 'invisible t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2227 (put-text-property end (1- end) 'invisible t)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2228 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2229 (insert-char ? 1 nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2230 (put-text-property (1- (point)) (point) 'invisible nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2231 (let ((start (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2232 (end (progn (insert tag-button) (point))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2233 (insert-char ?\n 1 nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2234 (put-text-property (1- (point)) (point) 'invisible nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2235 (speedbar-make-button start end tag-button-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2236 (if tag-button-function 'speedbar-highlight-face nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2237 tag-button-function tag-button-data))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2238 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2239
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2240 (defun speedbar-change-expand-button-char (char)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2241 "Change the expansion button character to CHAR for the current line."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2242 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2243 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2244 (if (re-search-forward ":\\s-*.\\([-+?]\\)" (save-excursion (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2245 (point)) t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2246 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2247 (goto-char (match-beginning 1))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2248 (delete-char 1)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2249 (insert-char char 1 t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2250 (put-text-property (point) (1- (point)) 'invisible nil)))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2251
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2252
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2253 ;;; Build button lists
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2254 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2255 (defun speedbar-insert-files-at-point (files level)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2256 "Insert list of FILES starting at point, and indenting all files to LEVEL.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2257 Tag expandable items with a +, otherwise a ?. Don't highlight ? as we
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2258 don't know how to manage them. The input parameter FILES is a cons
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2259 cell of the form ( 'DIRLIST . 'FILELIST )"
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2260 ;; Start inserting all the directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2261 (let ((dirs (car files)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2262 (while dirs
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2263 (speedbar-make-tag-line 'angle ?+ 'speedbar-dired (car dirs)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2264 (car dirs) 'speedbar-dir-follow nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2265 'speedbar-directory-face level)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2266 (setq dirs (cdr dirs))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2267 (let ((lst (car (cdr files)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2268 (case-fold-search t))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2269 (while lst
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2270 (let* ((known (string-match speedbar-file-regexp (car lst)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2271 (expchar (if known ?+ ??))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2272 (fn (if known 'speedbar-tag-file nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2273 (if (or speedbar-show-unknown-files (/= expchar ??))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2274 (speedbar-make-tag-line 'bracket expchar fn (car lst)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2275 (car lst) 'speedbar-find-file nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2276 'speedbar-file-face level)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2277 (setq lst (cdr lst)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2278
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2279 (defun speedbar-default-directory-list (directory index)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2280 "Insert files for DIRECTORY with level INDEX at point."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2281 (speedbar-insert-files-at-point
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2282 (speedbar-file-lists directory) index)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2283 (speedbar-reset-scanners)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2284 (if (= index 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2285 ;; If the shown files variable has extra directories, then
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2286 ;; it is our responsibility to redraw them all
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2287 ;; Luckilly, the nature of inserting items into this list means
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2288 ;; that by reversing it, we can easilly go in the right order
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2289 (let ((sf (cdr (reverse speedbar-shown-directories))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2290 (setq speedbar-shown-directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2291 (list (expand-file-name default-directory)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2292 ;; exand them all as we find them
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2293 (while sf
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2294 (if (speedbar-goto-this-file (car sf))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2295 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2296 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2297 (if (looking-at "[0-9]+:[ ]*<")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2298 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2299 (goto-char (match-end 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2300 (speedbar-do-function-pointer)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2301 (setq sf (cdr sf)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2302 )))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2303
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2304 (defun speedbar-apply-one-tag-hierarchy-method (lst method)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2305 "Adjust the tag hierarchy LST by METHOD."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2306 (cond
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2307 ((eq method 'sort)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2308 (sort (copy-alist lst)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2309 (lambda (a b) (string< (car a) (car b)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2310 ((eq method 'prefix-group)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2311 (let ((newlst nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2312 (sublst nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2313 (work-list nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2314 (junk-list nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2315 (short-group-list nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2316 (short-start-name nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2317 (short-end-name nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2318 (num-shorts-grouped 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2319 (bins (make-vector 256 nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2320 (diff-idx 0))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2321 ;; Break out sub-lists
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2322 (while lst
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2323 (if (listp (cdr-safe (car-safe lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2324 (setq newlst (cons (car lst) newlst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2325 (setq sublst (cons (car lst) sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2326 (setq lst (cdr lst)))
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2327 ;; Reverse newlst because it was made backwards.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2328 ;; Sublist doesn't need reversing because the act
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2329 ;; of binning things will reverse it for us.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2330 (setq newlst (nreverse newlst))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2331 ;; Now, first find out how long our list is. Never let a
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2332 ;; list get-shorter than our minimum.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2333 (if (<= (length sublst) speedbar-tag-split-minimum-length)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2334 (setq work-list (nreverse sublst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2335 (setq diff-idx (length (try-completion "" sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2336 ;; Sort the whole list into bins.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2337 (while sublst
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2338 (let ((e (car sublst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2339 (s (car (car sublst))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2340 (cond ((<= (length s) diff-idx)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2341 ;; 0 storage bin for shorty.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2342 (aset bins 0 (cons e (aref bins 0))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2343 (t
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2344 ;; stuff into a bin based on ascii value at diff
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2345 (aset bins (aref s diff-idx)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2346 (cons e (aref bins (aref s diff-idx)))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2347 (setq sublst (cdr sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2348 ;; Go through all our bins Stick singles into our
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2349 ;; junk-list, everything else as sublsts in work-list.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2350 ;; If two neighboring lists are both small, make a grouped
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2351 ;; group combinding those two sub-lists.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2352 (setq diff-idx 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2353 (while (> 256 diff-idx)
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2354 (let ((l (nreverse ;; Reverse the list since they are stuck in
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2355 ;; backwards.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2356 (aref bins diff-idx))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2357 (if l
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2358 (let ((tmp (cons (try-completion "" l) l)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2359 (if (or (> (length l) speedbar-tag-regroup-maximum-length)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2360 (> (+ (length l) (length short-group-list))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2361 speedbar-tag-split-minimum-length))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2362 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2363 ;; We have reached a longer list, so we
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2364 ;; must finish off a grouped group.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2365 (cond
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2366 ((and short-group-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2367 (= (length short-group-list)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2368 num-shorts-grouped))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2369 ;; All singles? Junk list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2370 (setq junk-list (append short-group-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2371 junk-list)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2372 ((= num-shorts-grouped 1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2373 ;; Only one short group? Just stick it in
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2374 ;; there by itself. Make a group, and find
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2375 ;; a subexpression
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2376 (let ((subexpression (try-completion
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2377 "" short-group-list)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2378 (if (< (length subexpression)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2379 speedbar-tag-group-name-minimum-length)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2380 (setq subexpression
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2381 (concat short-start-name
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2382 " ("
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2383 (substring
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2384 (car (car short-group-list))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2385 (length short-start-name))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2386 ")")))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2387 (setq work-list
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2388 (cons (cons subexpression
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2389 short-group-list)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2390 work-list))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2391 (short-group-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2392 ;; Multiple groups to be named in a special
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2393 ;; way by displaying the range over which we
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2394 ;; have grouped them.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2395 (setq work-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2396 (cons (cons (concat short-start-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2397 " to "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2398 short-end-name)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2399 (nreverse short-group-list))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2400 work-list))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2401 ;; Reset short group list information every time.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2402 (setq short-group-list nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2403 short-start-name nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2404 short-end-name nil
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2405 num-shorts-grouped 0)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2406 ;; Ok, now that we cleaned up the short-group-list,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2407 ;; we can deal with this new list, to decide if it
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2408 ;; should go on one of these sub-lists or not.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2409 (if (< (length l) speedbar-tag-regroup-maximum-length)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2410 (setq short-group-list (append short-group-list l)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2411 num-shorts-grouped (1+ num-shorts-grouped)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2412 short-end-name (car tmp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2413 short-start-name (if short-start-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2414 short-start-name
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2415 (car tmp)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2416 (setq work-list (cons tmp work-list))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2417 (setq diff-idx (1+ diff-idx))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2418 ;; Did we run out of things? Drop our new list onto the end.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2419 (cond
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2420 ((and short-group-list (= (length short-group-list) num-shorts-grouped))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2421 ;; All singles? Junk list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2422 (setq junk-list (append short-group-list junk-list)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2423 ((= num-shorts-grouped 1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2424 ;; Only one short group? Just stick it in
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2425 ;; there by itself.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2426 (setq work-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2427 (cons (cons (try-completion "" short-group-list)
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2428 short-group-list)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2429 work-list)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2430 (short-group-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2431 ;; Multiple groups to be named in a special
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2432 ;; way by displaying the range over which we
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2433 ;; have grouped them.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2434 (setq work-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2435 (cons (cons (concat short-start-name " to " short-end-name)
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2436 short-group-list)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2437 work-list))))
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2438 ;; Reverse the work list nreversed when consing.
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2439 (setq work-list (nreverse work-list))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2440 ;; Now, stick our new list onto the end of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2441 (if work-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2442 (if junk-list
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2443 (append newlst work-list junk-list)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2444 (append newlst work-list))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2445 (append newlst junk-list))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2446 ((eq method 'trim-words)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2447 (let ((newlst nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2448 (sublst nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2449 (trim-prefix nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2450 (trim-chars 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2451 (trimlst nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2452 (while lst
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2453 (if (listp (cdr-safe (car-safe lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2454 (setq newlst (cons (car lst) newlst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2455 (setq sublst (cons (car lst) sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2456 (setq lst (cdr lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2457 ;; Get the prefix to trim by. Make sure that we don't trim
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2458 ;; off silly pieces, only complete understandable words.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2459 (setq trim-prefix (try-completion "" sublst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2460 (if (or (= (length sublst) 1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2461 (not trim-prefix)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2462 (not (string-match "\\(\\w+\\W+\\)+" trim-prefix)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2463 (append (nreverse newlst) (nreverse sublst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2464 (setq trim-prefix (substring trim-prefix (match-beginning 0)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2465 (match-end 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2466 (setq trim-chars (length trim-prefix))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2467 (while sublst
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2468 (setq trimlst (cons
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2469 (cons (substring (car (car sublst)) trim-chars)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2470 (cdr (car sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2471 trimlst)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2472 sublst (cdr sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2473 ;; Put the lists together
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2474 (append (nreverse newlst) trimlst))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2475 ((eq method 'simple-group)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2476 (let ((newlst nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2477 (sublst nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2478 (while lst
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2479 (if (listp (cdr-safe (car-safe lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2480 (setq newlst (cons (car lst) newlst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2481 (setq sublst (cons (car lst) sublst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2482 (setq lst (cdr lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2483 (if (not newlst)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2484 (nreverse sublst)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2485 (setq newlst (cons (cons "Tags" (nreverse sublst)) newlst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2486 (nreverse newlst))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2487 (t lst)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2488
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2489 (defun speedbar-create-tag-hierarchy (lst)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2490 "Adjust the tag hierarchy in LST, and return it.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2491 This uses `speedbar-tag-hierarchy-method' to determine how to adjust
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2492 the list. See it's value for details."
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2493 (let* ((f (save-excursion
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2494 (forward-line -1)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2495 (speedbar-line-path)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2496 (methods (if (get-file-buffer f)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2497 (save-excursion (set-buffer (get-file-buffer f))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2498 speedbar-tag-hierarchy-method)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2499 speedbar-tag-hierarchy-method)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2500 (while methods
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2501 (setq lst (speedbar-apply-one-tag-hierarchy-method lst (car methods))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2502 methods (cdr methods)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2503 lst))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2504
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2505 (defun speedbar-insert-generic-list (level lst expand-fun find-fun)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2506 "At LEVEL, insert a generic multi-level alist LST.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2507 Associations with lists get {+} tags (to expand into more nodes) and
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2508 those with positions just get a > as the indicator. {+} buttons will
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2509 have the function EXPAND-FUN and the token is the CDR list. The token
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2510 name will have the function FIND-FUN and not token."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2511 ;; Remove imenu rescan button
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2512 (if (string= (car (car lst)) "*Rescan*")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2513 (setq lst (cdr lst)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2514 ;; Adjust the list.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2515 (setq lst (speedbar-create-tag-hierarchy lst))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2516 ;; insert the parts
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2517 (while lst
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2518 (cond ((null (car-safe lst)) nil) ;this would be a separator
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2519 ((or (numberp (cdr-safe (car-safe lst)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2520 (markerp (cdr-safe (car-safe lst))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2521 (speedbar-make-tag-line nil nil nil nil ;no expand button data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2522 (car (car lst)) ;button name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2523 find-fun ;function
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2524 (cdr (car lst)) ;token is position
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2525 'speedbar-tag-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2526 (1+ level)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2527 ((listp (cdr-safe (car-safe lst)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2528 (speedbar-make-tag-line 'curly ?+ expand-fun (cdr (car lst))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2529 (car (car lst)) ;button name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2530 nil nil 'speedbar-tag-face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2531 (1+ level)))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2532 (t (speedbar-message "Ooops!")))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2533 (setq lst (cdr lst))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2534
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2535 ;;; Timed functions
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2536 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2537 (defun speedbar-update-contents ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2538 "Generically update the contents of the speedbar buffer."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2539 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2540 ;; Set the current special buffer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2541 (setq speedbar-desired-buffer nil)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2542 ;; Check for special modes
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2543 (speedbar-maybe-add-localized-support (current-buffer))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2544 ;; Choose the correct method of doodling.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2545 (if (and speedbar-mode-specific-contents-flag
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2546 (listp speedbar-special-mode-expansion-list)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2547 speedbar-special-mode-expansion-list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2548 (local-variable-p
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2549 'speedbar-special-mode-expansion-list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2550 (current-buffer)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2551 ;;(eq (get major-mode 'mode-class 'special)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2552 (speedbar-update-special-contents)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2553 (speedbar-update-directory-contents)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2554
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2555 (defun speedbar-update-directory-contents ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2556 "Update the contents of the speedbar buffer based on the current directory."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2557 (let ((cbd (expand-file-name default-directory))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2558 cbd-parent
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2559 (funclst (speedbar-initial-expansion-list))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2560 (cache speedbar-full-text-cache)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2561 ;; disable stealth during update
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2562 (speedbar-stealthy-function-list nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2563 (use-cache nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2564 (expand-local nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2565 ;; Because there is a bug I can't find just yet
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2566 (inhibit-quit nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2567 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2568 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2569 ;; If we are updating contents to where we are, then this is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2570 ;; really a request to update existing contents, so we must be
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2571 ;; careful with our text cache!
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2572 (if (member cbd speedbar-shown-directories)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2573 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2574 (setq cache nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2575 ;; If the current directory is not the last element in the dir
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2576 ;; list, then we ALSO need to zap the list of expanded directories
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2577 (if (/= (length (member cbd speedbar-shown-directories)) 1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2578 (setq speedbar-shown-directories (list cbd))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2579
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2580 ;; Build cbd-parent, and see if THAT is in the current shown
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2581 ;; directories. First, go through pains to get the parent directory
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2582 (if (and speedbar-smart-directory-expand-flag
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2583 (save-match-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2584 (setq cbd-parent cbd)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2585 (if (string-match "/$" cbd-parent)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2586 (setq cbd-parent (substring cbd-parent 0
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2587 (match-beginning 0))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2588 (setq cbd-parent (file-name-directory cbd-parent)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2589 (member cbd-parent speedbar-shown-directories))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2590 (setq expand-local t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2591
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2592 ;; If this directory is NOT in the current list of available
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2593 ;; paths, then use the cache, and set the cache to our new
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2594 ;; value. Make sure to unhighlight the current file, or if we
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2595 ;; come back to this directory, it might be a different file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2596 ;; and then we get a mess!
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2597 (if (> (point-max) 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2598 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2599 (speedbar-clear-current-file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2600 (setq speedbar-full-text-cache
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2601 (cons speedbar-shown-directories (buffer-string)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2602
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2603 ;; Check if our new directory is in the list of directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2604 ;; shown in the text-cache
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2605 (if (member cbd (car cache))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2606 (setq speedbar-shown-directories (car cache)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2607 use-cache t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2608 ;; default the shown directories to this list...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2609 (setq speedbar-shown-directories (list cbd)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2610 ))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2611 (if (not expand-local) (setq speedbar-last-selected-file nil))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2612 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2613 (if (and expand-local
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2614 ;; Find this directory as a speedbar node.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2615 (speedbar-path-line cbd))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2616 ;; Open it.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2617 (speedbar-expand-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2618 (erase-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2619 (cond (use-cache
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2620 (setq default-directory
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2621 (nth (1- (length speedbar-shown-directories))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2622 speedbar-shown-directories))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2623 (insert (cdr cache)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2624 (t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2625 (while funclst
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2626 (setq default-directory cbd)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2627 (funcall (car funclst) cbd 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2628 (setq funclst (cdr funclst))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2629 (goto-char (point-min)))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2630 (speedbar-reconfigure-keymaps))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2631
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2632 (defun speedbar-update-special-contents ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2633 "Used the mode-specific variable to fill in the speedbar buffer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2634 This should only be used by modes classified as special."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2635 (let ((funclst speedbar-special-mode-expansion-list)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2636 (specialbuff (current-buffer)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2637 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2638 (setq speedbar-desired-buffer specialbuff)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2639 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2640 ;; If we are leaving a directory, cache it.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2641 (if (not speedbar-shown-directories)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2642 ;; Do nothing
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2643 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2644 ;; Clean up directory maintenance stuff
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2645 (speedbar-clear-current-file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2646 (setq speedbar-full-text-cache
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2647 (cons speedbar-shown-directories (buffer-string))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2648 speedbar-shown-directories nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2649 ;; Now fill in the buffer with our newly found specialized list.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2650 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2651 (while funclst
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2652 ;; We do not erase the buffer because these functions may
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2653 ;; decide NOT to update themselves.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2654 (funcall (car funclst) specialbuff)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2655 (setq funclst (cdr funclst))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2656 (goto-char (point-min))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2657 (speedbar-reconfigure-keymaps))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2658
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2659 (defun speedbar-timer-fn ()
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2660 "Run whenever Emacs is idle to update the speedbar item."
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2661 (if (not (and (frame-live-p speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2662 (frame-live-p speedbar-attached-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2663 (speedbar-set-timer nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2664 ;; Save all the match data so that we don't mess up executing fns
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2665 (save-match-data
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2666 ;; Only do stuff if the frame is visible, not an icon, and if
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2667 ;; it is currently flagged to do something.
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2668 (if (and speedbar-update-flag
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2669 (frame-visible-p speedbar-frame)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2670 (not (eq (frame-visible-p speedbar-frame) 'icon)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2671 (let ((af (selected-frame)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2672 (save-window-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2673 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2674 ;; make sure we at least choose a window to
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2675 ;; get a good directory from
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2676 (if (window-minibuffer-p (selected-window))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2677 nil
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2678 ;; Check for special modes
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2679 (speedbar-maybe-add-localized-support (current-buffer))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2680 ;; Update for special mode all the time!
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2681 (if (and speedbar-mode-specific-contents-flag
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2682 (listp speedbar-special-mode-expansion-list)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2683 speedbar-special-mode-expansion-list
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2684 (local-variable-p
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2685 'speedbar-special-mode-expansion-list
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2686 (current-buffer)))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2687 ;;(eq (get major-mode 'mode-class 'special)))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2688 (progn
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2689 (if (<= 2 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2690 (speedbar-message
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2691 "Updating speedbar to special mode: %s..."
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2692 major-mode))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2693 (speedbar-update-special-contents)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2694 (if (<= 2 speedbar-verbosity-level)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2695 (progn
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2696 (speedbar-message
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2697 "Updating speedbar to special mode: %s...done"
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2698 major-mode)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2699 (speedbar-message nil))))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2700 ;; Update all the contents if directories change!
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2701 (if (or (member (expand-file-name default-directory)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2702 speedbar-shown-directories)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2703 (and speedbar-ignored-path-regexp
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2704 (string-match
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2705 speedbar-ignored-path-regexp
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2706 (expand-file-name default-directory)))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2707 (member major-mode speedbar-ignored-modes)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2708 (eq af speedbar-frame)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2709 (not (buffer-file-name)))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2710 nil
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2711 (if (<= 1 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2712 (speedbar-message "Updating speedbar to: %s..."
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2713 default-directory))
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2714 (speedbar-update-directory-contents)
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2715 (if (<= 1 speedbar-verbosity-level)
22906
adfc04c48002 Updated refresh messages to clear themselves.
Eric M. Ludlam <zappo@gnu.org>
parents: 22893
diff changeset
2716 (progn
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2717 (speedbar-message "Updating speedbar to: %s...done"
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2718 default-directory)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2719 (speedbar-message nil)))))
23073
a0e975baf1e1 (speedbar-timer-fn): Disable updating if the frame
Eric M. Ludlam <zappo@gnu.org>
parents: 23015
diff changeset
2720 (select-frame af)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2721 ;; Now run stealthy updates of time-consuming items
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2722 (speedbar-stealthy-updates)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2723 ;; Now run the mouse tracking system
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2724 (speedbar-show-info-under-mouse)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2725 (run-hooks 'speedbar-timer-hook))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2726
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2727
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2728 ;;; Stealthy activities
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2729 ;;
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2730 (defvar speedbar-stealthy-update-recurse nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2731 "Recursion avoidance variable for stealthy update.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2732
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2733 (defun speedbar-stealthy-updates ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2734 "For a given speedbar, run all items in the stealthy function list.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2735 Each item returns t if it completes successfully, or nil if
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2736 interrupted by the user."
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2737 (if (not speedbar-stealthy-update-recurse)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2738 (let ((l (speedbar-initial-stealthy-functions))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2739 (speedbar-stealthy-update-recurse t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2740 (unwind-protect
23085
46deaf6e62a9 (speedbar-stealthy-updates): Do all updates w/ the the buffer writable.
Eric M. Ludlam <zappo@gnu.org>
parents: 23084
diff changeset
2741 (speedbar-with-writable
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2742 (while (and l (funcall (car l)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2743 ;;(sit-for 0)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2744 (setq l (cdr l))))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2745 ;;(speedbar-message "Exit with %S" (car l))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2746 ))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2747
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2748 (defun speedbar-reset-scanners ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2749 "Reset any variables used by functions in the stealthy list as state.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2750 If new functions are added, their state needs to be updated here."
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2751 (setq speedbar-vc-to-do-point t
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2752 speedbar-obj-to-do-point t)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2753 (run-hooks 'speedbar-scanner-reset-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2754 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2755
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2756 (defun speedbar-find-selected-file (file)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2757 "Goto the line where FILE is."
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2758 (goto-char (point-min))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2759 (let ((m nil))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2760 (while (and (setq m (re-search-forward
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2761 (concat " \\(" (file-name-nondirectory file)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2762 "\\)\\(" speedbar-indicator-regex "\\)?\n")
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2763 nil t))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2764 (not (string= file
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2765 (concat
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2766 (speedbar-line-path
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2767 (save-excursion
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2768 (goto-char (match-beginning 0))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2769 (beginning-of-line)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2770 (save-match-data
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2771 (looking-at "[0-9]+:")
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2772 (string-to-number (match-string 0)))))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2773 (match-string 1))))))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2774 (if m
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2775 (progn
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2776 (goto-char (match-beginning 1))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2777 (match-string 1)))))
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2778
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2779 (defun speedbar-clear-current-file ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2780 "Locate the file thought to be current, and remove its highlighting."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2781 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2782 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2783 (if speedbar-last-selected-file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2784 (speedbar-with-writable
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2785 (if (speedbar-find-selected-file speedbar-last-selected-file)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2786 (put-text-property (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2787 (match-end 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2788 'face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2789 'speedbar-file-face))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2790
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2791 (defun speedbar-update-current-file ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2792 "Find the current file, and update our visuals to indicate its name.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2793 This is specific to file names. If the file name doesn't show up, but
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2794 it should be in the list, then the directory cache needs to be
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2795 updated."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2796 (let* ((lastf (selected-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2797 (newcfd (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2798 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2799 (let ((rf (if (buffer-file-name)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2800 (buffer-file-name)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2801 nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2802 (select-frame lastf)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2803 rf)))
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2804 (newcf (if newcfd newcfd))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2805 (lastb (current-buffer))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2806 (sucf-recursive (boundp 'sucf-recursive))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2807 (case-fold-search t))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2808 (if (and newcf
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2809 ;; check here, that way we won't refresh to newcf until
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2810 ;; its been written, thus saving ourselves some time
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2811 (file-exists-p newcf)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2812 (not (string= newcf speedbar-last-selected-file)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2813 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2814 ;; It is important to select the frame, otherwise the window
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2815 ;; we want the cursor to move in will not be updated by the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2816 ;; search-forward command.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2817 (select-frame speedbar-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2818 ;; Remove the old file...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2819 (speedbar-clear-current-file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2820 ;; now highlight the new one.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2821 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2822 (speedbar-with-writable
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2823 (if (speedbar-find-selected-file newcf)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2824 ;; put the property on it
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2825 (put-text-property (match-beginning 1)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2826 (match-end 1)
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2827 'face
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2828 'speedbar-selected-face)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2829 ;; Oops, it's not in the list. Should it be?
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2830 (if (and (string-match speedbar-file-regexp newcf)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2831 (string= (file-name-directory newcfd)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2832 (expand-file-name default-directory)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2833 ;; yes, it is (we will ignore unknowns for now...)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2834 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2835 (speedbar-refresh)
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
2836 (if (speedbar-find-selected-file newcf)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2837 ;; put the property on it
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2838 (put-text-property (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2839 (match-end 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2840 'face
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2841 'speedbar-selected-face)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2842 ;; if it's not in there now, whatever...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2843 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2844 (setq speedbar-last-selected-file newcf))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2845 (if (not sucf-recursive)
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
2846 (progn
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
2847 (speedbar-center-buffer-smartly)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
2848 (speedbar-position-cursor-on-line)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
2849 ))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2850 (set-buffer lastb)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2851 (select-frame lastf)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2852 )))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2853 ;; return that we are done with this activity.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2854 t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2855
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2856 (defun speedbar-add-indicator (indicator-string &optional replace-this)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2857 "Add INDICATOR-STRING to the end of this speedbar line.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2858 If INDICATOR-STRING is space, and REPLACE-THIS is a character, then
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2859 an the existing indicator is removed. If there is already an
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2860 indicator, then do not add a space."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2861 (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2862 ;; The nature of the beast: Assume we are in "the right place"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2863 (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2864 (skip-chars-backward (concat " " speedbar-vc-indicator
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2865 (car speedbar-obj-indicator)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2866 (cdr speedbar-obj-indicator)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2867 (if (and (not (looking-at speedbar-indicator-regex))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2868 (not (string= indicator-string " ")))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2869 (insert speedbar-indicator-separator))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2870 (speedbar-with-writable
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2871 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2872 (if (and replace-this
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2873 (re-search-forward replace-this (save-excursion (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2874 (point))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2875 t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2876 (delete-region (match-beginning 0) (match-end 0))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2877 (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2878 (if (not (string= " " indicator-string))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2879 (insert indicator-string))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2880
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2881 ;; Load efs/ange-ftp only if compiling to remove byte-compiler warnings.
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2882 ;; Steven L Baur <steve@xemacs.org> said this was important:
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2883 (eval-when-compile (or (featurep 'xemacs)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2884 (condition-case () (require 'efs)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2885 (error (require 'ange-ftp)))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2886
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2887 (defun speedbar-check-vc ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2888 "Scan all files in a directory, and for each see if it's checked out.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2889 See `speedbar-this-file-in-vc' and `speedbar-vc-check-dir-p' for how
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2890 to add more types of version control systems."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2891 ;; Check for to-do to be reset. If reset but no RCS is available
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2892 ;; then set to nil (do nothing) otherwise, start at the beginning
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2893 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2894 (set-buffer speedbar-buffer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2895 (if (and speedbar-vc-do-check (eq speedbar-vc-to-do-point t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2896 (speedbar-vc-check-dir-p default-directory)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2897 (not (or (and (featurep 'ange-ftp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2898 (string-match
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2899 (car (if speedbar-xemacsp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2900 ange-ftp-path-format
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2901 ange-ftp-name-format))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2902 (expand-file-name default-directory)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2903 ;; efs support: Bob Weiner
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2904 (and (featurep 'efs)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2905 (string-match
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2906 (car efs-path-regexp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2907 (expand-file-name default-directory))))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2908 (setq speedbar-vc-to-do-point 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2909 (if (numberp speedbar-vc-to-do-point)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2910 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2911 (goto-char speedbar-vc-to-do-point)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2912 (while (and (not (input-pending-p))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2913 (re-search-forward "^\\([0-9]+\\):\\s-*\\[[+-]\\] "
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2914 nil t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2915 (setq speedbar-vc-to-do-point (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2916 (if (speedbar-check-vc-this-line (match-string 1))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2917 (speedbar-add-indicator speedbar-vc-indicator
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2918 (regexp-quote speedbar-vc-indicator))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2919 (speedbar-add-indicator " "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2920 (regexp-quote speedbar-vc-indicator))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2921 (if (input-pending-p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2922 ;; return that we are incomplete
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2923 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2924 ;; we are done, set to-do to nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2925 (setq speedbar-vc-to-do-point nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2926 ;; and return t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2927 t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2928 t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2929
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2930 (defun speedbar-check-vc-this-line (depth)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2931 "Return t if the file on this line is check of of a version control system.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2932 Parameter DEPTH is a string with the current depth of indentation of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2933 the file being checked."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2934 (let* ((d (string-to-int depth))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2935 (f (speedbar-line-path d))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2936 (fn (buffer-substring-no-properties
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2937 ;; Skip-chars: thanks ptype@dra.hmg.gb
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2938 (point) (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2939 (skip-chars-forward "^ "
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2940 (save-excursion (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2941 (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2942 (point))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2943 (fulln (concat f fn)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2944 (if (<= 2 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
2945 (speedbar-message "Speedbar vc check...%s" fulln))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2946 (and (file-writable-p fulln)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2947 (speedbar-this-file-in-vc f fn))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2948
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2949 (defun speedbar-vc-check-dir-p (path)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2950 "Return t if we should bother checking PATH for version control files.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2951 This can be overloaded to add new types of version control systems."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2952 (or
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2953 ;; Local RCS
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2954 (file-exists-p (concat path "RCS/"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2955 ;; Local SCCS
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2956 (file-exists-p (concat path "SCCS/"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2957 ;; Remote SCCS project
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2958 (let ((proj-dir (getenv "PROJECTDIR")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2959 (if proj-dir
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2960 (file-exists-p (concat proj-dir "/SCCS"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2961 nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2962 ;; User extension
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2963 (run-hook-with-args 'speedbar-vc-path-enable-hook path)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2964 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2965
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2966 (defun speedbar-this-file-in-vc (path name)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2967 "Check to see if the file in PATH with NAME is in a version control system.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2968 You can add new VC systems by overriding this function. You can
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2969 optimize this function by overriding it and only doing those checks
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2970 that will occur on your system."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2971 (or
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2972 ;; RCS file name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2973 (file-exists-p (concat path "RCS/" name ",v"))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
2974 (file-exists-p (concat path "RCS/" name))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2975 ;; Local SCCS file name
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2976 (file-exists-p (concat path "SCCS/s." name))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2977 ;; Remote SCCS file name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2978 (let ((proj-dir (getenv "PROJECTDIR")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2979 (if proj-dir
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
2980 (file-exists-p (concat proj-dir "/SCCS/s." name))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2981 nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2982 ;; User extension
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2983 (run-hook-with-args 'speedbar-vc-in-control-hook path name)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
2984 ))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2985
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2986 ;; Objet File scanning
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2987 (defun speedbar-check-objects ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2988 "Scan all files in a directory, and for each see if there is an object.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2989 See `speedbar-check-obj-this-line' and `speedbar-obj-alist' for how
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2990 to add more object types."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2991 ;; Check for to-do to be reset. If reset but no RCS is available
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2992 ;; then set to nil (do nothing) otherwise, start at the beginning
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2993 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2994 (set-buffer speedbar-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2995 (if (and speedbar-obj-do-check (eq speedbar-obj-to-do-point t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2996 (setq speedbar-obj-to-do-point 0))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2997 (if (numberp speedbar-obj-to-do-point)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2998 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
2999 (goto-char speedbar-obj-to-do-point)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3000 (while (and (not (input-pending-p))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3001 (re-search-forward "^\\([0-9]+\\):\\s-*\\[[+-]\\] "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3002 nil t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3003 (setq speedbar-obj-to-do-point (point))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3004 (let ((ind (speedbar-check-obj-this-line (match-string 1))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3005 (if (not ind) (setq ind " "))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3006 (speedbar-add-indicator ind (concat
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3007 (car speedbar-obj-indicator)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3008 "\\|"
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3009 (cdr speedbar-obj-indicator)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3010 (if (input-pending-p)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3011 ;; return that we are incomplete
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3012 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3013 ;; we are done, set to-do to nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3014 (setq speedbar-obj-to-do-point nil)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3015 ;; and return t
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3016 t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3017 t)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3018
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3019 (defun speedbar-check-obj-this-line (depth)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3020 "Return t if the file on this line has an associated object.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3021 Parameter DEPTH is a string with the current depth of indentation of
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3022 the file being checked."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3023 (let* ((d (string-to-int depth))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3024 (f (speedbar-line-path d))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3025 (fn (buffer-substring-no-properties
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3026 ;; Skip-chars: thanks ptype@dra.hmg.gb
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3027 (point) (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3028 (skip-chars-forward "^ "
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3029 (save-excursion (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3030 (point)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3031 (point))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3032 (fulln (concat f fn)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3033 (if (<= 2 speedbar-verbosity-level)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3034 (speedbar-message "Speedbar obj check...%s" fulln))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3035 (let ((oa speedbar-obj-alist))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3036 (while (and oa (not (string-match (car (car oa)) fulln)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3037 (setq oa (cdr oa)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3038 (if (not (and oa (file-exists-p (concat (file-name-sans-extension fulln)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3039 (cdr (car oa))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3040 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3041 ;; Find out if the object is out of date or not.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3042 (let ((date1 (nth 5 (file-attributes fulln)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3043 (date2 (nth 5 (file-attributes (concat
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3044 (file-name-sans-extension fulln)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3045 (cdr (car oa)))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3046 (if (or (< (car date1) (car date2))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3047 (and (= (car date1) (car date2))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3048 (< (nth 1 date1) (nth 1 date2))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3049 (car speedbar-obj-indicator)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3050 (cdr speedbar-obj-indicator)))))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3051
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3052 ;;; Clicking Activity
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3053 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3054 (defun speedbar-quick-mouse (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3055 "Since mouse events are strange, this will keep the mouse nicely positioned.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3056 This should be bound to mouse event E."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3057 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3058 (mouse-set-point e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3059 (speedbar-position-cursor-on-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3060 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3061
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3062 (defun speedbar-position-cursor-on-line ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3063 "Position the cursor on a line."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3064 (let ((oldpos (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3065 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3066 (if (looking-at "[0-9]+:\\s-*..?.? ")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3067 (goto-char (1- (match-end 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3068 (goto-char oldpos))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3069
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3070 (defun speedbar-power-click (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3071 "Activate any speedbar button as a power click.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3072 This should be bound to mouse event E."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3073 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3074 (let ((speedbar-power-click t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3075 (speedbar-click e)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3076
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3077 (defun speedbar-click (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3078 "Activate any speedbar buttons where the mouse is clicked.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3079 This must be bound to a mouse event. A button is any location of text
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3080 with a mouse face that has a text property called `speedbar-function'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3081 This should be bound to mouse event E."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3082 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3083 (mouse-set-point e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3084 (speedbar-do-function-pointer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3085 (speedbar-quick-mouse e))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3086
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3087 (defun speedbar-double-click (e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3088 "Activate any speedbar buttons where the mouse is clicked.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3089 This must be bound to a mouse event. A button is any location of text
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3090 with a mouse face that has a text property called `speedbar-function'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3091 This should be bound to mouse event E."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3092 (interactive "e")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3093 ;; Emacs only. XEmacs handles this via `mouse-track-click-hook'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3094 (cond ((eq (car e) 'down-mouse-1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3095 (mouse-set-point e))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3096 ((eq (car e) 'mouse-1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3097 (speedbar-quick-mouse e))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3098 ((or (eq (car e) 'double-down-mouse-1)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3099 (eq (car e) 'triple-down-mouse-1))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3100 (mouse-set-point e)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3101 (speedbar-do-function-pointer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3102 (speedbar-quick-mouse e))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3103
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3104 (defun speedbar-do-function-pointer ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3105 "Look under the cursor and examine the text properties.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3106 From this extract the file/tag name, token, indentation level and call
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3107 a function if appropriate"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3108 (let* ((fn (get-text-property (point) 'speedbar-function))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3109 (tok (get-text-property (point) 'speedbar-token))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3110 ;; The 1-,+ is safe because scaning starts AFTER the point
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3111 ;; specified. This lets the search include the character the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3112 ;; cursor is on.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3113 (tp (previous-single-property-change
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3114 (1+ (point)) 'speedbar-function))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3115 (np (next-single-property-change
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3116 (point) 'speedbar-function))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3117 (txt (buffer-substring-no-properties (or tp (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3118 (or np (point-max))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3119 (dent (save-excursion (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3120 (string-to-number
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3121 (if (looking-at "[0-9]+")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3122 (buffer-substring-no-properties
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3123 (match-beginning 0) (match-end 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3124 "0")))))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3125 ;;(speedbar-message "%S:%S:%S:%s" fn tok txt dent)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3126 (and fn (funcall fn txt tok dent)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3127 (speedbar-position-cursor-on-line))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3128
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3129 ;;; Reading info from the speedbar buffer
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3130 ;;
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3131 (defun speedbar-line-text (&optional p)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3132 "Retrieve the text after prefix junk for the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3133 Optional argument P is where to start the search from."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3134 (save-excursion
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3135 (if p (goto-char p))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3136 (beginning-of-line)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3137 (if (looking-at (concat
24232
446e5ef3f423 (speedbar-line-token): Match {...} instead of [...].
Richard M. Stallman <rms@gnu.org>
parents: 24154
diff changeset
3138 "\\([0-9]+\\): *[[<{][-+?][]>}] \\([^ \n]+\\)\\("
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3139 speedbar-indicator-regex "\\)?"))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3140 (match-string 2)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3141 nil)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3142
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3143 (defun speedbar-line-token (&optional p)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3144 "Retrieve the token information after the prefix junk for the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3145 Optional argument P is where to start the search from."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3146 (save-excursion
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3147 (if p (goto-char p))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3148 (beginning-of-line)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3149 (if (looking-at (concat
24232
446e5ef3f423 (speedbar-line-token): Match {...} instead of [...].
Richard M. Stallman <rms@gnu.org>
parents: 24154
diff changeset
3150 "\\([0-9]+\\): *[[<{][-+?][]>}] \\([^ \n]+\\)\\("
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3151 speedbar-indicator-regex "\\)?"))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3152 (progn
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3153 (goto-char (match-beginning 2))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3154 (get-text-property (point) 'speedbar-token))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3155 nil)))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3156
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3157 (defun speedbar-line-file (&optional p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3158 "Retrieve the file or whatever from the line at P point.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3159 The return value is a string representing the file. If it is a
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3160 directory, then it is the directory name."
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3161 (save-match-data
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3162 (let ((f (speedbar-line-text p)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3163 (if f
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3164 (let* ((depth (string-to-int (match-string 1)))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3165 (path (speedbar-line-path depth)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3166 (concat path f))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3167 nil))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3168
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3169 (defun speedbar-goto-this-file (file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3170 "If FILE is displayed, goto this line and return t.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3171 Otherwise do not move and return nil."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3172 (let ((path (substring (file-name-directory (expand-file-name file))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3173 (length (expand-file-name default-directory))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3174 (dest (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3175 (save-match-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3176 (goto-char (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3177 ;; scan all the directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3178 (while (and path (not (eq path t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3179 (if (string-match "^/?\\([^/]+\\)" path)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3180 (let ((pp (match-string 1 path)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3181 (if (save-match-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3182 (re-search-forward (concat "> " (regexp-quote pp) "$")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3183 nil t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3184 (setq path (substring path (match-end 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3185 (setq path nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3186 (setq path t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3187 ;; find the file part
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3188 (if (or (not path) (string= (file-name-nondirectory file) ""))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3189 ;; only had a dir part
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3190 (if path
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3191 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3192 (speedbar-position-cursor-on-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3193 t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3194 (goto-char dest) nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3195 ;; find the file part
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3196 (let ((nd (file-name-nondirectory file)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3197 (if (re-search-forward
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3198 (concat "] \\(" (regexp-quote nd)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3199 "\\)\\(" speedbar-indicator-regex "\\)$")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3200 nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3201 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3202 (speedbar-position-cursor-on-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3203 t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3204 (goto-char dest)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3205 nil))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3206
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3207 (defun speedbar-line-path (&optional depth)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3208 "Retrieve the pathname associated with the current line.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3209 This may require traversing backwards from DEPTH and combining the default
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3210 directory with these items. This function is replaceable in
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3211 `speedbar-mode-functions-list' as `speedbar-line-path'"
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3212 (let ((rf (speedbar-fetch-replacement-function 'speedbar-line-path)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3213 (if rf (funcall rf depth) default-directory)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3214
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3215 (defun speedbar-files-line-path (&optional depth)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3216 "Retrieve the pathname associated with the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3217 This may require traversing backwards from DEPTH and combining the default
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3218 directory with these items."
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3219 (save-excursion
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3220 (save-match-data
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3221 (if (not depth)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3222 (progn
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3223 (beginning-of-line)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3224 (looking-at "^\\([0-9]+\\):")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3225 (setq depth (string-to-int (match-string 1)))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3226 (let ((path nil))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3227 (setq depth (1- depth))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3228 (while (/= depth -1)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3229 (if (not (re-search-backward (format "^%d:" depth) nil t))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3230 (error "Error building path of tag")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3231 (cond ((looking-at "[0-9]+:\\s-*<->\\s-+\\([^\n]+\\)$")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3232 (setq path (concat (buffer-substring-no-properties
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3233 (match-beginning 1) (match-end 1))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3234 "/"
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3235 path)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3236 ((looking-at "[0-9]+:\\s-*[-]\\s-+\\([^\n]+\\)$")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3237 ;; This is the start of our path.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3238 (setq path (buffer-substring-no-properties
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3239 (match-beginning 1) (match-end 1))))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3240 (setq depth (1- depth)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3241 (if (and path
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3242 (string-match (concat speedbar-indicator-regex "$")
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3243 path))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3244 (setq path (substring path 0 (match-beginning 0))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3245 (concat default-directory path)))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3246
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3247 (defun speedbar-path-line (path)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3248 "Position the cursor on the line specified by PATH."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3249 (save-match-data
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3250 (if (string-match "/$" path)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3251 (setq path (substring path 0 (match-beginning 0))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3252 (let ((nomatch t) (depth 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3253 (fname (file-name-nondirectory path))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3254 (pname (file-name-directory path)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3255 (if (not (member pname speedbar-shown-directories))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3256 (error "Internal Error: File %s not shown in speedbar" path))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3257 (goto-char (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3258 (while (and nomatch
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3259 (re-search-forward
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3260 (concat "[]>] \\(" (regexp-quote fname)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3261 "\\)\\(" speedbar-indicator-regex "\\)?$")
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3262 nil t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3263 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3264 (looking-at "\\([0-9]+\\):")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3265 (setq depth (string-to-int (match-string 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3266 nomatch (not (string= pname (speedbar-line-path depth))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3267 (end-of-line))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3268 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3269 (not nomatch))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3270
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3271 (defun speedbar-edit-line ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3272 "Edit whatever tag or file is on the current speedbar line."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3273 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3274 (or (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3275 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3276 ;; If this fails, then it is a non-standard click, and as such,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3277 ;; perfectly allowed.
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
3278 (if (re-search-forward "[]>?}] [^ ]"
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3279 (save-excursion (end-of-line) (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3280 t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3281 (speedbar-do-function-pointer)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3282 nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3283 (speedbar-do-function-pointer)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3284
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3285 (defun speedbar-expand-line ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3286 "Expand the line under the cursor."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3287 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3288 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3289 (re-search-forward ":\\s-*.\\+. " (save-excursion (end-of-line) (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3290 (forward-char -2)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3291 (speedbar-do-function-pointer))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3292
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3293 (defun speedbar-contract-line ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3294 "Contract the line under the cursor."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3295 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3296 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3297 (re-search-forward ":\\s-*.-. " (save-excursion (end-of-line) (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3298 (forward-char -2)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3299 (speedbar-do-function-pointer))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3300
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3301 (if speedbar-xemacsp
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3302 (defalias 'speedbar-mouse-event-p 'button-press-event-p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3303 (defun speedbar-mouse-event-p (event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3304 "Return t if the event is a mouse related event"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3305 ;; And Emacs does it this way
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3306 (if (and (listp event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3307 (member (event-basic-type event)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3308 '(mouse-1 mouse-2 mouse-3)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3309 t
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3310 nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3311
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3312 (defun speedbar-maybee-jump-to-attached-frame ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3313 "Jump to the attached frame ONLY if this was not a mouse event."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3314 (if (or (not (speedbar-mouse-event-p last-input-event))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3315 speedbar-activity-change-focus-flag)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3316 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3317 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3318 (other-frame 0))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3319
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3320 (defun speedbar-find-file (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3321 "Speedbar click handler for filenames.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3322 TEXT, the file will be displayed in the attached frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3323 TOKEN is unused, but required by the click handler. INDENT is the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3324 current indentation level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3325 (let ((cdd (speedbar-line-path indent)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3326 (speedbar-find-file-in-frame (concat cdd text))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3327 (speedbar-stealthy-updates)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3328 (run-hooks 'speedbar-visiting-file-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3329 ;; Reset the timer with a new timeout when cliking a file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3330 ;; in case the user was navigating directories, we can cancel
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3331 ;; that other timer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3332 (speedbar-set-timer speedbar-update-speed))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3333 (speedbar-maybee-jump-to-attached-frame))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3334
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3335 (defun speedbar-dir-follow (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3336 "Speedbar click handler for directory names.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3337 Clicking a directory will cause the speedbar to list files in the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3338 the subdirectory TEXT. TOKEN is an unused requirement. The
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3339 subdirectory chosen will be at INDENT level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3340 (setq default-directory
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3341 (concat (expand-file-name (concat (speedbar-line-path indent) text))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3342 "/"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3343 ;; Because we leave speedbar as the current buffer,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3344 ;; update contents will change directory without
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3345 ;; having to touch the attached frame. Turn off smart expand just
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3346 ;; in case.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3347 (let ((speedbar-smart-directory-expand-flag nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3348 (speedbar-update-contents))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3349 (speedbar-set-timer speedbar-navigating-speed)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3350 (setq speedbar-last-selected-file nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3351 (speedbar-stealthy-updates))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3352
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3353 (defun speedbar-delete-subblock (indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3354 "Delete text from point to indentation level INDENT or greater.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3355 Handles end-of-sublist smartly."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3356 (speedbar-with-writable
23917
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3357 (save-excursion
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3358 (end-of-line) (forward-char 1)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3359 (let ((start (point)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3360 (while (and (looking-at "^\\([0-9]+\\):")
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3361 (> (string-to-int (match-string 1)) indent)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3362 (not (eobp)))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3363 (forward-line 1)
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3364 (beginning-of-line))
4182d24c6d9f (speedbar-frame-parameters) Add : to custom prompt.
Eric M. Ludlam <zappo@gnu.org>
parents: 23372
diff changeset
3365 (delete-region start (point))))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3366
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3367 (defun speedbar-dired (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3368 "Speedbar click handler for directory expand button.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3369 Clicking this button expands or contracts a directory. TEXT is the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3370 button clicked which has either a + or -. TOKEN is the directory to be
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3371 expanded. INDENT is the current indentation level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3372 (cond ((string-match "+" text) ;we have to expand this dir
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3373 (setq speedbar-shown-directories
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3374 (cons (expand-file-name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3375 (concat (speedbar-line-path indent) token "/"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3376 speedbar-shown-directories))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3377 (speedbar-change-expand-button-char ?-)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3378 (speedbar-reset-scanners)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3379 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3380 (end-of-line) (forward-char 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3381 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3382 (speedbar-default-directory-list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3383 (concat (speedbar-line-path indent) token "/")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3384 (1+ indent)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3385 ((string-match "-" text) ;we have to contract this node
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3386 (speedbar-reset-scanners)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3387 (let ((oldl speedbar-shown-directories)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3388 (newl nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3389 (td (expand-file-name
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3390 (concat (speedbar-line-path indent) token))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3391 (while oldl
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3392 (if (not (string-match (concat "^" (regexp-quote td)) (car oldl)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3393 (setq newl (cons (car oldl) newl)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3394 (setq oldl (cdr oldl)))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3395 (setq speedbar-shown-directories (nreverse newl)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3396 (speedbar-change-expand-button-char ?+)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3397 (speedbar-delete-subblock indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3398 )
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3399 (t (error "Ooops... not sure what to do")))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3400 (speedbar-center-buffer-smartly)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3401 (setq speedbar-last-selected-file nil)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3402 (save-excursion (speedbar-stealthy-updates)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3403
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3404 (defun speedbar-directory-buttons-follow (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3405 "Speedbar click handler for default directory buttons.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3406 TEXT is the button clicked on. TOKEN is the directory to follow.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3407 INDENT is the current indentation level and is unused."
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
3408 (if (string-match "^[A-z]:$" token)
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
3409 (setq default-directory (concat token (char-to-string directory-sep-char)))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3410 (setq default-directory token))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3411 ;; Because we leave speedbar as the current buffer,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3412 ;; update contents will change directory without
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3413 ;; having to touch the attached frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3414 (speedbar-update-contents)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3415 (speedbar-set-timer speedbar-navigating-speed))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3416
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3417 (defun speedbar-tag-file (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3418 "The cursor is on a selected line. Expand the tags in the specified file.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3419 The parameter TEXT and TOKEN are required, where TEXT is the button
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3420 clicked, and TOKEN is the file to expand. INDENT is the current
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3421 indentation level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3422 (cond ((string-match "+" text) ;we have to expand this file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3423 (let* ((fn (expand-file-name (concat (speedbar-line-path indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3424 token)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3425 (lst (if speedbar-use-imenu-flag
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3426 (let ((tim (speedbar-fetch-dynamic-imenu fn)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3427 (if (eq tim t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3428 (speedbar-fetch-dynamic-etags fn)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3429 tim))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3430 (speedbar-fetch-dynamic-etags fn))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3431 ;; if no list, then remove expando button
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3432 (if (not lst)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3433 (speedbar-change-expand-button-char ??)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3434 (speedbar-change-expand-button-char ?-)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3435 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3436 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3437 (end-of-line) (forward-char 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3438 (speedbar-insert-generic-list indent
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3439 lst 'speedbar-tag-expand
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3440 'speedbar-tag-find))))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3441 ((string-match "-" text) ;we have to contract this node
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3442 (speedbar-change-expand-button-char ?+)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3443 (speedbar-delete-subblock indent))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3444 (t (error "Ooops... not sure what to do")))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3445 (speedbar-center-buffer-smartly))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3446
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3447 (defun speedbar-tag-find (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3448 "For the tag TEXT in a file TOKEN, goto that position.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3449 INDENT is the current indentation level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3450 (let ((file (speedbar-line-path indent)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3451 (speedbar-find-file-in-frame file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3452 (save-excursion (speedbar-stealthy-updates))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3453 ;; Reset the timer with a new timeout when cliking a file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3454 ;; in case the user was navigating directories, we can cancel
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3455 ;; that other timer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3456 (speedbar-set-timer speedbar-update-speed)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3457 (goto-char token)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3458 (run-hooks 'speedbar-visiting-tag-hook)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3459 ;;(recenter)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3460 (speedbar-maybee-jump-to-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3461 ))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3462
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3463 (defun speedbar-tag-expand (text token indent)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3464 "Expand a tag sublist. Imenu will return sub-lists of specialized tag types.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3465 Etags does not support this feature. TEXT will be the button
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3466 string. TOKEN will be the list, and INDENT is the current indentation
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3467 level."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3468 (cond ((string-match "+" text) ;we have to expand this file
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3469 (speedbar-change-expand-button-char ?-)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3470 (speedbar-with-writable
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3471 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3472 (end-of-line) (forward-char 1)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3473 (speedbar-insert-generic-list indent token 'speedbar-tag-expand
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3474 'speedbar-tag-find))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3475 ((string-match "-" text) ;we have to contract this node
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3476 (speedbar-change-expand-button-char ?+)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3477 (speedbar-delete-subblock indent))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3478 (t (error "Ooops... not sure what to do")))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3479 (speedbar-center-buffer-smartly))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3480
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3481 ;;; Loading files into the attached frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3482 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3483 (defun speedbar-find-file-in-frame (file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3484 "This will load FILE into the speedbar attached frame.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3485 If the file is being displayed in a different frame already, then raise that
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3486 frame instead."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3487 (let* ((buff (find-file-noselect file))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3488 (bwin (get-buffer-window buff 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3489 (if bwin
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3490 (progn
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3491 (select-window bwin)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3492 (raise-frame (window-frame bwin)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3493 (if speedbar-power-click
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3494 (let ((pop-up-frames t)) (select-window (display-buffer buff)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3495 (select-frame speedbar-attached-frame)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3496 (switch-to-buffer buff))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3497 )
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3498
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3499 ;;; Centering Utility
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3500 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3501 (defun speedbar-center-buffer-smartly ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3502 "Recenter a speedbar buffer so the current indentation level is all visible.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3503 This assumes that the cursor is on a file, or tag of a file which the user is
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3504 interested in."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3505 (if (<= (count-lines (point-min) (point-max))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
3506 (1- (window-height (selected-window))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3507 ;; whole buffer fits
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3508 (let ((cp (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3509 (goto-char (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3510 (recenter 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3511 (goto-char cp))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3512 ;; too big
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3513 (let (depth start end exp p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3514 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3515 (beginning-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3516 (setq depth (if (looking-at "[0-9]+")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3517 (string-to-int (buffer-substring-no-properties
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3518 (match-beginning 0) (match-end 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3519 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3520 (setq exp (format "^%d:\\s-*[[{<]\\([?+-]\\)[]>}]" depth)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3521 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3522 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3523 (if (re-search-backward exp nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3524 (setq start (point))
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
3525 (setq start (point-min)))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3526 (save-excursion ;Not sure about this part.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3527 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3528 (setq p (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3529 (while (and (not (re-search-forward exp nil t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3530 (>= depth 0))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3531 (setq depth (1- depth))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3532 (setq exp (format "^%d:\\s-*[[{<]\\([?+-]\\)[]>}]" depth)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3533 (if (/= (point) p)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3534 (setq end (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3535 (setq end (point-max)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3536 ;; Now work out the details of centering
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3537 (let ((nl (count-lines start end))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3538 (cp (point)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3539 (if (> nl (window-height (selected-window)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3540 ;; We can't fit it all, so just center on cursor
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3541 (progn (goto-char start)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3542 (recenter 1))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3543 ;; we can fit everything on the screen, but...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3544 (if (and (pos-visible-in-window-p start (selected-window))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3545 (pos-visible-in-window-p end (selected-window)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3546 ;; we are all set!
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3547 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3548 ;; we need to do something...
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3549 (goto-char start)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3550 (let ((newcent (/ (- (window-height (selected-window)) nl) 2))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3551 (lte (count-lines start (point-max))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3552 (if (and (< (+ newcent lte) (window-height (selected-window)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3553 (> (- (window-height (selected-window)) lte 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3554 newcent))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3555 (setq newcent (- (window-height (selected-window))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3556 lte 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3557 (recenter newcent))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3558 (goto-char cp)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3559
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3560
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3561 ;;; Tag Management -- Imenu
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3562 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3563 (if (not speedbar-use-imenu-flag)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3564
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3565 nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3566
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3567 (eval-when-compile (if (locate-library "imenu") (require 'imenu)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3568
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3569 (defun speedbar-fetch-dynamic-imenu (file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3570 "Load FILE into a buffer, and generate tags using Imenu.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3571 Returns the tag list, or t for an error."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3572 ;; Load this AND compile it in
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3573 (require 'imenu)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3574 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3575 (set-buffer (find-file-noselect file))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3576 (if speedbar-power-click (setq imenu--index-alist nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3577 (condition-case nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3578 (let ((index-alist (imenu--make-index-alist t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3579 (if speedbar-sort-tags
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3580 (sort (copy-alist index-alist)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3581 (lambda (a b) (string< (car a) (car b))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3582 index-alist))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3583 (error t))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3584 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3585
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3586 ;;; Tag Management -- etags (old XEmacs compatibility part)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3587 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3588 (defvar speedbar-fetch-etags-parse-list
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3589 '(;; Note that java has the same parse-group as c
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3590 ("\\.\\([cChH]\\|c\\+\\+\\|cpp\\|cc\\|hh\\|java\\)\\'" .
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3591 speedbar-parse-c-or-c++tag)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3592 ("^\\.emacs$\\|.\\(el\\|l\\|lsp\\)\\'" .
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3593 "def[^i]+\\s-+\\(\\(\\w\\|[-_]\\)+\\)\\s-*\C-?")
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3594 ; ("\\.\\([fF]\\|for\\|FOR\\|77\\|90\\)\\'" .
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3595 ; speedbar-parse-fortran77-tag)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3596 ("\\.tex\\'" . speedbar-parse-tex-string)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3597 ("\\.p\\'" .
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3598 "\\(\\(FUNCTION\\|function\\|PROCEDURE\\|procedure\\)\\s-+\\([a-zA-Z0-9_.:]+\\)\\)\\s-*(?^?")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3599 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3600 "Associations of file extensions and expressions for extracting tags.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3601 To add a new file type, you would want to add a new association to the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3602 list, where the car is the file match, and the cdr is the way to
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3603 extract an element from the tags output. If the output is complex,
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3604 use a function symbol instead of regexp. The function should expect
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3605 to be at the beginning of a line in the etags buffer.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3606
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3607 This variable is ignored if `speedbar-use-imenu-flag' is non-nil.")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3608
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3609 (defvar speedbar-fetch-etags-command "etags"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3610 "*Command used to create an etags file.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3611
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3612 This variable is ignored if `speedbar-use-imenu-flag' is t")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3613
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3614 (defvar speedbar-fetch-etags-arguments '("-D" "-I" "-o" "-")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3615 "*List of arguments to use with `speedbar-fetch-etags-command'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3616 This creates an etags output buffer. Use `speedbar-toggle-etags' to
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3617 modify this list conveniently.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3618
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3619 This variable is ignored if `speedbar-use-imenu-flag' is t")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3620
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3621 (defun speedbar-toggle-etags (flag)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3622 "Toggle FLAG in `speedbar-fetch-etags-arguments'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3623 FLAG then becomes a member of etags command line arguments. If flag
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3624 is \"sort\", then toggle the value of `speedbar-sort-tags'. If its
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3625 value is \"show\" then toggle the value of
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3626 `speedbar-show-unknown-files'.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3627
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3628 This function is a convenience function for XEmacs menu created by
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3629 Farzin Guilak <farzin@protocol.com>"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3630 (interactive)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3631 (cond
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3632 ((equal flag "sort")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3633 (setq speedbar-sort-tags (not speedbar-sort-tags)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3634 ((equal flag "show")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3635 (setq speedbar-show-unknown-files (not speedbar-show-unknown-files)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3636 ((or (equal flag "-C")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3637 (equal flag "-S")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3638 (equal flag "-D"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3639 (if (member flag speedbar-fetch-etags-arguments)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3640 (setq speedbar-fetch-etags-arguments
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3641 (delete flag speedbar-fetch-etags-arguments))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3642 (add-to-list 'speedbar-fetch-etags-arguments flag)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3643 (t nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3644
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3645 (defun speedbar-fetch-dynamic-etags (file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3646 "For FILE, run etags and create a list of symbols extracted.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3647 Each symbol will be associated with its line position in FILE."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3648 (let ((newlist nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3649 (unwind-protect
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3650 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3651 (if (get-buffer "*etags tmp*")
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3652 (kill-buffer "*etags tmp*")) ;kill to clean it up
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3653 (if (<= 1 speedbar-verbosity-level)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3654 (speedbar-message "Fetching etags..."))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3655 (set-buffer (get-buffer-create "*etags tmp*"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3656 (apply 'call-process speedbar-fetch-etags-command nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3657 (current-buffer) nil
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3658 (append speedbar-fetch-etags-arguments (list file)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3659 (goto-char (point-min))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3660 (if (<= 1 speedbar-verbosity-level)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3661 (speedbar-message "Fetching etags..."))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3662 (let ((expr
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3663 (let ((exprlst speedbar-fetch-etags-parse-list)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3664 (ans nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3665 (while (and (not ans) exprlst)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3666 (if (string-match (car (car exprlst)) file)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3667 (setq ans (car exprlst)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3668 (setq exprlst (cdr exprlst)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3669 (cdr ans))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3670 (if expr
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3671 (let (tnl)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3672 (while (not (save-excursion (end-of-line) (eobp)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3673 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3674 (setq tnl (speedbar-extract-one-symbol expr)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3675 (if tnl (setq newlist (cons tnl newlist)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3676 (forward-line 1)))
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3677 (speedbar-message
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3678 "Sorry, no support for a file of that extension"))))
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3679 )
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3680 (if speedbar-sort-tags
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3681 (sort newlist (lambda (a b) (string< (car a) (car b))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3682 (reverse newlist))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3683
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3684 ;; This bit donated by Farzin Guilak <farzin@protocol.com> but I'm not
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3685 ;; sure it's needed with the different sorting method.
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3686 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3687 ;(defun speedbar-clean-etags()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3688 ; "Removes spaces before the ^? character, and removes `#define',
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3689 ;return types, etc. preceding tags. This ensures that the sort operation
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3690 ;works on the tags, not the return types."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3691 ; (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3692 ; (goto-char (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3693 ; (while
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3694 ; (re-search-forward "(?[ \t](?\C-?" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3695 ; (replace-match "\C-?" nil nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3696 ; (goto-char (point-min))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3697 ; (while
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3698 ; (re-search-forward "\\(.*[ \t]+\\)\\([^ \t\n]+.*\C-?\\)" nil t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3699 ; (delete-region (match-beginning 1) (match-end 1)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3700
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3701 (defun speedbar-extract-one-symbol (expr)
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3702 "At point, return nil, or one alist in the form: (SYMBOL . POSITION)
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3703 The line should contain output from etags. Parse the output using the
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3704 regular expression EXPR"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3705 (let* ((sym (if (stringp expr)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3706 (if (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3707 (re-search-forward expr (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3708 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3709 (point)) t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3710 (buffer-substring-no-properties (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3711 (match-end 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3712 (funcall expr)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3713 (pos (let ((j (re-search-forward "[\C-?\C-a]\\([0-9]+\\),\\([0-9]+\\)"
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3714 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3715 (end-of-line)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3716 (point))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3717 t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3718 (if (and j sym)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3719 (1+ (string-to-int (buffer-substring-no-properties
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3720 (match-beginning 2)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3721 (match-end 2))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3722 0))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3723 (if (/= pos 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3724 (cons sym pos)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3725 nil)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3726
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3727 (defun speedbar-parse-c-or-c++tag ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3728 "Parse a c or c++ tag, which tends to be a little complex."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3729 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3730 (let ((bound (save-excursion (end-of-line) (point))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3731 (cond ((re-search-forward "\C-?\\([^\C-a]+\\)\C-a" bound t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3732 (buffer-substring-no-properties (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3733 (match-end 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3734 ((re-search-forward "\\<\\([^ \t]+\\)\\s-+new(" bound t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3735 (buffer-substring-no-properties (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3736 (match-end 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3737 ((re-search-forward "\\<\\([^ \t(]+\\)\\s-*(\C-?" bound t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3738 (buffer-substring-no-properties (match-beginning 1)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3739 (match-end 1)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3740 (t nil))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3741 )))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3742
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3743 (defun speedbar-parse-tex-string ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3744 "Parse a Tex string. Only find data which is relevant."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3745 (save-excursion
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3746 (let ((bound (save-excursion (end-of-line) (point))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3747 (cond ((re-search-forward "\\(\\(sub\\)*section\\|chapter\\|cite\\)\\s-*{[^\C-?}]*}?" bound t)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3748 (buffer-substring-no-properties (match-beginning 0)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3749 (match-end 0)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3750 (t nil)))))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3751
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3752
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3753 ;;; BUFFER DISPLAY mode.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3754 ;;
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3755 (defvar speedbar-buffers-key-map nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3756 "Keymap used when in the buffers display mode.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3757
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3758 (if speedbar-buffers-key-map
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3759 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3760 (setq speedbar-buffers-key-map (speedbar-make-specialized-keymap))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3761
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3762 ;; Basic tree features
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3763 (define-key speedbar-buffers-key-map "e" 'speedbar-edit-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3764 (define-key speedbar-buffers-key-map "\C-m" 'speedbar-edit-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3765 (define-key speedbar-buffers-key-map "+" 'speedbar-expand-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3766 (define-key speedbar-buffers-key-map "-" 'speedbar-contract-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3767
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3768 ;; Buffer specific keybindings
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3769 (define-key speedbar-buffers-key-map "k" 'speedbar-buffer-kill-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3770 (define-key speedbar-buffers-key-map "r" 'speedbar-buffer-revert-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3771
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3772 )
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3773
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3774 (defvar speedbar-buffer-easymenu-definition
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3775 '(["Jump to buffer" speedbar-edit-line t]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3776 ["Expand File Tags" speedbar-expand-line
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3777 (save-excursion (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3778 (looking-at "[0-9]+: *.\\+. "))]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3779 ["Contract File Tags" speedbar-contract-line
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3780 (save-excursion (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3781 (looking-at "[0-9]+: *.-. "))]
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3782 )
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3783 "Menu item elements shown when displaying a buffer list.")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3784
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3785 (defun speedbar-buffer-buttons (directory zero)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3786 "Create speedbar buttons based on the buffers currently loaded.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3787 DIRECTORY is the path to the currently active buffer, and ZERO is 0."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3788 (speedbar-buffer-buttons-engine nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3789
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3790 (defun speedbar-buffer-buttons-temp (directory zero)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3791 "Create speedbar buttons based on the buffers currently loaded.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3792 DIRECTORY is the path to the currently active buffer, and ZERO is 0."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3793 (speedbar-buffer-buttons-engine t))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3794
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3795 (defun speedbar-buffer-buttons-engine (temp)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3796 "Create speedbar buffer buttons.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3797 If TEMP is non-nil, then clicking on a buffer restores the previous display."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3798 (insert "Active Buffers:\n")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3799 (let ((bl (buffer-list)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3800 (while bl
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3801 (if (string-match "^[ *]" (buffer-name (car bl)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3802 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3803 (let* ((known (string-match speedbar-file-regexp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3804 (buffer-name (car bl))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3805 (expchar (if known ?+ ??))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3806 (fn (if known 'speedbar-tag-file nil))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3807 (fname (save-excursion (set-buffer (car bl))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3808 (buffer-file-name))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3809 (speedbar-make-tag-line 'bracket expchar fn fname
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3810 (buffer-name (car bl))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3811 'speedbar-buffer-click temp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3812 'speedbar-file-face 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3813 (setq bl (cdr bl)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3814 (setq bl (buffer-list))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3815 (insert "Scratch Buffers:\n")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3816 (while bl
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3817 (if (not (string-match "^\\*" (buffer-name (car bl))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3818 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3819 (if (eq (car bl) speedbar-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3820 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3821 (speedbar-make-tag-line 'bracket ?? nil nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3822 (buffer-name (car bl))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3823 'speedbar-buffer-click temp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3824 'speedbar-file-face 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3825 (setq bl (cdr bl)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3826 (setq bl (buffer-list))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3827 (insert "Hidden Buffers:\n")
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3828 (while bl
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3829 (if (not (string-match "^ " (buffer-name (car bl))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3830 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3831 (if (eq (car bl) speedbar-buffer)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3832 nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3833 (speedbar-make-tag-line 'bracket ?? nil nil
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3834 (buffer-name (car bl))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3835 'speedbar-buffer-click temp
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3836 'speedbar-file-face 0)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3837 (setq bl (cdr bl)))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3838
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3839 (defun speedbar-buffers-item-info ()
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3840 "Display information about the current buffer on the current line."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3841 (or (speedbar-item-info-tag-helper)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3842 (let* ((item (speedbar-line-text))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3843 (buffer (if item (get-buffer item) nil)))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3844 (and buffer
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3845 (speedbar-message "%s%s %S %d %s"
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3846 (if (buffer-modified-p buffer) "* " "")
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3847 item
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3848 (save-excursion (set-buffer buffer) major-mode)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3849 (save-excursion (set-buffer buffer)
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3850 (buffer-size))
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3851 (or (buffer-file-name buffer) "<No file>"))))))
24154
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3852
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3853 (defun speedbar-buffers-line-path (&optional depth)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3854 "Fetch the full path to the file (buffer) specified on the current line.
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3855 Optional argument DEPTH specifies the current depth of the back search."
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3856 (end-of-line)
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3857 ;; Buffers are always at level 0
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3858 (if (not (re-search-backward "^0:" nil t))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3859 nil
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3860 (let* ((bn (speedbar-line-text))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3861 (buffer (if bn (get-buffer bn))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3862 (if buffer (file-name-directory (buffer-file-name buffer))))))
91c00b394901 (speedbar-item-info-file-helper): Add optional arg
Eric M. Ludlam <zappo@gnu.org>
parents: 23917
diff changeset
3863
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3864 (defun speedbar-buffer-click (text token indent)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3865 "When the users clicks on a buffer-button in speedbar.
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3866 TEXT is the buffer's name, TOKEN and INDENT are unused."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3867 (if speedbar-power-click
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3868 (let ((pop-up-frames t)) (select-window (display-buffer text)))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3869 (select-frame speedbar-attached-frame)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3870 (switch-to-buffer text)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3871 (if token (speedbar-change-initial-expansion-list
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3872 speedbar-previously-used-expansion-list-name))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3873
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3874 (defun speedbar-buffer-kill-buffer ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3875 "Kill the buffer the cursor is on in the speedbar buffer."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3876 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3877 (or (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3878 (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3879 ;; If this fails, then it is a non-standard click, and as such,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3880 ;; perfectly allowed.
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
3881 (if (re-search-forward "[]>?}] [^ ]"
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3882 (save-excursion (end-of-line) (point))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3883 t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3884 (let ((text (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3885 (forward-char -1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3886 (buffer-substring (point) (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3887 (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3888 (point))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3889 (if (and (get-buffer text)
24475
1e20dcb26ff7 Added commentary about stealthy functions.
Karl Heuer <kwzh@gnu.org>
parents: 24321
diff changeset
3890 (speedbar-y-or-n-p (format "Kill buffer %s? " text)))
22893
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
3891 (kill-buffer text))
322179a8fd20 (speedbar-update-current-file): Added call to
Eric M. Ludlam <zappo@gnu.org>
parents: 22735
diff changeset
3892 (speedbar-refresh))))))
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3893
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3894 (defun speedbar-buffer-revert-buffer ()
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3895 "Revert the buffer the cursor is on in the speedbar buffer."
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3896 (interactive)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3897 (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3898 (beginning-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3899 ;; If this fails, then it is a non-standard click, and as such,
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3900 ;; perfectly allowed
22950
606be1490be7 (speedbar-edit-line, speedbar-buffer-kill-buffer,
Eric M. Ludlam <zappo@gnu.org>
parents: 22906
diff changeset
3901 (if (re-search-forward "[]>?}] [^ ]"
22735
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3902 (save-excursion (end-of-line) (point))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3903 t)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3904 (let ((text (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3905 (forward-char -1)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3906 (buffer-substring (point) (save-excursion
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3907 (end-of-line)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3908 (point))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3909 (if (get-buffer text)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3910 (progn
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3911 (set-buffer text)
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3912 (revert-buffer t)))))))
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3913
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3914
ca02f300fc41 More commentary.
Karl Heuer <kwzh@gnu.org>
parents: 22250
diff changeset
3915
21650
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3916 ;;; Color loading section This is messy *Blech!*
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3917 ;;
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3918 (defface speedbar-button-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3919 (:foreground "green4"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3920 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3921 (:foreground "green3")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3922 "Face used for +/- buttons."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3923 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3924
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3925 (defface speedbar-file-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3926 (:foreground "cyan4"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3927 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3928 (:foreground "cyan"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3929 (t (:bold t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3930 "Face used for file names."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3931 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3932
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3933 (defface speedbar-directory-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3934 (:foreground "blue4"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3935 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3936 (:foreground "light blue")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3937 "Faced used for directory names."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3938 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3939 (defface speedbar-tag-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3940 (:foreground "brown"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3941 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3942 (:foreground "yellow")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3943 "Face used for displaying tags."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3944 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3945
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3946 (defface speedbar-selected-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3947 (:foreground "red" :underline t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3948 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3949 (:foreground "red" :underline t))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3950 (t (:underline t)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3951 "Face used to underline the file in the active window."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3952 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3953
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3954 (defface speedbar-highlight-face '((((class color) (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3955 (:background "green"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3956 (((class color) (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3957 (:background "sea green"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3958 (((class grayscale monochrome)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3959 (background light))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3960 (:background "black"))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3961 (((class grayscale monochrome)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3962 (background dark))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3963 (:background "white")))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3964 "Face used for highlighting buttons with the mouse."
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3965 :group 'speedbar-faces)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3966
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3967 ;; some edebug hooks
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3968 (add-hook 'edebug-setup-hook
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3969 (lambda ()
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3970 (def-edebug-spec speedbar-with-writable def-body)))
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3971
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3972 (provide 'speedbar)
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3973 ;;; speedbar ends here
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3974
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3975 ;; run load-time hooks
69bdeef5e927 Initial revision
Dan Nicolaescu <done@ece.arizona.edu>
parents:
diff changeset
3976 (run-hooks 'speedbar-load-hook)