(directory_files_internal): Set result list to nil
[emacs.git] / man / speedbar.texi
blob734c8c0ca785cc81b4d0323eeab284cf3c6c438d
1 \input texinfo   @c -*-texinfo-*-
2 @c
3 @c $Id: speedbar.texi,v 1.5 2000/12/05 23:02:24 fx Exp $
4 @c
6 @c This file is part of GNU Emacs
8 @c GNU Emacs is free software; you can redistribute it and/or modify it
9 @c under the terms of the GNU General Public License as published by the
10 @c Free Software Foundation; either version 2 of the License, or (at
11 @c your option) any later version.
13 @c GNU Emacs is distributed in the hope that it will be useful, but
14 @c WITHOUT ANY WARRANTY; without even the implied warranty of
15 @c MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
16 @c General Public License for more details.
18 @c You should have received a copy of the GNU General Public License
19 @c along with Emacs; see the file COPYING.  If not, write to the Free
20 @c Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA.
22 @setfilename ../info/speedbar
23 @settitle Speedbar: File/Tag summarizing utility
25 @dircategory Emacs
26 @direntry
27 * Speedbar: (speedbar).        File/Tag summarizing utility.
28 @end direntry
29 @ifnottex
30 Copyright @copyright{} 1999, 2000 Free Software Foundation, Inc.
32 Permission is granted to copy, distribute and/or modify this document
33 under the terms of the GNU Free Documentation License, Version 1.1 or
34 any later version published by the Free Software Foundation; with the
35 Invariant Sections being ``The GNU Manifesto'', ``Distribution'' and
36 ``GNU GENERAL PUBLIC LICENSE'', with the Front-Cover texts being ``A GNU
37 Manual'', and with the Back-Cover Texts as in (a) below.  A copy of the
38 license is included in the section entitled ``GNU Free Documentation
39 License'' in the Emacs manual.
41 (a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
42 this GNU Manual, like GNU software.  Copies published by the Free
43 Software Foundation raise funds for GNU development.''
45 This document is part of a collection distributed under the GNU Free
46 Documentation License.  If you want to distribute this document
47 separately from the collection, you can do so by adding a copy of the
48 license to the document, as described in section 6 of the license.
49 @end ifnottex
51 @titlepage
52 @sp 10
53 @center @titlefont{Speedbar}
54 @sp 2
55 @center Eric Ludlam
56 @vskip 0pt plus 1 fill
57 @page
58 @vskip 0pt plus 1filll
59 Copyright @copyright{} 1999, 2000 Free Software Foundation, Inc.
60 @sp 1
61 Permission is granted to copy, distribute and/or modify this document
62 under the terms of the GNU Free Documentation License, Version 1.1 or
63 any later version published by the Free Software Foundation; with the
64 Invariant Sections being ``The GNU Manifesto'', ``Distribution'' and
65 ``GNU GENERAL PUBLIC LICENSE'', with the Front-Cover texts being ``A GNU
66 Manual'', and with the Back-Cover Texts as in (a) below.  A copy of the
67 license is included in the section entitled ``GNU Free Documentation
68 License'' in the Emacs manual.
70 (a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
71 this GNU Manual, like GNU software.  Copies published by the Free
72 Software Foundation raise funds for GNU development.''
74 This document is part of a collection distributed under the GNU Free
75 Documentation License.  If you want to distribute this document
76 separately from the collection, you can do so by adding a copy of the
77 license to the document, as described in section 6 of the license.
78 @end titlepage
80 @syncodeindex fn cp
82 @node Top, , , (dir)Top
83 @comment  node-name,  next,  previous,  up
85 Speedbar is a program for Emacs which can be used to summarize
86 information related to the current buffer.  Its original inspiration
87 is the `explorer' often used in modern development environments, office
88 packages, and web browsers.
90 Speedbar displays a narrow frame in which a tree view is shown.  This
91 tree view defaults to containing a list of files and directories.  Files
92 can be `expanded' to list tags inside. Directories can be expanded to
93 list the files within itself.  Each file or tag can be jumped to
94 immediately.
96 Speedbar expands upon `explorer' windows by maintaining context with the
97 user.  For example, when using the file view, the current buffer's file
98 is highlighted.  Speedbar also mimics the explorer windows by providing
99 multiple display modes.  These modes come in two flavors.  Major display
100 modes remain consistent across buffers, and minor display modes appear
101 only when a buffer of the applicable type is shown.  This allows
102 authors of other packages to provide speedbar summaries customized to
103 the needs of that mode.
105 Throughout this manual, activities are defined as `clicking on', or
106 `expanding' items.  Clicking means using using @kbd{mouse-2} on a
107 button.  Expanding refers to clicking on an expansion button to display
108 an expanded summary of the entry the expansion button is
109 on.  @xref{Basic Navigation}.
111 @menu
112 * Introduction::     Basics of speedbar.
113 * Basic Navigation:: Basics of speedbar common between all modes.
114 * File Mode::        Summarizing files.
115 * Buffer Mode::      Summarizing buffers.
116 * Minor Modes::      Additional minor modes such as Info and RMAIL.
117 * Customizing::      Changing speedbar behavior.
118 * Extending::        Extend speedbar for your own project.
119 * Index::
120 @end menu
122 @node Introduction, Basic Navigation, , Top
123 @comment  node-name,  next,  previous,  up
124 @chapter Introduction
125 @cindex introduction
127 To start using speedbar use the command @kbd{M-x speedbar RET} or select
128 it from the Tools menu in versions of Emacs with speedbar installed by
129 default.  This command will open a new frame to summarize the local
130 files.  On X Window systems or on MS-Windows, speedbar's frame is twenty
131 characters wide, and will mimic the height of the frame from which it
132 was started.  It positions itself to the left or right of the frame you
133 started it from.
135 To use speedbar effectively, it is important to understand its
136 relationship with the frame you started it from.  This frame is the
137 @dfn{attached frame} which speedbar will use as a reference point.  Once
138 started, speedbar watches the contents of this frame, and attempts to
139 make its contents relevant to the buffer loaded into the attached
140 frame.  In addition, all requests made in speedbar that require the
141 display of another buffer will display in the attached frame.
143 When used in terminal mode, the new frame appears the same size as the
144 terminal.  Since it is not visible while working in the attached frame,
145 speedbar will save time by using the @dfn{slowbar mode}, where no tracking is
146 done until speedbar is requested to show itself (i.e., the speedbar's
147 frame becomes the selected frame).
149 @cindex @code{speedbar-get-focus}
150 The function to use when switching between frames using the keyboard is
151 @code{speedbar-get-focus}.  This function will toggle between frames, and
152 it's useful to bind it to a key in terminal mode.  @xref{Customizing}.
154 @node Basic Navigation, File Mode, Introduction, Top
155 @comment  node-name,  next,  previous,  up
156 @chapter Basic Navigation
158 Speedbar can display different types of data, and has several display
159 and behavior modes.  These modes all have a common behavior, menu
160 system, and look.  If one mode is learned, then the other modes are easy
161 to use.
163 @menu
164 * Basic Keybindings::
165 * Basic Visuals::
166 * Mouse Bindings::
167 * Displays Submenu::
168 @end menu
170 @node Basic Keybindings, Basic Visuals, Basic Navigation, Basic Navigation
171 @comment  node-name,  next,  previous,  up
172 @section Basic Keybindings
173 @cindex keybindings
175 These keybindings are common across all modes:
177 @table @kbd
178 @item delete, SPC
179 @cindex scrolling in speedbar
180 Scroll up and down one page.
181 @item Q
182 @cindex quitting speedbar
183 Quit speedbar, and kill the frame.
184 @item q
185 Quit speedbar, and hide the frame.  This makes it faster to restore the
186 speedbar frame, than if you press @kbd{Q}.
187 @item g
188 @cindex refresh speedbar display
189 Refresh whatever contents are in speedbar.
190 @item t
191 @cindex slowbar mode
192 Toggle speedbar to and from slowbar mode.  In slowbar mode, frame
193 tracking is not done.
194 @item n
195 @itemx p
196 @cindex navigation
197 Move, respectively, to the next or previous item.  A summary of that
198 item will be displayed in the attached frame's minibuffer.
199 @item M-n
200 @itemx M-p
201 Move to the next or previous item in a restricted fashion.  If a list is
202 open, the cursor will skip over it.  If the cursor is in an open list,
203 it will not leave it.
204 @item C-M-n
205 @itemx C-M-n
206 Move forwards and backwards across extended groups.  This lets you
207 quickly skip over all files, directories, or other common sub-items at
208 the same current depth.
209 @item C-x b
210 Switch buffers in the attached frame.
211 @end table
213 Speedbar can handle multiple modes.  Two are provided by default.
214 These modes are File mode, and Buffers mode.  There are accelerators to
215 switch into these different modes.
217 @cindex mode switching hotkeys
218 @table @kbd
219 @item b
220 Switch into Quick Buffers mode (@pxref{Buffer Mode}).  After one use, the
221 previous display mode is restored.
222 @item f
223 Switch into File mode.
224 @item r
225 Switch back to the previous mode.
226 @end table
228 Some modes provide groups, lists and tags.  @xref{Basic Visuals}.  When
229 these are available, some additional common bindings are available.
231 @cindex common keys
232 @table @kbd
233 @item RET
234 @itemx e
235 Edit/Open the current group or tag.  This behavior is dependent on the
236 mode.  In general, files or buffers are opened in the attached frame,
237 and directories or group nodes are expanded locally.
238 @item +
239 @itemx =
240 Expand the current group, displaying sub items.
241 When used with a prefix argument, any data that may have been cached is
242 flushed.  This is similar to a power click.  @xref{Mouse Bindings}.
243 @item -
244 Contract the current group, hiding sub items.
245 @end table
247 @node Basic Visuals, Mouse Bindings, Basic Keybindings, Basic Navigation
248 @comment  node-name,  next,  previous,  up
249 @section Basic Visuals
250 @cindex visuals
252 Speedbar has visual cues for indicating different types of data.  These
253 cues are used consistently across the different speedbar modes to make
254 them easier to interpret.
256 At a high level, in File mode, there are directory buttons, sub
257 directory buttons, file buttons, tag buttons, and expansion buttons.
258 This makes it easy to use the mouse to navigate a directory tree, and
259 quickly view files, or a summary of those files.
261 The most basic visual effect used to distinguish between these button
262 types is color and mouse highlighting.  Anything the mouse highlights
263 can be clicked on and is called a button (@pxref{Mouse Bindings}).
264 Anything not highlighted by the mouse will not be clickable.
266 Text in speedbar consists of four different types of data.  Knowing how
267 to read these textual elements will make it easier to navigate by
268 identifying the types of data available.
270 @subsubsection Groups
271 @cindex groups
273 Groups summarize information in a single line, and provide a high level
274 view of more complex systems, like a directory tree, or manual chapters.
276 Groups appear at different indentation levels, and are prefixed with a
277 @samp{+} in some sort of `box'.  The group name will summarize the
278 information within it, and the expansion box will display that
279 information inline.  In File mode, directories and files are `groups'
280 where the @samp{+} is surrounded by brackets like this:
282 @example
283 <+> include
284 <-> src
285  [+] foo.c
286 @end example
288 In this example, we see both open and closed directories, in addition to
289 a file.  The directories have a box consisting of angle brackets, and a
290 file uses square brackets.
292 In all modes, a group can be `edited' by pressing @kbd{RET}, meaning a
293 file will be opened, or a directory explicitly opened in speedbar.  A
294 group can be expanded or contracted using @kbd{+} or
295 @kbd{-}.  @xref{Basic Keybindings}.
297 Sometimes groups may have a @samp{?} in its indicator box.  This means
298 that it is a group type, but there are no contents, or no known way of
299 extracting contents of that group.
301 When a group has been expanded, the indicator button changes from
302 @samp{+} to @samp{-}.  This indicates that the contents are being shown.
303 Click the @samp{-} button to contract the group, or hide the contents
304 currently displayed.
306 @subsubsection Tags
307 @cindex tags
309 Tags are the leaf nodes of the tree system.  Tags are generally prefixed
310 with a simple character, such as @samp{>}.  Tags can only be jumped to using
311 @kbd{RET} or @kbd{e}.
313 @subsubsection Boolean Flags
315 Sometimes a group or tag is given a boolean flag.  These flags appear as
316 extra text characters at the end of the line.  File mode uses boolean
317 flags, such as a @samp{*} to indicate that a file has been checked out
318 of a versioning system.
320 For additional flags, see
321 @c Note to self, update these to sub-nodes which are more relevant.
322 @ref{File Mode}, and @ref{Version Control}.
324 @subsubsection Unadorned Text
326 Unadorned text generally starts in column 0, without any special symbols
327 prefixing them.  In Buffers mode different buffer groups are prefixed
328 with a description of what the following buffers are (Files, scratch
329 buffers, and invisible buffers.)
331 Unadorned text will generally be colorless, and not clickable.
333 @subsubsection Color Cues
335 Each type of Group, item indicator, and label is given a different
336 color.  The colors chosen are dependent on whether the background color
337 is light or dark.
338 Of important note is that the `current item', which may be a buffer or
339 file name, is highlighted red, and underlined.
341 Colors can be customized from the group @code{speedbar-faces}.  Some
342 modes, such as for Info, will use the Info colors instead of default
343 speedbar colors as an indication of what is currently being displayed.
345 The face naming convention mirrors the File display mode.  Modes which
346 do not use files will attempt to use the same colors on analogous
347 entries.
349 @node Mouse Bindings, Displays Submenu, Basic Visuals, Basic Navigation
350 @comment  node-name,  next,  previous,  up
351 @section Mouse Bindings
352 @cindex mouse bindings
354 The mouse has become a common information navigation tool.  Speedbar
355 will use the mouse to navigate file systems, buffer lists, and other
356 data.  The different textual cues provide buttons which can be clicked
357 on (@pxref{Basic Visuals}).  Anything that highlights can be clicked on
358 with the mouse, or affected by the menu.
360 The mouse bindings are:
362 @table @kbd
363 @item mouse-1
364 Move cursor to that location.
365 @item mouse-2
366 @itemx double-mouse-1
367 Activate the current button.  @kbd{double-mouse-1} is called a @dfn{double
368 click} on other platforms, and is useful for windows users with two
369 button mice.
370 @c Isn't it true that with two-button mice, the right button is mouse-2?
371 @item S-mouse-2
372 @itemx S-double-mouse-1
373 @cindex power click
374 This has the same effect as @kbd{mouse-2}, except it is called a power
375 click.  This means that if a group with an expansion button @samp{+} is
376 clicked, any caches are flushed, and subitems re-read.  If it is a name,
377 it will be opened in a new frame.
378 @item mouse-3
379 Activate the speedbar menu.  The item selected affects the line clicked,
380 not the line where the cursor was.
381 @item mode-line mouse-1
382 Activate the menu.  This affects the item the cursor is on before the
383 click, since the mouse was not clicked on anything.
384 @item C-mouse-1
385 Buffers sub-menu.  The buffer in the attached frame is switched.
386 @end table
388 When the mouse moves over buttons in speedbar, details of that item
389 should be displayed in the minibuffer of the attached frame.  Sometimes
390 this can contain extra information such as file permissions, or tag
391 location.
393 @node Displays Submenu, , Mouse Bindings, Basic Navigation
394 @comment  node-name,  next,  previous,  up
395 @section Displays Submenu
396 @cindex displays submenu
398 You can display different data by using different display modes.  These
399 specialized modes make it easier to navigate the relevant pieces of
400 information, such as files and directories, or buffers.
402 In the main menu, found by clicking @kbd{mouse-3}, there is a submenu
403 labeled ``Displays''.  This submenu lets you easily choose between
404 different display modes.
406 The contents are modes currently loaded into emacs.  By default, this
407 would include Files, Quick Buffers, and Buffers.  Other major display
408 modes such as Info are loaded separately.
410 @node File Mode, Buffer Mode, Basic Navigation, Top
411 @comment  node-name,  next,  previous,  up
412 @chapter File Mode
413 @cindex file mode
415 File mode displays a summary of your current directory.  You can display
416 files in the attached frame, or summarize the tags found in files.  You
417 can even see if a file is checked out of a version control system, or
418 has some associated object file.
420 Advanced behavior, like copying and renaming files, is also provided.
422 @menu
423 * Directory Display::   What the display means.
424 * Hidden Files::        How to display hidden files.
425 * File Keybindings::    Performing file operations.
426 @end menu
428 @node Directory Display, Hidden Files, File Mode, File Mode
429 @comment  node-name,  next,  previous,  up
430 @section Directory Display
431 @cindex directory display
433 There are three major sections in the display.  The first line or two is
434 the root directory speedbar is currently viewing.  You can jump to one
435 of the parent directories by clicking on the name of the directory you
436 wish to jump to.
438 Next, directories are listed.  A directory starts with the group
439 indicator button @samp{<+>}.  Clicking the directory name makes speedbar
440 load that directory as the root directory for its display.  Clicking the
441 @samp{<+>} button will list all directories and files beneath.
443 Next, files are listed.  Files start with the group indicator @samp{[+]}
444 or @samp{[?]}.  You can jump to a file in the attached frame by clicking
445 on the file name.  You can expand a file and look at its tags by
446 clicking on the @samp{[+]} symbol near the file name.
448 A typical session might look like this:
450 @example
451 ~/lisp/
452 <+> checkdoc
453 <+> eieio
454 <-> speedbar
455  [+] Makefile
456  [+] rpm.el #
457  [+] sb-gud.el #
458  [+] sb-info.el #
459  [+] sb-rmail.el #
460  [+] sb-w3.el
461  [-] speedbar.el *!
462   @{+@} Types
463   @{+@} Variables
464   @{+@} def (group)
465   @{+@} speedbar-
466  [+] speedbar.texi *
467 <+> testme
468 [+] align.el
469 [+] autoconf.el
470 @end example
472 In this example, you can see several directories.  The directory
473 @file{speedbar} has been opened inline.  Inside the directory
474 @file{speedbar}, the file @file{speedbar.el} has its tags exposed.
475 These tags are extensive, and they are summarized into tag groups.
477 Files get additional boolean flags associated with them.  Valid flags are:
479 @cindex file flags
480 @table @code
481 @item *
482 This file has been checked out of a version control
483 system.  @xref{Version Control}.
484 @cindex @code{speedbar-obj-alist}
485 @item #
486 This file has an up to date object file associated with it.  The
487 variable @code{speedbar-obj-alist} defines how speedbar determines this
488 value.
489 @item !
490 This file has an out of date object file associated with it.
491 @end table
493 A Tag group is prefixed with the symbol @samp{@{+@}}.  Clicking this
494 symbol will show all symbols that have been organized into that group.
495 Different types of files have unique tagging methods as defined by their
496 major mode.  Tags are generated with either the @code{imenu} package, or
497 through the @code{etags} interface.
499 Tag groups are defined in multiple ways which make it easier to find the
500 tag you are looking for.  Imenu keywords explicitly create groups, and
501 speedbar will automatically create groups if tag lists are too long.
503 In our example, Imenu created the groups @samp{Types} and
504 @samp{Variables}.  All remaining top-level symbols are then regrouped
505 based on the variable @code{speedbar-tag-hierarchy-method}.  The
506 subgroups @samp{def} and @samp{speedbar-} are groupings where the first
507 few characters of the given symbols are specified in the group name.
508 Some group names may say something like @samp{speedbar-t to speedbar-v},
509 indicating that all symbols which alphabetically fall between those
510 categories are included in that sub-group.  @xref{Tag Hierarchy Methods}.
512 @node Hidden Files, File Keybindings, Directory Display, File Mode
513 @comment  node-name,  next,  previous,  up
514 @section Hidden Files
515 @cindex hidden files
517 On Unix, a hidden file is a file whose name starts with a period.  They
518 are hidden from a regular directory listing because the user is not
519 generally interested in them.
521 In speedbar, a hidden file is a file which isn't very interesting and
522 might prove distracting to the user.  Any uninteresting files are
523 removed from the File display.  There are two levels of uninterest in
524 speedbar.  The first level of uninterest are files which have no
525 expansion method, or way of extracting tags.  The second level is any
526 file that matches the same pattern used for completion in
527 @code{find-file}.  This is derived from the variable
528 @code{completion-ignored-extensions}.
530 You can toggle the display of uninteresting files from the toggle menu
531 item @samp{Show All Files}.  This will display all level one hidden files.
532 These files will be shown with a @samp{?} indicator.  Level 2 hidden
533 files will still not be shown.
535 Object files fall into the category of level 2 hidden files.  You can
536 determine their presence by the @samp{#} and @samp{!} file indicators.
537 @xref{Directory Display}.
539 @node File Keybindings, , Hidden Files, File Mode
540 @comment  node-name,  next,  previous,  up
541 @section File Keybindings
542 @cindex file keybindings
544 File mode has keybindings permitting different file system operations
545 such as copy or rename.  These commands all operate on the @dfn{current
546 file}.  In this case, the current file is the file at point, or clicked
547 on when pulling up the menu.
549 @table @kbd
550 @item U
551 Move the entire speedbar display up one directory.
552 @item I
553 Display information in the minibuffer about this line.  This is the same
554 information shown when navigating with @kbd{n} and @kbd{p}, or moving
555 the mouse over an item.
556 @item B
557 Byte compile the Emacs Lisp file on this line.
558 @item L
559 Load the Emacs Lisp file on this line.  If a @file{.elc} file exists,
560 optionally load that.
561 @item C
562 Copy the current file to some other location.
563 @item R
564 Rename the current file, possibly moving it to some other location.
565 @item D
566 Delete the current file.
567 @item O
568 Delete the current file's object file.  Use the symbols @samp{#} and
569 @samp{!} to determine if there is an object file available.
570 @end table
572 One menu item toggles the display of all available files.  By default,
573 only files which Emacs understands, and knows how to convert into a tag
574 list, are shown.  By showing all files, additional files such as text files are
575 also displayed, but they are prefixed with the @samp{[?]} symbol.  This
576 means that it is a file, but Emacs doesn't know how to expand it.
578 @node Buffer Mode, Minor Modes, File Mode, Top
579 @comment  node-name,  next,  previous,  up
580 @chapter Buffer Mode
581 @cindex buffer mode
583 Buffer mode is very similar to File mode, except that instead of
584 tracking the current directory and all files available there, the
585 current list of Emacs buffers is shown.
587 These buffers can have their tags expanded in the same way as files,
588 and uses the same unknown file indicator (@pxref{File Mode}).
590 Buffer mode does not have file operation bindings, but the following
591 buffer specific keybindings are available:
593 @table @kbd
594 @item k
595 Kill this buffer.  Do not touch its file.
596 @item r
597 Revert this buffer, reloading from disk.
598 @end table
600 In addition to Buffer mode, there is also Quick Buffer mode.  In fact,
601 Quick Buffers is bound to the @kbd{b} key.  The only difference between
602 Buffers and Quick Buffers is that after one operation  is performed
603 which affects the attached frame, the display is immediately reverted to
604 the last displayed mode.
606 Thus, if you are in File mode, and you need quick access to a buffer,
607 press @kbd{b}, click on the buffer you want, and speedbar will revert
608 back to File mode.
610 @node Minor Modes, Customizing, Buffer Mode, Top
611 @comment  node-name,  next,  previous,  up
612 @chapter Minor Display Modes
613 @cindex minor display modes
615 For some buffers, a list of files and tags makes no sense.  This could
616 be because files are not currently in reference (such as web pages), or
617 that the files you might be interested have special properties (such as
618 email folders.)
620 In these cases, a minor display mode is needed.  A minor display mode
621 will override any major display mode currently being displayed for the
622 duration of the specialized buffer's use.  Minor display modes
623 will follow the general rules of their major counterparts in terms of
624 keybindings and visuals, but will have specialized behaviors.
626 @menu
627 * RMAIL::  Managing folders in speedbar
628 * Info::   Browsing topics in speedbar
629 * GDB::    Managing the current stack trace in speedbar
630 @end menu
632 @node RMAIL, Info, Minor Modes, Minor Modes
633 @comment  node-name,  next,  previous,  up
634 @section RMAIL
635 @cindex RMAIL
637 When using RMAIL, speedbar will display two sections.  The first is a
638 layer one reply button.  Clicking here will initialize a reply buffer
639 showing only this email address in the @samp{To:} field.
641 The second section lists all RMAIL folders in the same directory as your
642 main RMAIL folder.  The general rule is that RMAIL folders always appear
643 in all caps, or numbers.  It is possible to save mail in folders with
644 lower case letters, but there is no clean way of detecting such RMAIL folders
645 without opening them all.
647 Each folder can be visited by clicking the name.  You can move mail from
648 the current RMAIL folder into a different folder by clicking the
649 @samp{<M>} button.  The @samp{M} stands for Move.
651 In this way you can manage your existing RMAIL folders fairly easily
652 using the mouse.
654 @node Info, GDB, RMAIL, Minor Modes
655 @comment  node-name,  next,  previous,  up
656 @section Info
657 @cindex Info
659 When browsing Info files, all local relevant information is displayed in
660 the info buffer and a topical high-level view is provided in speedbar.
661 All top-level info nodes are shown in the speedbar frame, and can be
662 jumped to by clicking the name.
664 You can open these nodes with the @samp{[+]} button to see what sub-topics
665 are available.  Since these sub-topics are not examined until you click
666 the @samp{[+]} button, sometimes a @samp{[?]} will appear when you click on
667 a @samp{[+]}, indicating that there are no sub-topics.
669 @node GDB, , Info, Minor Modes
670 @comment  node-name,  next,  previous,  up
671 @section GDB
672 @cindex gdb
673 @cindex gud
675 If you are debugging an application with GDB in Emacs, speedbar can show
676 you the current stack when the current buffer is the @file{*gdb*}
677 buffer.  Usually, it will just report that there is no stack, but when
678 the application is stopped, the current stack will be shown.
680 You can click on any stack element and gdb will move to that stack
681 level.  You can then check variables local to that level at the GDB
682 prompt.
684 This mode has the unfortunate side-effect of breaking GDB's repeat
685 feature when you hit @kbd{RET} since your previous command is overridden
686 with a stack fetching command.
688 @node Customizing, Extending, Minor Modes, Top
689 @comment  node-name,  next,  previous,  up
690 @chapter Customizing
691 @cindex customizing
693 Speedbar is highly customizable, with a plethora of control elements.
694 Since speedbar is so visual and reduces so much information, this is an
695 important aspect of its behavior.
697 In general, there are three custom groups you can use to quickly modify
698 speedbar's behavior.
700 @table @code
701 @item speedbar
702 Basic speedbar behaviors.
703 @item speedbar-vc
704 Customizations regarding version control handling.
705 @item speedbar-faces
706 Customize speedbar's many colors and fonts.
707 @end table
709 @menu
710 * Frames and Faces::        Visible behaviors.
711 * Tag Hierarchy Methods::   Customizing how tags are displayed.
712 * Version Control::         Adding new VC detection modes.
713 * Hooks::                   The many hooks you can use.
714 @end menu
716 @node Frames and Faces, Tag Hierarchy Methods, Customizing, Customizing
717 @comment  node-name,  next,  previous,  up
718 @section Frames and Faces
719 @cindex faces
720 @cindex frame parameters
722 There are several faces speedbar generates to provide a consistent
723 color scheme across display types.  You can customize these faces using
724 your favorite method.  They are:
726 @table @asis
727 @cindex @code{speedbar-button-face}
728 @item speedbar-button-face
729 Face used on expand/contract buttons.
730 @cindex @code{speedbar-file-face}
731 @item speedbar-file-face
732 Face used on Files.  Should also be used on non-directory like nodes.
733 @cindex @code{speedbar-directory-face}
734 @item speedbar-directory-face
735 Face used for directories, or nodes which consist of groups of other nodes.
736 @cindex @code{speedbar-tag-face}
737 @item speedbar-tag-face
738 Face used for tags in a file, or for leaf items.
739 @cindex @code{speedbar-selected-face}
740 @item speedbar-selected-face
741 Face used to highlight the selected item.  This would be the current
742 file being edited.
743 @cindex @code{speedbar-highlight-face}
744 @item speedbar-highlight-face
745 Face used when the mouse passes over a button.
746 @end table
748 You can also customize speedbar's initial frame parameters.  How this is
749 accomplished is dependent on your platform being Emacs or XEmacs.
751 @cindex @code{speedbar-frame-parameters}, Emacs
752 In Emacs, change the alist @code{speedbar-frame-parameters}.  This
753 variable is used to set up initial details.  Height is also
754 automatically added when speedbar is created, though you can override
757 @cindex @code{speedbar-frame-plist}, XEmacs
758 In XEmacs, change the plist @code{speedbar-frame-plist}.  This is the
759 XEmacs way of doing the same thing.
761 @node Tag Hierarchy Methods, Version Control, Frames and Faces, Customizing
762 @comment  node-name,  next,  previous,  up
763 @section Tag Hierarchy Methods
764 @cindex tag hierarchy
765 @cindex tag groups
766 @cindex tag sorting
768 When listing tags within a file, it is possible to get an annoyingly
769 long list of entries.  Imenu (which generates the tag list in Emacs)
770 will group some classes of items automatically.   Even here, however,
771 some tag groups can be quite large.
773 @cindex @code{speedbar-tag-hierarchy-method}
774 To solve this problem, tags can be grouped into logical units through a
775 hierarchy processor.  The specific variable to use is
776 @code{speedbar-tag-hierarchy-method}.  There are several methods that
777 can be applied in any order.  They are:
779 @table @code
780 @cindex @code{speedbar-trim-words-tag-hierarchy}
781 @item speedbar-trim-words-tag-hierarchy
782 Find a common prefix for all elements of a group, and trim it off.
783 @cindex @code{speedbar-prefix-group-tag-hierarchy}
784 @item speedbar-prefix-group-tag-hierarchy
785 If a group is too large, place sets of tags into bins based on common
786 prefixes.
787 @cindex @code{speedbar-simple-group-tag-hierarchy}
788 @item speedbar-simple-group-tag-hierarchy
789 Take all items in the top level list not in a group, and stick them into
790 a @samp{Tags} group.
791 @cindex @code{speedbar-sort-tag-hierarchy}
792 @item speedbar-sort-tag-hierarchy
793 Sort all items, leaving groups on top.
794 @end table
796 You can also add your own functions to reorganize tags as you see fit.
798 Some other control variables are:
800 @table @code
801 @cindex @code{speedbar-tag-group-name-minimum-length}
802 @item speedbar-tag-group-name-minimum-length
803 Default value: 4.
805 The minimum length of a prefix group name before expanding.  Thus, if
806 the @code{speedbar-tag-hierarchy-method} includes
807 @code{speedbar-prefix-group-tag-hierarchy} and one such group's common
808 characters is less than this number of characters, then the group name
809 will be changed to the form of:
811 @example
812 worda to wordb
813 @end example
815 instead of just
817 @example
818 word
819 @end example
821 This way we won't get silly looking listings.
823 @cindex @code{speedbar-tag-split-minimum-length}
824 @item speedbar-tag-split-minimum-length
825 Default value: 20.
827 Minimum length before we stop trying to create sub-lists in tags.
828 This is used by all tag-hierarchy methods that break large lists into
829 sub-lists.
831 @cindex @code{speedbar-tag-regroup-maximum-length}
832 @item speedbar-tag-regroup-maximum-length
833 Default value: 10.
835 Maximum length of submenus that are regrouped.
836 If the regrouping option is used, then if two or more short subgroups
837 are next to each other, then they are combined until this number of
838 items is reached.
839 @end table
841 @node Version Control, Hooks, Tag Hierarchy Methods, Customizing
842 @comment  node-name,  next,  previous,  up
843 @section Version Control
844 @cindex version control
845 @cindex vc extensions
847 When using the file mode in speedbar, information regarding a version
848 control system adds small details to the display.  If a file is in a
849 version control system, and is ``checked out'', or ``locked'' locally, an
850 asterisk @samp{*} is placed at the end of the file name.  In addition,
851 the directory name for Version Control systems are left out of the
852 speedbar display.
854 @cindex @code{speedbar-directory-unshown-regexp}
855 You can easily add new version control systems into speedbar's detection
856 scheme.  To make a directory ``disappear'' from the list, use the variable
857 @code{speedbar-directory-unshown-regexp}.
859 @cindex @code{speedbar-vc-path-enable-hook}
860 Next, you need to write entries for two hooks.  The first is
861 @code{speedbar-vc-path-enable-hook} which will enable a VC check in the
862 current directory for the group of files being checked.  Your hook
863 function should take one parameter (the directory to check) and return
864 @code{t} if your VC method is in control here.
866 @cindex @code{speedbar-vc-in-control-hook}
867 The second function is @code{speedbar-vc-in-control-hook}.  This hook
868 takes two parameters, the @var{path} of the file to check, and the
869 @var{file} name.  Return @code{t} if you want to have the asterisk
870 placed near this file.
872 @cindex @code{speedbar-vc-indicator}
873 Lastly, you can change the VC indicator using the variable
874 @code{speedbar-vc-indicator}, and specify a single character string.
876 @node Hooks, , Version Control, Customizing
877 @comment  node-name,  next,  previous,  up
878 @section Hooks
879 @cindex hooks
881 There are several hooks in speedbar allowing custom behaviors to be
882 added.  Available hooks are:
884 @table @code
885 @cindex @code{speedbar-visiting-file-hook}
886 @item speedbar-visiting-file-hook
887 Hooks run when speedbar visits a file in the selected frame.
888 @cindex @code{speedbar-visiting-tag-hook}
889 @item speedbar-visiting-tag-hook
890 Hooks run when speedbar visits a tag in the selected frame.
891 @cindex @code{speedbar-load-hook}
892 @item speedbar-load-hook
893 Hooks run when speedbar is loaded.
894 @cindex @code{speedbar-reconfigure-keymaps-hook}
895 @item speedbar-reconfigure-keymaps-hook
896 Hooks run when the keymaps are regenerated.  Keymaps are reconfigured
897 whenever modes change.  This will let you add custom keybindings.
898 @cindex @code{speedbar-before-popup-hook}
899 @item speedbar-before-popup-hook
900 Hooks called before popping up the speedbar frame.
901 New frames are often popped up when ``power clicking'' on an item to view
903 @cindex @code{speedbar-before-delete-hook}
904 @item speedbar-before-delete-hook
905 Hooks called before deleting or hiding the speedbar frame.
906 @cindex @code{speedbar-mode-hook}
907 @item speedbar-mode-hook
908 Hooks called after creating a speedbar buffer.
909 @cindex @code{speedbar-timer-hook}
910 @item speedbar-timer-hook
911 Hooks called after running the speedbar timer function.
912 @cindex @code{speedbar-scanner-reset-hook}
913 @item speedbar-scanner-reset-hook
914 Hook called whenever generic scanners are reset.
915 Set this to implement your own scanning or rescan safe functions with
916 state data.
917 @end table
919 @node Extending, Index, Customizing, Top
920 @comment  node-name,  next,  previous,  up
921 @chapter Extending
922 @cindex extending
924 Speedbar can run different types of Major display modes such as Files
925 (@pxref{File Mode}), and Buffers (@pxref{Buffer Mode}).  It can also manage
926 different minor display modes for use with buffers handling specialized
927 data.
929 These major and minor display modes are handled through an extension
930 system which permits specialized keymaps and menu extensions, in
931 addition to a unique rendering function.  You can also specify a wide
932 range of tagging functions.  The default uses @code{imenu}, but new
933 tagging methods can be easily added.  In this chapter, you will
934 learn how to write your own major or minor display modes, and how to
935 create specialized tagging functions.
937 @menu
938 * Minor Display Modes::    How to create a minor display mode.
939 * Major Display Modes::    How to create a major display mode.
940 * Tagging Extensions::     How to create your own tagging methods.
941 * Creating a display::     How to insert buttons and hierarchies.
942 @end menu
944 @node Minor Display Modes, Major Display Modes, Extending, Extending
945 @section Minor Display Modes
946 @cindex create minor display mode
948 A @dfn{minor display mode} is a mode useful when using a specific type of
949 buffer.  This mode might not be useful for any other kind of data or
950 mode, or may just be more useful that a files or buffers based mode when
951 working with a specialized mode.
953 Examples that already exist for speedbar include RMAIL, Info, and gdb.
954 These modes display information specific to the major mode shown in the
955 attached frame.
957 To enable a minor display mode in your favorite Major mode, follow these
958 steps.  The string @samp{@var{name}} is the name of the major mode being
959 augmented with speedbar.
961 @enumerate
962 @item
963 Create the keymap variable @code{@var{name}-speedbar-key-map}.
965 @item
966 Create a function, named whatever you like, which assigns values into your
967 keymap.  Use this command to create the keymap before assigning
968 bindings:
970 @smallexample
971     (setq @var{name}-speedbar-key-map (speedbar-make-specialized-keymap))
972 @end smallexample
974 This function creates a special keymap for use in speedbar.
976 @item
977 Call your install function, or assign it to a hook like this:
979 @smallexample
980 (if (featurep 'speedbar)
981     (@var{name}-install-speedbar-variables)
982   (add-hook 'speedbar-load-hook '@var{name}-install-speedbar-variables))
983 @end smallexample
985 @item
986 Create an easymenu compatible vector named
987 @code{@var{name}-speedbar-menu-items}.  This will be spliced into
988 speedbar's control menu.
990 @item
991 Create a function called @code{@var{name}-speedbar-buttons}.  This function
992 should take one variable, which is the buffer for which it will create
993 buttons.   At this time @code{(current-buffer)} will point to the
994 uncleared speedbar buffer.
995 @end enumerate
997 When writing @code{@var{name}-speedbar-buttons}, the first thing you will
998 want to do is execute a check to see if you need to re-create your
999 display.  If it needs to be cleared, you need to erase the speedbar
1000 buffer yourself, and start drawing buttons.  @xref{Creating a display}.
1002 @node Major Display Modes, Tagging Extensions, Minor Display Modes, Extending
1003 @section Major Display Modes
1004 @cindex create major display mode
1006 Creating a @dfn{Major Display Mode} for speedbar requires authoring a keymap,
1007 an easy-menu segment, and writing several functions.  These items can be
1008 given any name, and are made the same way as in a minor display mode
1009 (@pxref{Minor Display Modes}).  Once this is done, these items need to be
1010 registered.
1012 Because this setup activity may or may not have speedbar available when
1013 it is being loaded, it is necessary to create an install function.  This
1014 function should create and initialize the keymap, and add your
1015 expansions into the customization tables.
1017 @cindex @code{speedbar-make-specialized-keymap}
1018 When creating the keymap, use the function
1019 @code{speedbar-make-specialized-keymap} instead of other keymap making
1020 functions.  This will provide you with the initial bindings needed.
1021 Some common speedbar functions you might want to bind are:
1023 @table @code
1024 @cindex @code{speedbar-edit-line}
1025 @item speedbar-edit-line
1026 Edit the item on the current line.
1027 @cindex @code{speedbar-expand-line}
1028 @item speedbar-expand-line
1029 Expand the item under the cursor.
1030 With a numeric argument (@kbd{C-u}), flush cached data before expanding.
1031 @cindex @code{speedbar-contract-line}
1032 @item speedbar-contract-line
1033 Contract the item under the cursor.
1034 @end table
1036 @cindex @code{speedbar-line-path}
1037 These function require that function @code{speedbar-line-path} be
1038 correctly overloaded to work.
1040 Next, register your extension like this;
1042 @example
1043   (speedbar-add-expansion-list '("MyExtension"
1044                                  MyExtension-speedbar-menu-items
1045                                  MyExtension-speedbar-key-map
1046                                  MyExtension-speedbar-buttons))
1047 @end example
1049 There are no limitations to the names you use.
1051 The first parameter is the string representing your display mode.
1052 The second parameter is a variable name containing an easymenu compatible
1053 menu definition.  This will be stuck in the middle of speedbar's menu.
1054 The third parameter is the variable name containing the keymap we
1055 discussed earlier.
1056 The last parameter is a function which draws buttons for your mode.
1057 This function must take two parameters.  The directory currently being
1058 displayed, and the depth at which you should start rendering buttons.
1059 The function will then draw (starting at the current cursor position)
1060 any buttons deemed necessary based on the input parameters.
1061 @xref{Creating a display}.
1063 Next, you need to register function overrides.  This may look something
1064 like this:
1066 @example
1067 (speedbar-add-mode-functions-list
1068  '("MYEXTENSION"
1069    (speedbar-item-info . MyExtension-speedbar-item-info)
1070    (speedbar-line-path . MyExtension-speedbar-line-path)))
1071 @end example
1073 The first element in the list is the name of you extension.  The second
1074 is an alist of functions to overload.  The function to overload is
1075 first, followed by what you want called instead.
1077 For @code{speedbar-line-path} your function should take an optional DEPTH
1078 parameter.  This is the starting depth for heavily indented lines.  If
1079 it is not provided, you can derive it like this:
1081 @example
1082 (save-match-data
1083   (if (not depth)
1084       (progn
1085         (beginning-of-line)
1086         (looking-at "^\\([0-9]+\\):")
1087         (setq depth (string-to-int (match-string 1)))))
1088 @end example
1090 @noindent
1091 where the depth is stored as invisible text at the beginning of each
1092 line.
1094 The path returned should be the full path name of the file associated
1095 with that line.  If the cursor is on a tag, then the file containing
1096 that tag should be returned.  This is critical for built in file based
1097 functions to work (meaning less code for you to write).  If your display
1098 does not deal in files, you do not need to overload this function.
1100 @cindex @code{speedbar-item-info}
1101 The function @code{speedbar-item-info}, however, is very likely to need
1102 overloading.  This function takes no parameters and must derive a text
1103 summary to display in the minibuffer.
1105 There are several helper functions you can use if you are going to use
1106 built in tagging.  These functions can be @code{or}ed since each one
1107 returns non-nil if it displays a message.  They are:
1109 @table @code
1110 @cindex @code{speedbar-item-info-file-helper}
1111 @item speedbar-item-info-file-helper
1112 This takes an optional @var{filename} parameter.  You can derive your own
1113 filename, or it will derive it using a (possibly overloaded) function
1114 @code{speedbar-line-file}.  It shows details about a file.
1115 @cindex @code{speedbar-item-info-tag-helper}
1116 @item speedbar-item-info-tag-helper
1117 If the current line is a tag, then display information about that tag,
1118 such as its parent file, and location.
1119 @end table
1121 Your custom function might look like this:
1123 @example
1124 (defun MyExtension-item-info ()
1125   "Display information about the current line."
1126   (or (speedbar-item-info-tag-helper)
1127       (message "Interesting detail.")))
1128 @end example
1130 Once you have done all this, speedbar will show an entry in the
1131 @samp{Displays} menu declaring that your extension is available.
1133 @node Tagging Extensions, Creating a display, Major Display Modes, Extending
1134 @section Tagging Extensions
1136 It is possible to create new methods for tagging files in speedbar.
1137 To do this, you need two basic functions, one function to fetch the
1138 tags from a buffer, the other to insert them below the filename.
1140 @defun my-fetch-dynamic-tags file
1141 Parse @var{file} for a list of tags.  Return the list, or @code{t} if there was
1142 an error.
1143 @end defun
1145 The non-error return value can be anything, as long as it can be
1146 inserted by its paired function:
1148 @defun my-insert-tag-list level lst
1149 Insert a list of tags @var{lst} started at indentation level
1150 @var{level}.  Creates buttons for each tag, and provides any other
1151 display information required.
1152 @end  defun
1154 @cindex @code{speedbar-create-tag-hierarchy}
1155 It is often useful to use @code{speedbar-create-tag-hierarchy} on your
1156 token list.  See that function's documentation for details on what it
1157 requires.
1159 @cindex @code{speedbar-dynamic-tags-function-list}
1160 Once these two functions are written, modify the variable
1161 @code{speedbar-dynamic-tags-function-list} to include your parser at the
1162 beginning, like this:
1164 @example
1165 (add-to-list 'speedbar-dynamic-tags-function-list
1166              '(my-fetch-dynamic-tags  . my-insert-tag-list))
1167 @end example
1169 If your parser is only good for a few types of files, make sure that it
1170 is either a buffer local modification, or that the tag generator returns
1171 @code{t} for non valid buffers.
1173 @node Creating a display, , Tagging Extensions, Extending
1174 @section Creating a display
1175 @cindex creating a display
1177 Rendering a display in speedbar is completely flexible.  When your
1178 button function is called, see @ref{Minor Display Modes}, and @ref{Major
1179 Display Modes}, you have control to @code{insert} anything you want.
1181 The conventions allow almost anything to be inserted, but several helper
1182 functions are provided to make it easy to create the standardized
1183 buttons.
1185 To understand the built in functions, each `button' in speedbar consists
1186 of four important pieces of data.  The text to be displayed, token
1187 data to be associated with the text, a function to call, and some face to
1188 display it in.
1190 When a function is provided, then that text becomes mouse activated,
1191 meaning the mouse will highlight the text.
1193 Additionally, for data which can form deep trees, each line is given a
1194 depth which indicates how far down the tree it is.  This information is
1195 stored in invisible text at the beginning of each line, and is used by
1196 the navigation commands.
1198 @defun speedbar-insert-button text face mouse function &optional token prevline
1199 This function inserts one button into the current location.
1200 @var{text} is the text to insert.  @var{face} is the face in which it
1201 will be displayed.   @var{mouse} is the face to display over the text
1202 when the mouse passes over it.  @var{function} is called whenever the
1203 user clicks on the text.
1205 The optional argument @var{token} is extra data to associated with the
1206 text.  Lastly @var{prevline} should be non-nil if you want this line to
1207 appear directly after the last button which was created instead of on
1208 the next line.
1209 @end defun
1211 @defun speedbar-make-tag-line exp-button-type exp-button-char exp-button-function exp-button-data tag-button tag-button-function tag-button-data tag-button-face depth
1213 Create a tag line with @var{exp-button-type} for the small expansion
1214 button.  This is the button that expands or contracts a node (if
1215 applicable), and @var{exp-button-char} the character in it (@samp{+},
1216 @samp{-}, @samp{?},
1217 etc).  @var{exp-button-function} is the function to call if it's clicked
1218 on.  Button types are @code{'bracket}, @code{'angle}, @code{'curly},
1219 @code{'expandtag}, @code{'statictag}, or nil.  @var{exp-button-data} is
1220 extra data attached to the text forming the expansion button.
1222 Next, @var{tag-button} is the text of the tag.
1223 @var{tag-button-function} is the function to call if clicked on, and
1224 @var{tag-button-data} is the data to attach to the text field (such a
1225 tag positioning, etc).  @var{tag-button-face} is a face used for this
1226 type of tag.
1228 Lastly, @var{depth} shows the depth of expansion.
1230 This function assumes that the cursor is in the speedbar window at the
1231 position to insert a new item, and that the new item will end with a CR.
1232 @end defun
1234 @defun speedbar-insert-generic-list level list expand-fun find-fun
1236 At @var{level}, (the current indentation level desired) insert a generic
1237 multi-level alist @var{list}.  Associations with lists get @samp{@{+@}}
1238 tags (to expand into more nodes) and those with positions or other data
1239 just get a @samp{>} as the indicator.  @samp{@{+@}} buttons will have the
1240 function @var{expand-fun} and the token is the @code{cdr} list.  The
1241 token name will have the function @var{find-fun} and not token.
1243 Each element of the list can have one of these forms:
1245 @table @code
1246 @item (@var{name} . marker-or-number)
1247 One tag at this level.
1248 @item (@var{name} (@var{name} . marker-or-number) (@var{name} . marker-or-number) ... )
1249 One group of tags.
1250 @item (@var{name} marker-or-number (@var{name} . marker-or-number) ... )
1251 One Group of tags where the group has a starting position.
1252 @end table
1254 When you use @code{speedbar-insert-generic-list}, there are some
1255 variables you can set buffer-locally to change the behavior.  The most
1256 obvious is @code{speedbar-tag-hierarchy-method}.
1257 @xref{Tag Hierarchy Methods}.
1259 @defvar speedbar-generic-list-group-expand-button-type
1260 This is the button type used for groups of tags, whether expanded
1261 or added in via a hierarchy method.  Two good values are
1262 @code{'curly} and @code{'expandtag}.  Curly is the default button, and
1263 @code{'expandtag} is useful if the groups also has a position.
1264 @end defvar
1266 @defvar speedbar-generic-list-tag-button-type
1267 This is the button type used for a single tag.
1268 Two good values are @code{nil} and @code{'statictag}.
1269 @code{nil} is the default, and @code{'statictag} has the same width as
1270 @code{'expandtag}.
1271 @end defvar
1273 @end defun
1275 @node Index, , Extending, Top
1276 @comment  node-name,  next,  previous,  up
1277 @unnumbered Concept Index
1278 @printindex cp
1280 @bye
1281 @c  LocalWords:  speedbar's xref Keybindings slowbar kbd subsubsection
1282 @c  LocalWords:  keybindings