1 @c This is part of the Emacs manual.
2 @c Copyright (C) 1985,86,87,93,94,95,97,99,00,2001 Free Software Foundation, Inc.
3 @c See file emacs.texi for copying conditions.
4 @node Maintaining, Abbrevs, Building, Top
5 @chapter Maintaining Programs
8 @cindex program editing
10 This chapter describes Emacs features for maintaining programs. The
11 version control features,described in the chapter on files
12 (@pxref{Version Control}), are also useful particularly for this
16 * Change Log:: Maintaining a change history for your program.
17 * Authors:: Maintaining an @file{AUTHORS} file.
18 * Tags:: Go direct to any function in your program in one
19 command. Tags remembers which file it is in.
20 * Emerge:: A convenient way of merging two versions of a program.
28 @findex add-change-log-entry-other-window
29 The Emacs command @kbd{C-x 4 a} adds a new entry to the change log
30 file for the file you are editing
31 (@code{add-change-log-entry-other-window}). If that file is actually
32 a backup file, it makes an entry appropriate for the file's
33 parent---that is useful for making log entries for functions that
34 have been deleted in the current version.
36 A change log file contains a chronological record of when and why you
37 have changed a program, consisting of a sequence of entries describing
38 individual changes. Normally it is kept in a file called
39 @file{ChangeLog} in the same directory as the file you are editing, or
40 one of its parent directories. A single @file{ChangeLog} file can
41 record changes for all the files in its directory and all its
44 A change log entry starts with a header line that contains the
45 current date, your name, and your email address (taken from the
46 variable @code{user-mail-address}). Aside from these header lines,
47 every line in the change log starts with a space or a tab. The bulk
48 of the entry consists of @dfn{items}, each of which starts with a line
49 starting with whitespace and a star. Here are two entries, both dated
50 in May 1993, each with two items:
56 1993-05-25 Richard Stallman <rms@@gnu.org>
58 * man.el: Rename symbols `man-*' to `Man-*'.
59 (manual-entry): Make prompt string clearer.
61 * simple.el (blink-matching-paren-distance):
62 Change default to 12,000.
64 1993-05-24 Richard Stallman <rms@@gnu.org>
66 * vc.el (minor-mode-map-alist): Don't use it if it's void.
67 (vc-cancel-version): Doc fix.
70 One entry can describe several changes; each change should have its
71 own item. Normally there should be a blank line between items. When
72 items are related (parts of the same change, in different places), group
73 them by leaving no blank line between them. The second entry above
74 contains two items grouped in this way.
76 @kbd{C-x 4 a} visits the change log file and creates a new entry
77 unless the most recent entry is for today's date and your name. It
78 also creates a new item for the current file. For many languages, it
79 can even guess the name of the function or other object that was
82 @vindex add-log-keep-changes-together
83 When the option @code{add-log-keep-changes-together} is
84 non-@code{nil}, @kbd{C-x 4 a} adds to any existing entry for the file
85 rather than starting a new entry.
87 @vindex change-log-version-info-enabled
88 @vindex change-log-version-number-regexp-list
89 @cindex file version in change log entries
90 If the value of the variable @code{change-log-version-info-enabled}
91 is non-@code{nil}, @kbd{C-x 4 a} adds the file's version number to the
92 change log entry. It finds the version number by searching the first
93 ten percent of the file, using regular expressions from the variable
94 @code{change-log-version-number-regexp-list}.
96 @cindex Change Log mode
97 @findex change-log-mode
98 The change log file is visited in Change Log mode. In this major
99 mode, each bunch of grouped items counts as one paragraph, and each
100 entry is considered a page. This facilitates editing the entries.
101 @kbd{C-j} and auto-fill indent each new line like the previous line;
102 this is convenient for entering the contents of an entry.
104 @findex change-log-merge
105 You can use the command @kbd{M-x change-log-merge} to merge other
106 log files into a buffer in Change Log Mode, preserving the date
109 @findex change-log-redate
110 @cindex converting change log date style
111 Versions of Emacs before 20.1 used a different format for the time of
112 the change log entry:
115 Fri May 25 11:23:23 1993 Richard Stallman <rms@@gnu.org>
119 The @kbd{M-x change-log-redate} command converts all the old-style
120 date entries in the change log file visited in the current buffer to
121 the new format, to make the file uniform in style. This is handy when
122 entries are contributed by many different people, some of whom use old
125 Version control systems are another way to keep track of changes in your
126 program and keep a change log. @xref{Log Buffer}.
129 @section @file{AUTHORS} files
130 @cindex @file{AUTHORS} file
132 Programs which have many contributors usually include a file named
133 @file{AUTHORS} in their distribution, which lists the individual
134 contributions. Emacs has a special command for maintaining the
135 @file{AUTHORS} file that is part of the Emacs distribution.
138 The @kbd{M-x authors} command prompts for the name of the root of the
139 Emacs source directory. It then scans @file{ChageLog} files and Lisp
140 source files under that directory for information about authors of
141 individual packages and people who made changes in source files, and
142 puts the information it gleans into a buffer named @samp{*Authors*}.
143 You can then edit the contents of that buffer and merge it with the
144 existing @file{AUTHORS} file.
146 Do not assume that this command finds all the contributors; don't
147 assume that a person not listed in the output was not a contributor.
148 If you merged in someone's contribution and did not put his name
149 in the change log, he won't show up in @kbd{M-x authors} either.
155 A @dfn{tags table} is a description of how a multi-file program is
156 broken up into files. It lists the names of the component files and the
157 names and positions of the functions (or other named subunits) in each
158 file. Grouping the related files makes it possible to search or replace
159 through all the files with one command. Recording the function names
160 and positions makes possible the @kbd{M-.} command which finds the
161 definition of a function by looking up which of the files it is in.
163 Tags tables are stored in files called @dfn{tags table files}. The
164 conventional name for a tags table file is @file{TAGS}.
166 Each entry in the tags table records the name of one tag, the name of the
167 file that the tag is defined in (implicitly), and the position in that file
168 of the tag's definition.
170 Just what names from the described files are recorded in the tags table
171 depends on the programming language of the described file. They
172 normally include all file names, functions and subroutines, and may
173 also include global variables, data types, and anything else
174 convenient. Each name recorded is called a @dfn{tag}.
176 @cindex C++ class browser, tags
178 @cindex class browser, C++
180 See also the Ebrowse facility, which is tailored for C++.
181 @xref{Top,, Ebrowse, ebrowse, Ebrowse User's Manual}.
184 * Tag Syntax:: Tag syntax for various types of code and text files.
185 * Create Tags Table:: Creating a tags table with @code{etags}.
186 * Etags Regexps:: Create arbitrary tags using regular expressions.
187 * Select Tags Table:: How to visit a tags table.
188 * Find Tag:: Commands to find the definition of a specific tag.
189 * Tags Search:: Using a tags table for searching and replacing.
190 * List Tags:: Listing and finding tags defined in a file.
194 @subsection Source File Tag Syntax
196 Here is how tag syntax is defined for the most popular languages:
200 In C code, any C function or typedef is a tag, and so are definitions of
201 @code{struct}, @code{union} and @code{enum}.
202 @code{#define} macro definitions and @code{enum} constants are also
203 tags, unless you specify @samp{--no-defines} when making the tags table.
204 Similarly, global variables are tags, unless you specify
205 @samp{--no-globals}. Use of @samp{--no-globals} and @samp{--no-defines}
206 can make the tags table file much smaller.
208 You can tag function declarations and external variables in addition
209 to function definitions by giving the @samp{--declarations} option to
213 In C++ code, in addition to all the tag constructs of C code, member
214 functions are also recognized, and optionally member variables if you
215 use the @samp{--members} option. Tags for variables and functions in
216 classes are named @samp{@var{class}::@var{variable}} and
217 @samp{@var{class}::@var{function}}. @code{operator} definitions have
218 tag names like @samp{operator+}.
221 In Java code, tags include all the constructs recognized in C++, plus
222 the @code{interface}, @code{extends} and @code{implements} constructs.
223 Tags for variables and functions in classes are named
224 @samp{@var{class}.@var{variable}} and @samp{@var{class}.@var{function}}.
227 In La@TeX{} text, the argument of any of the commands @code{\chapter},
228 @code{\section}, @code{\subsection}, @code{\subsubsection},
229 @code{\eqno}, @code{\label}, @code{\ref}, @code{\cite}, @code{\bibitem},
230 @code{\part}, @code{\appendix}, @code{\entry}, or @code{\index}, is a
233 Other commands can make tags as well, if you specify them in the
234 environment variable @env{TEXTAGS} before invoking @code{etags}. The
235 value of this environment variable should be a colon-separated list of
236 command names. For example,
239 TEXTAGS="def:newcommand:newenvironment"
244 specifies (using Bourne shell syntax) that the commands @samp{\def},
245 @samp{\newcommand} and @samp{\newenvironment} also define tags.
248 In Lisp code, any function defined with @code{defun}, any variable
249 defined with @code{defvar} or @code{defconst}, and in general the first
250 argument of any expression that starts with @samp{(def} in column zero, is
254 In Scheme code, tags include anything defined with @code{def} or with a
255 construct whose name starts with @samp{def}. They also include variables
256 set with @code{set!} at top level in the file.
259 Several other languages are also supported:
264 In Ada code, functions, procedures, packages, tasks, and types are
265 tags. Use the @samp{--packages-only} option to create tags for
268 In Ada, the same name can be used for different kinds of entity
269 (e.g.@:, for a procedure and for a function). Also, for things like
270 packages, procedures and functions, there is the spec (i.e.@: the
271 interface) and the body (i.e.@: the implementation). To make it
272 easier to pick the definition you want, Ada tag name have suffixes
273 indicating the type of entity:
290 Thus, @kbd{M-x find-tag @key{RET} bidule/b @key{RET}} will go
291 directly to the body of the package @code{bidule}, while @kbd{M-x
292 find-tag @key{RET} bidule @key{RET}} will just search for any tag
296 In assembler code, labels appearing at the beginning of a line,
297 followed by a colon, are tags.
300 In Bison or Yacc input files, each rule defines as a tag the nonterminal
301 it constructs. The portions of the file that contain C code are parsed
305 In Cobol code, tags are paragraph names; that is, any word starting in
306 column 8 and followed by a period.
309 In Erlang code, the tags are the functions, records, and macros defined
313 In Fortran code, functions, subroutines and blockdata are tags.
316 In makefiles, targets are tags.
319 In Objective C code, tags include Objective C definitions for classes,
320 class categories, methods, and protocols.
323 In Pascal code, the tags are the functions and procedures defined in
327 In Perl code, the tags are the procedures defined by the @code{sub},
328 @code{my} and @code{local} keywords. Use @samp{--globals} if you want
329 to tag global variables.
332 In PostScript code, the tags are the functions.
335 In Prolog code, a tag name appears at the left margin.
338 In Python code, @code{def} or @code{class} at the beginning of a line
342 You can also generate tags based on regexp matching (@pxref{Etags
343 Regexps}) to handle other formats and languages.
345 @node Create Tags Table
346 @subsection Creating Tags Tables
347 @cindex @code{etags} program
349 The @code{etags} program is used to create a tags table file. It knows
350 the syntax of several languages, as described in
352 the previous section.
357 Here is how to run @code{etags}:
360 etags @var{inputfiles}@dots{}
364 The @code{etags} program reads the specified files, and writes a tags
365 table named @file{TAGS} in the current working directory.
367 If the specified files don't exist, @code{etags} looks for
368 compressed versions of them and uncompresses them to read them. Under
369 MS-DOS, @code{etags} also looks for file names like @file{mycode.cgz}
370 if it is given @samp{mycode.c} on the command line and @file{mycode.c}
373 @code{etags} recognizes the language used in an input file based on
374 its file name and contents. You can specify the language with the
375 @samp{--language=@var{name}} option, described below.
377 If the tags table data become outdated due to changes in the files
378 described in the table, the way to update the tags table is the same
379 way it was made in the first place. If the tags table fails to record
380 a tag, or records it for the wrong file, then Emacs cannot possibly
381 find its definition until you update the tags table. However, if the
382 position recorded in the tags table becomes a little bit wrong (due to
383 other editing), the only consequence is a slight delay in finding the
384 tag. Even if the stored position is very far wrong, Emacs will still
385 find the tag, after searching most of the file for it. Even that
386 delay is hardly noticeable with today's computers.
388 So you should update a tags table when you define new tags that you want
389 to have listed, or when you move tag definitions from one file to another,
390 or when changes become substantial. Normally there is no need to update
391 the tags table after each edit, or even every day.
393 One tags table can virtually include another. Specify the included
394 tags file name with the @samp{--include=@var{file}} option when
395 creating the file that is to include it. The latter file then acts as
396 if it covered all the source files specified in the included file, as
397 well as the files it directly contains.
399 If you specify the source files with relative file names when you run
400 @code{etags}, the tags file will contain file names relative to the
401 directory where the tags file was initially written. This way, you can
402 move an entire directory tree containing both the tags file and the
403 source files, and the tags file will still refer correctly to the source
406 If you specify absolute file names as arguments to @code{etags}, then
407 the tags file will contain absolute file names. This way, the tags file
408 will still refer to the same files even if you move it, as long as the
409 source files remain in the same place. Absolute file names start with
410 @samp{/}, or with @samp{@var{device}:/} on MS-DOS and MS-Windows.
412 When you want to make a tags table from a great number of files, you
413 may have problems listing them on the command line, because some systems
414 have a limit on its length. The simplest way to circumvent this limit
415 is to tell @code{etags} to read the file names from its standard input,
416 by typing a dash in place of the file names, like this:
419 find . -name "*.[chCH]" -print | etags -
422 Use the option @samp{--language=@var{name}} to specify the language
423 explicitly. You can intermix these options with file names; each one
424 applies to the file names that follow it. Specify
425 @samp{--language=auto} to tell @code{etags} to resume guessing the
426 language from the file names and file contents. Specify
427 @samp{--language=none} to turn off language-specific processing
428 entirely; then @code{etags} recognizes tags by regexp matching alone
429 (@pxref{Etags Regexps}).
431 @samp{etags --help} prints the list of the languages @code{etags}
432 knows, and the file name rules for guessing the language. It also prints
433 a list of all the available @code{etags} options, together with a short
437 @subsection Etags Regexps
439 The @samp{--regex} option provides a general way of recognizing tags
440 based on regexp matching. You can freely intermix it with file names.
441 Each @samp{--regex} option adds to the preceding ones, and applies only
442 to the following files. The syntax is:
445 --regex=/@var{tagregexp}[/@var{nameregexp}]/
449 where @var{tagregexp} is used to match the lines to tag. It is always
450 anchored, that is, it behaves as if preceded by @samp{^}. If you want
451 to account for indentation, just match any initial number of blanks by
452 beginning your regular expression with @samp{[ \t]*}. In the regular
453 expressions, @samp{\} quotes the next character, and @samp{\t} stands
454 for the tab character. Note that @code{etags} does not handle the other
455 C escape sequences for special characters.
457 @cindex interval operator (in regexps)
458 The syntax of regular expressions in @code{etags} is the same as in
459 Emacs, augmented with the @dfn{interval operator}, which works as in
460 @code{grep} and @code{ed}. The syntax of an interval operator is
461 @samp{\@{@var{m},@var{n}\@}}, and its meaning is to match the preceding
462 expression at least @var{m} times and up to @var{n} times.
464 You should not match more characters with @var{tagregexp} than that
465 needed to recognize what you want to tag. If the match is such that
466 more characters than needed are unavoidably matched by @var{tagregexp}
467 (as will usually be the case), you should add a @var{nameregexp}, to
468 pick out just the tag. This will enable Emacs to find tags more
469 accurately and to do completion on tag names more reliably. You can
470 find some examples below.
472 The option @samp{--ignore-case-regex} (or @samp{-c}) works like
473 @samp{--regex}, except that matching ignores case. This is
474 appropriate for certain programming languages.
476 The @samp{-R} option deletes all the regexps defined with
477 @samp{--regex} options. It applies to the file names following it, as
478 you can see from the following example:
481 etags --regex=/@var{reg1}/ voo.doo --regex=/@var{reg2}/ \
482 bar.ber -R --lang=lisp los.er
486 Here @code{etags} chooses the parsing language for @file{voo.doo} and
487 @file{bar.ber} according to their contents. @code{etags} also uses
488 @var{reg1} to recognize additional tags in @file{voo.doo}, and both
489 @var{reg1} and @var{reg2} to recognize additional tags in
490 @file{bar.ber}. @code{etags} uses the Lisp tags rules, and no regexp
491 matching, to recognize tags in @file{los.er}.
493 You can specify a regular expression for a particular language, by
494 writing @samp{@{lang@}} in front of it. Then @code{etags} will use
495 the regular expression only for files of that language. (@samp{etags
496 --help} prints the list of languages recognised by @code{etags}.) The
497 following example tags the @code{DEFVAR} macros in the Emacs source
498 files, for the C language only:
501 --regex='@{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/'
505 This feature is particularly useful when you store a list of regular
506 expressions in a file. The following option syntax instructs
507 @code{etags} to read two files of regular expressions. The regular
508 expressions contained in the second file are matched without regard to
512 --regex=@@first-file --ignore-case-regex=@@second-file
516 A regex file contains one regular expressions per line. Empty lines,
517 and lines beginning with space or tab are ignored. When the first
518 character in a line is @samp{@@}, @code{etags} assumes that the rest
519 of the line is the name of a file of regular expressions; thus, one
520 such file can include another file. All the other lines are taken to
521 be regular expressions. If the first non-whitespace text on the line
522 is @samp{--}, that line is a comment.
524 For example, one can create a file called @samp{emacs.tags} with the
528 -- This is for GNU Emacs C source files
529 @{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/\1/
533 and then use it like this:
536 etags --regex=@@emacs.tags *.[ch] */*.[ch]
539 Here are some more examples. The regexps are quoted to protect them
540 from shell interpretation.
548 etags --language=none \
549 --regex='/[ \t]*function.*=[ \t]*\([^ \t]*\)[ \t]*(/\1/' \
550 --regex='/###key \(.*\)/\1/' \
551 --regex='/[ \t]*global[ \t].*/' \
556 Note that tags are not generated for scripts, so that you have to add
557 a line by yourself of the form @samp{###key @var{scriptname}} if you
564 etags --language=none --regex='/proc[ \t]+\([^ \t]+\)/\1/' *.tcl
571 etags --language=none \
572 --regex='/[ \t]*\(ARCHITECTURE\|CONFIGURATION\) +[^ ]* +OF/' \
573 --regex='/[ \t]*\(ATTRIBUTE\|ENTITY\|FUNCTION\|PACKAGE\
574 \( BODY\)?\|PROCEDURE\|PROCESS\|TYPE\)[ \t]+\([^ \t(]+\)/\3/'
578 @node Select Tags Table
579 @subsection Selecting a Tags Table
581 @vindex tags-file-name
582 @findex visit-tags-table
583 Emacs has at any time one @dfn{selected} tags table, and all the commands
584 for working with tags tables use the selected one. To select a tags table,
585 type @kbd{M-x visit-tags-table}, which reads the tags table file name as an
586 argument. The name @file{TAGS} in the default directory is used as the
589 All this command does is store the file name in the variable
590 @code{tags-file-name}. Emacs does not actually read in the tags table
591 contents until you try to use them. Setting this variable yourself is just
592 as good as using @code{visit-tags-table}. The variable's initial value is
593 @code{nil}; that value tells all the commands for working with tags tables
594 that they must ask for a tags table file name to use.
596 Using @code{visit-tags-table} when a tags table is already loaded
597 gives you a choice: you can add the new tags table to the current list
598 of tags tables, or start a new list. The tags commands use all the tags
599 tables in the current list. If you start a new list, the new tags table
600 is used @emph{instead} of others. If you add the new table to the
601 current list, it is used @emph{as well as} the others. When the tags
602 commands scan the list of tags tables, they don't always start at the
603 beginning of the list; they start with the first tags table (if any)
604 that describes the current file, proceed from there to the end of the
605 list, and then scan from the beginning of the list until they have
606 covered all the tables in the list.
608 @vindex tags-table-list
609 You can specify a precise list of tags tables by setting the variable
610 @code{tags-table-list} to a list of strings, like this:
612 @c keep this on two lines for formatting in smallbook
615 (setq tags-table-list
616 '("~/emacs" "/usr/local/lib/emacs/src"))
621 This tells the tags commands to look at the @file{TAGS} files in your
622 @file{~/emacs} directory and in the @file{/usr/local/lib/emacs/src}
623 directory. The order depends on which file you are in and which tags
624 table mentions that file, as explained above.
626 Do not set both @code{tags-file-name} and @code{tags-table-list}.
629 @subsection Finding a Tag
631 The most important thing that a tags table enables you to do is to find
632 the definition of a specific tag.
635 @item M-.@: @var{tag} @key{RET}
636 Find first definition of @var{tag} (@code{find-tag}).
638 Find next alternate definition of last tag specified.
640 Go back to previous tag found.
641 @item C-M-. @var{pattern} @key{RET}
642 Find a tag whose name matches @var{pattern} (@code{find-tag-regexp}).
644 Find the next tag whose name matches the last pattern used.
645 @item C-x 4 .@: @var{tag} @key{RET}
646 Find first definition of @var{tag}, but display it in another window
647 (@code{find-tag-other-window}).
648 @item C-x 5 .@: @var{tag} @key{RET}
649 Find first definition of @var{tag}, and create a new frame to select the
650 buffer (@code{find-tag-other-frame}).
652 Pop back to where you previously invoked @kbd{M-.} and friends.
657 @kbd{M-.}@: (@code{find-tag}) is the command to find the definition of
658 a specified tag. It searches through the tags table for that tag, as a
659 string, and then uses the tags table info to determine the file that the
660 definition is in and the approximate character position in the file of
661 the definition. Then @code{find-tag} visits that file, moves point to
662 the approximate character position, and searches ever-increasing
663 distances away to find the tag definition.
665 If an empty argument is given (just type @key{RET}), the balanced
666 expression in the buffer before or around point is used as the
667 @var{tag} argument. @xref{Expressions}.
669 You don't need to give @kbd{M-.} the full name of the tag; a part
670 will do. This is because @kbd{M-.} finds tags in the table which
671 contain @var{tag} as a substring. However, it prefers an exact match
672 to a substring match. To find other tags that match the same
673 substring, give @code{find-tag} a numeric argument, as in @kbd{C-u
674 M-.}; this does not read a tag name, but continues searching the tags
675 table's text for another tag containing the same substring last used.
676 If you have a real @key{META} key, @kbd{M-0 M-.}@: is an easier
677 alternative to @kbd{C-u M-.}.
680 @findex find-tag-other-window
682 @findex find-tag-other-frame
683 Like most commands that can switch buffers, @code{find-tag} has a
684 variant that displays the new buffer in another window, and one that
685 makes a new frame for it. The former is @kbd{C-x 4 .}, which invokes
686 the command @code{find-tag-other-window}. The latter is @kbd{C-x 5 .},
687 which invokes @code{find-tag-other-frame}.
689 To move back to places you've found tags recently, use @kbd{C-u -
690 M-.}; more generally, @kbd{M-.} with a negative numeric argument. This
691 command can take you to another buffer. @kbd{C-x 4 .} with a negative
692 argument finds the previous tag location in another window.
696 @vindex find-tag-marker-ring-length
697 As well as going back to places you've found tags recently, you can go
698 back to places @emph{from where} you found them. Use @kbd{M-*}, which
699 invokes the command @code{pop-tag-mark}, for this. Typically you would
700 find and study the definition of something with @kbd{M-.} and then
701 return to where you were with @kbd{M-*}.
703 Both @kbd{C-u - M-.} and @kbd{M-*} allow you to retrace your steps to
704 a depth determined by the variable @code{find-tag-marker-ring-length}.
706 @findex find-tag-regexp
708 The command @kbd{C-M-.} (@code{find-tag-regexp}) visits the tags that
709 match a specified regular expression. It is just like @kbd{M-.} except
710 that it does regexp matching instead of substring matching.
713 @subsection Searching and Replacing with Tags Tables
714 @cindex search and replace in multiple files
715 @cindex multiple-file search and replace
717 The commands in this section visit and search all the files listed in the
718 selected tags table, one by one. For these commands, the tags table serves
719 only to specify a sequence of files to search.
722 @item M-x tags-search @key{RET} @var{regexp} @key{RET}
723 Search for @var{regexp} through the files in the selected tags
725 @item M-x tags-query-replace @key{RET} @var{regexp} @key{RET} @var{replacement} @key{RET}
726 Perform a @code{query-replace-regexp} on each file in the selected tags table.
728 Restart one of the commands above, from the current location of point
729 (@code{tags-loop-continue}).
733 @kbd{M-x tags-search} reads a regexp using the minibuffer, then
734 searches for matches in all the files in the selected tags table, one
735 file at a time. It displays the name of the file being searched so you
736 can follow its progress. As soon as it finds an occurrence,
737 @code{tags-search} returns.
740 @findex tags-loop-continue
741 Having found one match, you probably want to find all the rest. To find
742 one more match, type @kbd{M-,} (@code{tags-loop-continue}) to resume the
743 @code{tags-search}. This searches the rest of the current buffer, followed
744 by the remaining files of the tags table.@refill
746 @findex tags-query-replace
747 @kbd{M-x tags-query-replace} performs a single
748 @code{query-replace-regexp} through all the files in the tags table. It
749 reads a regexp to search for and a string to replace with, just like
750 ordinary @kbd{M-x query-replace-regexp}. It searches much like @kbd{M-x
751 tags-search}, but repeatedly, processing matches according to your
752 input. @xref{Replace}, for more information on query replace.
754 @vindex tags-case-fold-search
755 @cindex case-sensitivity and tags search
756 You can control the case-sensitivity of tags search commands by
757 customizing the value of the variable @code{tags-case-fold-search}. The
758 default is to use the same setting as the value of
759 @code{case-fold-search} (@pxref{Search Case}).
761 It is possible to get through all the files in the tags table with a
762 single invocation of @kbd{M-x tags-query-replace}. But often it is
763 useful to exit temporarily, which you can do with any input event that
764 has no special query replace meaning. You can resume the query replace
765 subsequently by typing @kbd{M-,}; this command resumes the last tags
766 search or replace command that you did.
768 The commands in this section carry out much broader searches than the
769 @code{find-tag} family. The @code{find-tag} commands search only for
770 definitions of tags that match your substring or regexp. The commands
771 @code{tags-search} and @code{tags-query-replace} find every occurrence
772 of the regexp, as ordinary search commands and replace commands do in
775 These commands create buffers only temporarily for the files that they
776 have to search (those which are not already visited in Emacs buffers).
777 Buffers in which no match is found are quickly killed; the others
780 It may have struck you that @code{tags-search} is a lot like
781 @code{grep}. You can also run @code{grep} itself as an inferior of
782 Emacs and have Emacs show you the matching lines one by one. This works
783 much like running a compilation; finding the source locations of the
784 @code{grep} matches works like finding the compilation errors.
788 @subsection Tags Table Inquiries
791 @item M-x list-tags @key{RET} @var{file} @key{RET}
792 Display a list of the tags defined in the program file @var{file}.
793 @item M-x tags-apropos @key{RET} @var{regexp} @key{RET}
794 Display a list of all tags matching @var{regexp}.
798 @kbd{M-x list-tags} reads the name of one of the files described by
799 the selected tags table, and displays a list of all the tags defined in
800 that file. The ``file name'' argument is really just a string to
801 compare against the file names recorded in the tags table; it is read as
802 a string rather than as a file name. Therefore, completion and
803 defaulting are not available, and you must enter the file name the same
804 way it appears in the tags table. Do not include a directory as part of
805 the file name unless the file name recorded in the tags table includes a
809 @vindex tags-apropos-verbose
810 @kbd{M-x tags-apropos} is like @code{apropos} for tags
811 (@pxref{Apropos}). It finds all the tags in the selected tags table
812 whose entries match @var{regexp}, and displays them. If the variable
813 @code{tags-apropos-verbose} is non-@code{nil}, it displays the names
814 of the tags files together with the tag names.
816 @vindex tags-tag-face
817 @vindex tags-apropos-additional-actions
818 You can customize the appearance of the output with the face
819 @code{tags-tag-face}. You can display additional output with @kbd{M-x
820 tags-apropos} by customizing the variable
821 @code{tags-apropos-additional-actions}---see its documentation for
824 You can also use the collection of tag names to complete a symbol
825 name in the buffer. @xref{Symbol Completion}.
828 @section Merging Files with Emerge
830 @cindex merging files
832 It's not unusual for programmers to get their signals crossed and modify
833 the same program in two different directions. To recover from this
834 confusion, you need to merge the two versions. Emerge makes this
835 easier. See also @ref{Comparing Files}, for commands to compare
836 in a more manual fashion, and @ref{,Ediff,, ediff, The Ediff Manual}.
839 * Overview of Emerge:: How to start Emerge. Basic concepts.
840 * Submodes of Emerge:: Fast mode vs. Edit mode.
841 Skip Prefers mode and Auto Advance mode.
842 * State of Difference:: You do the merge by specifying state A or B
844 * Merge Commands:: Commands for selecting a difference,
845 changing states of differences, etc.
846 * Exiting Emerge:: What to do when you've finished the merge.
847 * Combining in Emerge:: How to keep both alternatives for a difference.
848 * Fine Points of Emerge:: Misc.
851 @node Overview of Emerge
852 @subsection Overview of Emerge
854 To start Emerge, run one of these four commands:
857 @item M-x emerge-files
859 Merge two specified files.
861 @item M-x emerge-files-with-ancestor
862 @findex emerge-files-with-ancestor
863 Merge two specified files, with reference to a common ancestor.
865 @item M-x emerge-buffers
866 @findex emerge-buffers
869 @item M-x emerge-buffers-with-ancestor
870 @findex emerge-buffers-with-ancestor
871 Merge two buffers with reference to a common ancestor in a third
875 @cindex merge buffer (Emerge)
876 @cindex A and B buffers (Emerge)
877 The Emerge commands compare two files or buffers, and display the
878 comparison in three buffers: one for each input text (the @dfn{A buffer}
879 and the @dfn{B buffer}), and one (the @dfn{merge buffer}) where merging
880 takes place. The merge buffer shows the full merged text, not just the
881 differences. Wherever the two input texts differ, you can choose which
882 one of them to include in the merge buffer.
884 The Emerge commands that take input from existing buffers use only the
885 accessible portions of those buffers, if they are narrowed
888 If a common ancestor version is available, from which the two texts to
889 be merged were both derived, Emerge can use it to guess which
890 alternative is right. Wherever one current version agrees with the
891 ancestor, Emerge presumes that the other current version is a deliberate
892 change which should be kept in the merged version. Use the
893 @samp{with-ancestor} commands if you want to specify a common ancestor
894 text. These commands read three file or buffer names---variant A,
895 variant B, and the common ancestor.
897 After the comparison is done and the buffers are prepared, the
898 interactive merging starts. You control the merging by typing special
899 @dfn{merge commands} in the merge buffer. The merge buffer shows you a
900 full merged text, not just differences. For each run of differences
901 between the input texts, you can choose which one of them to keep, or
902 edit them both together.
904 The merge buffer uses a special major mode, Emerge mode, with commands
905 for making these choices. But you can also edit the buffer with
906 ordinary Emacs commands.
908 At any given time, the attention of Emerge is focused on one
909 particular difference, called the @dfn{selected} difference. This
910 difference is marked off in the three buffers like this:
914 @var{text that differs}
919 Emerge numbers all the differences sequentially and the mode
920 line always shows the number of the selected difference.
922 Normally, the merge buffer starts out with the A version of the text.
923 But when the A version of a difference agrees with the common ancestor,
924 then the B version is initially preferred for that difference.
926 Emerge leaves the merged text in the merge buffer when you exit. At
927 that point, you can save it in a file with @kbd{C-x C-w}. If you give a
928 numeric argument to @code{emerge-files} or
929 @code{emerge-files-with-ancestor}, it reads the name of the output file
930 using the minibuffer. (This is the last file name those commands read.)
931 Then exiting from Emerge saves the merged text in the output file.
933 Normally, Emerge commands save the output buffer in its file when you
934 exit. If you abort Emerge with @kbd{C-]}, the Emerge command does not
935 save the output buffer, but you can save it yourself if you wish.
937 @node Submodes of Emerge
938 @subsection Submodes of Emerge
940 You can choose between two modes for giving merge commands: Fast mode
941 and Edit mode. In Fast mode, basic merge commands are single
942 characters, but ordinary Emacs commands are disabled. This is
943 convenient if you use only merge commands. In Edit mode, all merge
944 commands start with the prefix key @kbd{C-c C-c}, and the normal Emacs
945 commands are also available. This allows editing the merge buffer, but
946 slows down Emerge operations.
948 Use @kbd{e} to switch to Edit mode, and @kbd{C-c C-c f} to switch to
949 Fast mode. The mode line indicates Edit and Fast modes with @samp{E}
952 Emerge has two additional submodes that affect how particular merge
953 commands work: Auto Advance mode and Skip Prefers mode.
955 If Auto Advance mode is in effect, the @kbd{a} and @kbd{b} commands
956 advance to the next difference. This lets you go through the merge
957 faster as long as you simply choose one of the alternatives from the
958 input. The mode line indicates Auto Advance mode with @samp{A}.
960 If Skip Prefers mode is in effect, the @kbd{n} and @kbd{p} commands
961 skip over differences in states prefer-A and prefer-B (@pxref{State of
962 Difference}). Thus you see only differences for which neither version
963 is presumed ``correct.'' The mode line indicates Skip Prefers mode with
966 @findex emerge-auto-advance-mode
967 @findex emerge-skip-prefers-mode
968 Use the command @kbd{s a} (@code{emerge-auto-advance-mode}) to set or
969 clear Auto Advance mode. Use @kbd{s s}
970 (@code{emerge-skip-prefers-mode}) to set or clear Skip Prefers mode.
971 These commands turn on the mode with a positive argument, turns it off
972 with a negative or zero argument, and toggle the mode with no argument.
974 @node State of Difference
975 @subsection State of a Difference
977 In the merge buffer, a difference is marked with lines of @samp{v} and
978 @samp{^} characters. Each difference has one of these seven states:
982 The difference is showing the A version. The @kbd{a} command always
983 produces this state; the mode line indicates it with @samp{A}.
986 The difference is showing the B version. The @kbd{b} command always
987 produces this state; the mode line indicates it with @samp{B}.
991 The difference is showing the A or the B state by default, because you
992 haven't made a choice. All differences start in the default-A state
993 (and thus the merge buffer is a copy of the A buffer), except those for
994 which one alternative is ``preferred'' (see below).
996 When you select a difference, its state changes from default-A or
997 default-B to plain A or B. Thus, the selected difference never has
998 state default-A or default-B, and these states are never displayed in
1001 The command @kbd{d a} chooses default-A as the default state, and @kbd{d
1002 b} chooses default-B. This chosen default applies to all differences
1003 which you haven't ever selected and for which no alternative is preferred.
1004 If you are moving through the merge sequentially, the differences you
1005 haven't selected are those following the selected one. Thus, while
1006 moving sequentially, you can effectively make the A version the default
1007 for some sections of the merge buffer and the B version the default for
1008 others by using @kbd{d a} and @kbd{d b} between sections.
1012 The difference is showing the A or B state because it is
1013 @dfn{preferred}. This means that you haven't made an explicit choice,
1014 but one alternative seems likely to be right because the other
1015 alternative agrees with the common ancestor. Thus, where the A buffer
1016 agrees with the common ancestor, the B version is preferred, because
1017 chances are it is the one that was actually changed.
1019 These two states are displayed in the mode line as @samp{A*} and @samp{B*}.
1022 The difference is showing a combination of the A and B states, as a
1023 result of the @kbd{x c} or @kbd{x C} commands.
1025 Once a difference is in this state, the @kbd{a} and @kbd{b} commands
1026 don't do anything to it unless you give them a numeric argument.
1028 The mode line displays this state as @samp{comb}.
1031 @node Merge Commands
1032 @subsection Merge Commands
1034 Here are the Merge commands for Fast mode; in Edit mode, precede them
1039 Select the previous difference.
1042 Select the next difference.
1045 Choose the A version of this difference.
1048 Choose the B version of this difference.
1051 Select difference number @var{n}.
1054 Select the difference containing point. You can use this command in the
1055 merge buffer or in the A or B buffer.
1058 Quit---finish the merge.
1061 Abort---exit merging and do not save the output.
1064 Go into Fast mode. (In Edit mode, this is actually @kbd{C-c C-c f}.)
1070 Recenter (like @kbd{C-l}) all three windows.
1073 Specify part of a prefix numeric argument.
1076 Also specify part of a prefix numeric argument.
1079 Choose the A version as the default from here down in
1083 Choose the B version as the default from here down in
1087 Copy the A version of this difference into the kill ring.
1090 Copy the B version of this difference into the kill ring.
1093 Insert the A version of this difference at point.
1096 Insert the B version of this difference at point.
1099 Put point and mark around the difference.
1102 Scroll all three windows down (like @kbd{M-v}).
1105 Scroll all three windows up (like @kbd{C-v}).
1108 Scroll all three windows left (like @kbd{C-x <}).
1111 Scroll all three windows right (like @kbd{C-x >}).
1114 Reset horizontal scroll on all three windows.
1117 Shrink the merge window to one line. (Use @kbd{C-u l} to restore it
1121 Combine the two versions of this difference (@pxref{Combining in
1125 Show the names of the files/buffers Emerge is operating on, in a Help
1126 window. (Use @kbd{C-u l} to restore windows.)
1129 Join this difference with the following one.
1130 (@kbd{C-u x j} joins this difference with the previous one.)
1133 Split this difference into two differences. Before you use this
1134 command, position point in each of the three buffers at the place where
1135 you want to split the difference.
1138 Trim identical lines off the top and bottom of the difference.
1139 Such lines occur when the A and B versions are
1140 identical but differ from the ancestor version.
1143 @node Exiting Emerge
1144 @subsection Exiting Emerge
1146 The @kbd{q} command (@code{emerge-quit}) finishes the merge, storing
1147 the results into the output file if you specified one. It restores the
1148 A and B buffers to their proper contents, or kills them if they were
1149 created by Emerge and you haven't changed them. It also disables the
1150 Emerge commands in the merge buffer, since executing them later could
1151 damage the contents of the various buffers.
1153 @kbd{C-]} aborts the merge. This means exiting without writing the
1154 output file. If you didn't specify an output file, then there is no
1155 real difference between aborting and finishing the merge.
1157 If the Emerge command was called from another Lisp program, then its
1158 return value is @code{t} for successful completion, or @code{nil} if you
1161 @node Combining in Emerge
1162 @subsection Combining the Two Versions
1164 Sometimes you want to keep @emph{both} alternatives for a particular
1165 difference. To do this, use @kbd{x c}, which edits the merge buffer
1171 @var{version from A buffer}
1173 @var{version from B buffer}
1174 #endif /* not NEW */
1179 @vindex emerge-combine-versions-template
1180 While this example shows C preprocessor conditionals delimiting the two
1181 alternative versions, you can specify the strings to use by setting
1182 the variable @code{emerge-combine-versions-template} to a string of your
1183 choice. In the string, @samp{%a} says where to put version A, and
1184 @samp{%b} says where to put version B. The default setting, which
1185 produces the results shown above, looks like this:
1189 "#ifdef NEW\n%a#else /* not NEW */\n%b#endif /* not NEW */\n"
1193 @node Fine Points of Emerge
1194 @subsection Fine Points of Emerge
1196 During the merge, you mustn't try to edit the A and B buffers yourself.
1197 Emerge modifies them temporarily, but ultimately puts them back the way
1200 You can have any number of merges going at once---just don't use any one
1201 buffer as input to more than one merge at once, since the temporary
1202 changes made in these buffers would get in each other's way.
1204 Starting Emerge can take a long time because it needs to compare the
1205 files fully. Emacs can't do anything else until @code{diff} finishes.
1206 Perhaps in the future someone will change Emerge to do the comparison in
1207 the background when the input files are large---then you could keep on
1208 doing other things with Emacs until Emerge is ready to accept
1211 @vindex emerge-startup-hook
1212 After setting up the merge, Emerge runs the hook
1213 @code{emerge-startup-hook} (@pxref{Hooks}).