*** empty log message ***
[emacs.git] / man / maintaining.texi
blob3ffd6dd5e7690c5612be2efcabe87ed2b986b4c7
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
6 @cindex Lisp editing
7 @cindex C editing
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
13 purpose.
15 @menu
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.
21 @end menu
23 @node Change Log
24 @section Change Logs
26 @cindex change log
27 @kindex C-x 4 a
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
42 subdirectories.
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:
52 @iftex
53 @medbreak
54 @end iftex
55 @smallexample
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.
68 @end smallexample
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
80 changed.
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
107 ordering of entries.
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:
114 @smallexample
115 Fri May 25 11:23:23 1993 Richard Stallman  <rms@@gnu.org>
116 @end smallexample
118 @noindent
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
123 versions of Emacs.
125   Version control systems are another way to keep track of changes in your
126 program and keep a change log.  @xref{Log Buffer}.
128 @node Authors
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.
137 @findex authors
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.
151 @node Tags
152 @section Tags Tables
153 @cindex tags table
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
177 @cindex tags, C++
178 @cindex class browser, C++
179 @cindex Ebrowse
180   See also the Ebrowse facility, which is tailored for C++.
181 @xref{Top,, Ebrowse, ebrowse, Ebrowse User's Manual}.
183 @menu
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.
191 @end menu
193 @node Tag Syntax
194 @subsection Source File Tag Syntax
196   Here is how tag syntax is defined for the most popular languages:
198 @itemize @bullet
199 @item
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
210 @code{etags}.
212 @item
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+}.
220 @item
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}}.
226 @item
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
231 tag.@refill
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,
238 @example
239 TEXTAGS="def:newcommand:newenvironment"
240 export TEXTAGS
241 @end example
243 @noindent
244 specifies (using Bourne shell syntax) that the commands @samp{\def},
245 @samp{\newcommand} and @samp{\newenvironment} also define tags.
247 @item
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
251 a tag.
253 @item
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.
257 @end itemize
259   Several other languages are also supported:
261 @itemize @bullet
263 @item
264 In Ada code, functions, procedures, packages, tasks, and types are
265 tags.  Use the @samp{--packages-only} option to create tags for
266 packages only.
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:
275 @table @samp
276 @item /b
277 package body.
278 @item /f
279 function.
280 @item /k
281 task.
282 @item /p
283 procedure.
284 @item /s
285 package spec.
286 @item /t
287 type.
288 @end table
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
293 @code{bidule}.
295 @item
296 In assembler code, labels appearing at the beginning of a line,
297 followed by a colon, are tags.
299 @item
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
302 as C code.
304 @item
305 In Cobol code, tags are paragraph names; that is, any word starting in
306 column 8 and followed by a period.
308 @item
309 In Erlang code, the tags are the functions, records, and macros defined
310 in the file.
312 @item
313 In Fortran code, functions, subroutines and blockdata are tags.
315 @item
316 In makefiles, targets are tags.
318 @item
319 In Objective C code, tags include Objective C definitions for classes,
320 class categories, methods, and protocols.
322 @item
323 In Pascal code, the tags are the functions and procedures defined in
324 the file.
326 @item
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.
331 @item
332 In PostScript code, the tags are the functions.
334 @item
335 In Prolog code, a tag name appears at the left margin.
337 @item
338 In Python code, @code{def} or @code{class} at the beginning of a line
339 generate a tag.
340 @end itemize
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
351 @iftex
352 the previous section.
353 @end iftex
354 @ifinfo
355 @ref{Tag Syntax}.
356 @end ifinfo
357 Here is how to run @code{etags}:
359 @example
360 etags @var{inputfiles}@dots{}
361 @end example
363 @noindent
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}
371 does not exist.
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
404 files.
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:
418 @smallexample
419 find . -name "*.[chCH]" -print | etags -
420 @end smallexample
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
434 explanation.
436 @node Etags Regexps
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:
444 @smallexample
445 --regex=/@var{tagregexp}[/@var{nameregexp}]/
446 @end smallexample
448 @noindent
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:
480 @smallexample
481 etags --regex=/@var{reg1}/ voo.doo --regex=/@var{reg2}/ \
482     bar.ber -R --lang=lisp los.er
483 @end smallexample
485 @noindent
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:
500 @smallexample
501 --regex='@{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/'
502 @end smallexample
504 @noindent
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
509 case.
511 @smallexample
512 --regex=@@first-file --ignore-case-regex=@@second-file
513 @end smallexample
515 @noindent
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
525 following contents:
527 @smallexample
528         -- This is for GNU Emacs C source files
529 @{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/\1/
530 @end smallexample
532 @noindent
533 and then use it like this:
535 @smallexample
536 etags --regex=@@emacs.tags *.[ch] */*.[ch]
537 @end smallexample
539   Here are some more examples.  The regexps are quoted to protect them
540 from shell interpretation.
542 @itemize @bullet
544 @item
545 Tag Octave files:
547 @smallexample
548 etags --language=none \
549       --regex='/[ \t]*function.*=[ \t]*\([^ \t]*\)[ \t]*(/\1/' \
550       --regex='/###key \(.*\)/\1/' \
551       --regex='/[ \t]*global[ \t].*/' \
552       *.m
553 @end smallexample
555 @noindent
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
558 want to jump to it.
560 @item
561 Tag Tcl files:
563 @smallexample
564 etags --language=none --regex='/proc[ \t]+\([^ \t]+\)/\1/' *.tcl
565 @end smallexample
567 @item
568 Tag VHDL files:
570 @smallexample
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/'
575 @end smallexample
576 @end itemize
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
587 default file name.
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
613 @example
614 @group
615 (setq tags-table-list
616       '("~/emacs" "/usr/local/lib/emacs/src"))
617 @end group
618 @end example
620 @noindent
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}.
628 @node Find Tag
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.
634 @table @kbd
635 @item M-.@: @var{tag} @key{RET}
636 Find first definition of @var{tag} (@code{find-tag}).
637 @item C-u M-.
638 Find next alternate definition of last tag specified.
639 @item C-u - M-.
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}).
643 @item C-u C-M-.
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}).
651 @item M-*
652 Pop back to where you previously invoked @kbd{M-.} and friends.
653 @end table
655 @kindex M-.
656 @findex find-tag
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-.}.
679 @kindex C-x 4 .
680 @findex find-tag-other-window
681 @kindex C-x 5 .
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.
694 @kindex M-*
695 @findex pop-tag-mark
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
707 @kindex C-M-.
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.
712 @node Tags Search
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.
721 @table @kbd
722 @item M-x tags-search @key{RET} @var{regexp} @key{RET}
723 Search for @var{regexp} through the files in the selected tags
724 table.
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.
727 @item M-,
728 Restart one of the commands above, from the current location of point
729 (@code{tags-loop-continue}).
730 @end table
732 @findex tags-search
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.
739 @kindex M-,
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
773 the current buffer.
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
778 continue to exist.
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.
785 @xref{Compilation}.
787 @node List Tags
788 @subsection Tags Table Inquiries
790 @table @kbd
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}.
795 @end table
797 @findex list-tags
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
806 directory.
808 @findex tags-apropos
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
822 details.
824   You can also use the collection of tag names to complete a symbol
825 name in the buffer.  @xref{Symbol Completion}.
827 @node Emerge
828 @section Merging Files with Emerge
829 @cindex 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}.
838 @menu
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
843                           for each difference.
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.
849 @end menu
851 @node Overview of Emerge
852 @subsection Overview of Emerge
854 To start Emerge, run one of these four commands:
856 @table @kbd
857 @item M-x emerge-files
858 @findex 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
867 Merge two 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
872 buffer.
873 @end table
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
886 (@pxref{Narrowing}).
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:
912 @example
913 vvvvvvvvvvvvvvvvvvvv
914 @var{text that differs}
915 ^^^^^^^^^^^^^^^^^^^^
916 @end example
918 @noindent
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}
950 and @samp{F}.
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
964 @samp{S}.
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:
980 @table @asis
981 @item A
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}.
985 @item B
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}.
989 @item default-A
990 @itemx default-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
999 the mode line.
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.
1010 @item prefer-A
1011 @itemx prefer-B
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*}.
1021 @item combined
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}.
1029 @end table
1031 @node Merge Commands
1032 @subsection Merge Commands
1034   Here are the Merge commands for Fast mode; in Edit mode, precede them
1035 with @kbd{C-c C-c}:
1037 @table @kbd
1038 @item p
1039 Select the previous difference.
1041 @item n
1042 Select the next difference.
1044 @item a
1045 Choose the A version of this difference.
1047 @item b
1048 Choose the B version of this difference.
1050 @item C-u @var{n} j
1051 Select difference number @var{n}.
1053 @item .
1054 Select the difference containing point.  You can use this command in the
1055 merge buffer or in the A or B buffer.
1057 @item q
1058 Quit---finish the merge.
1060 @item C-]
1061 Abort---exit merging and do not save the output.
1063 @item f
1064 Go into Fast mode.  (In Edit mode, this is actually @kbd{C-c C-c f}.)
1066 @item e
1067 Go into Edit mode.
1069 @item l
1070 Recenter (like @kbd{C-l}) all three windows.
1072 @item -
1073 Specify part of a prefix numeric argument.
1075 @item @var{digit}
1076 Also specify part of a prefix numeric argument.
1078 @item d a
1079 Choose the A version as the default from here down in
1080 the merge buffer.
1082 @item d b
1083 Choose the B version as the default from here down in
1084 the merge buffer.
1086 @item c a
1087 Copy the A version of this difference into the kill ring.
1089 @item c b
1090 Copy the B version of this difference into the kill ring.
1092 @item i a
1093 Insert the A version of this difference at point.
1095 @item i b
1096 Insert the B version of this difference at point.
1098 @item m
1099 Put point and mark around the difference.
1101 @item ^
1102 Scroll all three windows down (like @kbd{M-v}).
1104 @item v
1105 Scroll all three windows up (like @kbd{C-v}).
1107 @item <
1108 Scroll all three windows left (like @kbd{C-x <}).
1110 @item >
1111 Scroll all three windows right (like @kbd{C-x >}).
1113 @item |
1114 Reset horizontal scroll on all three windows.
1116 @item x 1
1117 Shrink the merge window to one line.  (Use @kbd{C-u l} to restore it
1118 to full size.)
1120 @item x c
1121 Combine the two versions of this difference (@pxref{Combining in
1122 Emerge}).
1124 @item x f
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.)
1128 @item x j
1129 Join this difference with the following one.
1130 (@kbd{C-u x j} joins this difference with the previous one.)
1132 @item x s
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.
1137 @item x t
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.
1141 @end table
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
1159 abort.
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
1166 like this:
1168 @example
1169 @group
1170 #ifdef NEW
1171 @var{version from A buffer}
1172 #else /* not NEW */
1173 @var{version from B buffer}
1174 #endif /* not NEW */
1175 @end group
1176 @end example
1178 @noindent
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:
1187 @example
1188 @group
1189 "#ifdef NEW\n%a#else /* not NEW */\n%b#endif /* not NEW */\n"
1190 @end group
1191 @end example
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
1198 they were.
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
1209 commands.
1211 @vindex emerge-startup-hook
1212   After setting up the merge, Emerge runs the hook
1213 @code{emerge-startup-hook} (@pxref{Hooks}).