]> code.delx.au - gnu-emacs/blob - man/maintaining.texi
(x_clip_to_row): Add area arg. Callers changed.
[gnu-emacs] / man / maintaining.texi
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
9
10 This chapter describes Emacs features for maintaining programs. The
11 version control features (@pxref{Version Control}) are also
12 particularly useful for this purpose.
13
14 @menu
15 * Change Log:: Maintaining a change history for your program.
16 * Tags:: Go direct to any function in your program in one
17 command. Tags remembers which file it is in.
18 * Emerge:: A convenient way of merging two versions of a program.
19 @end menu
20
21 @node Change Log
22 @section Change Logs
23
24 @cindex change log
25 @kindex C-x 4 a
26 @findex add-change-log-entry-other-window
27 The Emacs command @kbd{C-x 4 a} adds a new entry to the change log
28 file for the file you are editing
29 (@code{add-change-log-entry-other-window}). If that file is actually
30 a backup file, it makes an entry appropriate for the file's
31 parent---that is useful for making log entries for functions that
32 have been deleted in the current version.
33
34 A change log file contains a chronological record of when and why you
35 have changed a program, consisting of a sequence of entries describing
36 individual changes. Normally it is kept in a file called
37 @file{ChangeLog} in the same directory as the file you are editing, or
38 one of its parent directories. A single @file{ChangeLog} file can
39 record changes for all the files in its directory and all its
40 subdirectories.
41
42 You should put a copyright notice and permission notice at the
43 end of the change log file. Here is an example:
44
45 @example
46 Copyright 1997, 1998 Free Software Foundation, Inc.
47 Copying and distribution of this file, with or without modification, are
48 permitted provided the copyright notice and this notice are preserved.
49 @end example
50
51 @noindent
52 Of course, you should substitute the proper years and copyright holder.
53
54 A change log entry starts with a header line that contains the
55 current date, your name, and your email address (taken from the
56 variable @code{user-mail-address}). Aside from these header lines,
57 every line in the change log starts with a space or a tab. The bulk
58 of the entry consists of @dfn{items}, each of which starts with a line
59 starting with whitespace and a star. Here are two entries, both dated
60 in May 1993, each with two items:
61
62 @iftex
63 @medbreak
64 @end iftex
65 @smallexample
66 1993-05-25 Richard Stallman <rms@@gnu.org>
67
68 * man.el: Rename symbols `man-*' to `Man-*'.
69 (manual-entry): Make prompt string clearer.
70
71 * simple.el (blink-matching-paren-distance):
72 Change default to 12,000.
73
74 1993-05-24 Richard Stallman <rms@@gnu.org>
75
76 * vc.el (minor-mode-map-alist): Don't use it if it's void.
77 (vc-cancel-version): Doc fix.
78 @end smallexample
79
80 One entry can describe several changes; each change should have its
81 own item. Normally there should be a blank line between items. When
82 items are related (parts of the same change, in different places), group
83 them by leaving no blank line between them. The second entry above
84 contains two items grouped in this way.
85
86 @kbd{C-x 4 a} visits the change log file and creates a new entry
87 unless the most recent entry is for today's date and your name. It
88 also creates a new item for the current file. For many languages, it
89 can even guess the name of the function or other object that was
90 changed.
91
92 @vindex add-log-keep-changes-together
93 When the option @code{add-log-keep-changes-together} is
94 non-@code{nil}, @kbd{C-x 4 a} adds to any existing entry for the file
95 rather than starting a new entry.
96
97 @vindex change-log-version-info-enabled
98 @vindex change-log-version-number-regexp-list
99 @cindex file version in change log entries
100 If the value of the variable @code{change-log-version-info-enabled}
101 is non-@code{nil}, @kbd{C-x 4 a} adds the file's version number to the
102 change log entry. It finds the version number by searching the first
103 ten percent of the file, using regular expressions from the variable
104 @code{change-log-version-number-regexp-list}.
105
106 @vindex add-log-always-start-new-record
107 If @code{add-log-always-start-new-record} is non-@code{nil},
108 @kbd{C-x 4 a} always makes a new entry, even if the last entry
109 was made by you and on the same date.
110
111 @cindex Change Log mode
112 @findex change-log-mode
113 The change log file is visited in Change Log mode. In this major
114 mode, each bunch of grouped items counts as one paragraph, and each
115 entry is considered a page. This facilitates editing the entries.
116 @kbd{C-j} and auto-fill indent each new line like the previous line;
117 this is convenient for entering the contents of an entry.
118
119 @findex change-log-merge
120 You can use the command @kbd{M-x change-log-merge} to merge other
121 log files into a buffer in Change Log Mode, preserving the date
122 ordering of entries.
123
124 @findex change-log-redate
125 @cindex converting change log date style
126 Versions of Emacs before 20.1 used a different format for the time of
127 the change log entry:
128
129 @smallexample
130 Fri May 25 11:23:23 1993 Richard Stallman <rms@@gnu.org>
131 @end smallexample
132
133 @noindent
134 The @kbd{M-x change-log-redate} command converts all the old-style
135 date entries in the change log file visited in the current buffer to
136 the new format, to make the file uniform in style. This is handy when
137 entries are contributed by many different people, some of whom use old
138 versions of Emacs.
139
140 Version control systems are another way to keep track of changes in your
141 program and keep a change log. @xref{Log Buffer}.
142
143 @ignore
144 @c This is commented out because the command is specific
145 @c to maintenance of Emacs itself.
146
147 @node Authors
148 @section @file{AUTHORS} files
149 @cindex @file{AUTHORS} file
150
151 Programs which have many contributors usually include a file named
152 @file{AUTHORS} in their distribution, which lists the individual
153 contributions. Emacs has a special command for maintaining the
154 @file{AUTHORS} file that is part of the Emacs distribution.
155
156 @findex authors
157 The @kbd{M-x authors} command prompts for the name of the root of the
158 Emacs source directory. It then scans @file{ChangeLog} files and Lisp
159 source files under that directory for information about authors of
160 individual packages, and people who made changes in source files, and
161 puts the information it gleans into a buffer named @samp{*Authors*}.
162 You can then edit the contents of that buffer and merge it with the
163 existing @file{AUTHORS} file.
164
165 Do not assume that this command finds all the contributors; don't
166 assume that a person not listed in the output was not a contributor.
167 If you merged in someone's contribution and did not put his name
168 in the change log, he won't show up in @kbd{M-x authors} either.
169 @end ignore
170
171 @node Tags
172 @section Tags Tables
173 @cindex tags table
174
175 A @dfn{tags table} is a description of how a multi-file program is
176 broken up into files. It lists the names of the component files and the
177 names and positions of the functions (or other named subunits) in each
178 file. Grouping the related files makes it possible to search or replace
179 through all the files with one command. Recording the function names
180 and positions makes possible the @kbd{M-.} command which finds the
181 definition of a function by looking up which of the files it is in.
182
183 Tags tables are stored in files called @dfn{tags table files}. The
184 conventional name for a tags table file is @file{TAGS}.
185
186 Each entry in the tags table records the name of one tag, the name of the
187 file that the tag is defined in (implicitly), and the position in that
188 file of the tag's definition. When a file parsed by @code{etags} is
189 generated from a different source file, like a C file generated from a
190 Cweb source file, the tags of the parsed file reference the source
191 file.
192
193 Just what names from the described files are recorded in the tags table
194 depends on the programming language of the described file. They
195 normally include all file names, functions and subroutines, and may
196 also include global variables, data types, and anything else
197 convenient. Each name recorded is called a @dfn{tag}.
198
199 @cindex C++ class browser, tags
200 @cindex tags, C++
201 @cindex class browser, C++
202 @cindex Ebrowse
203 See also the Ebrowse facility, which is tailored for C++.
204 @xref{Top,, Ebrowse, ebrowse, Ebrowse User's Manual}.
205
206 @menu
207 * Tag Syntax:: Tag syntax for various types of code and text files.
208 * Create Tags Table:: Creating a tags table with @code{etags}.
209 * Etags Regexps:: Create arbitrary tags using regular expressions.
210 * Select Tags Table:: How to visit a tags table.
211 * Find Tag:: Commands to find the definition of a specific tag.
212 * Tags Search:: Using a tags table for searching and replacing.
213 * List Tags:: Listing and finding tags defined in a file.
214 @end menu
215
216 @node Tag Syntax
217 @subsection Source File Tag Syntax
218
219 Here is how tag syntax is defined for the most popular languages:
220
221 @itemize @bullet
222 @item
223 In C code, any C function or typedef is a tag, and so are definitions of
224 @code{struct}, @code{union} and @code{enum}.
225 @code{#define} macro definitions and @code{enum} constants are also
226 tags, unless you specify @samp{--no-defines} when making the tags table.
227 Similarly, global variables are tags, unless you specify
228 @samp{--no-globals}. Use of @samp{--no-globals} and @samp{--no-defines}
229 can make the tags table file much smaller.
230
231 You can tag function declarations and external variables in addition
232 to function definitions by giving the @samp{--declarations} option to
233 @code{etags}. You can tag struct members with the @samp{--members}
234 option.
235
236 @item
237 In C++ code, in addition to all the tag constructs of C code, member
238 functions are also recognized, and optionally member variables if you
239 use the @samp{--members} option. Tags for variables and functions in
240 classes are named @samp{@var{class}::@var{variable}} and
241 @samp{@var{class}::@var{function}}. @code{operator} definitions have
242 tag names like @samp{operator+}.
243
244 @item
245 In Java code, tags include all the constructs recognized in C++, plus
246 the @code{interface}, @code{extends} and @code{implements} constructs.
247 Tags for variables and functions in classes are named
248 @samp{@var{class}.@var{variable}} and @samp{@var{class}.@var{function}}.
249
250 @item
251 In La@TeX{} text, the argument of any of the commands @code{\chapter},
252 @code{\section}, @code{\subsection}, @code{\subsubsection},
253 @code{\eqno}, @code{\label}, @code{\ref}, @code{\cite},
254 @code{\bibitem}, @code{\part}, @code{\appendix}, @code{\entry},
255 @code{\index}, @code{\def}, @code{\newcommand}, @code{\renewcommand},
256 @code{\newenvironment} or @code{\renewenvironment} is a tag.@refill
257
258 Other commands can make tags as well, if you specify them in the
259 environment variable @env{TEXTAGS} before invoking @code{etags}. The
260 value of this environment variable should be a colon-separated list of
261 command names. For example,
262
263 @example
264 TEXTAGS="mycommand:myothercommand"
265 export TEXTAGS
266 @end example
267
268 @noindent
269 specifies (using Bourne shell syntax) that the commands
270 @samp{\mycommand} and @samp{\myothercommand} also define tags.
271
272 @item
273 In Lisp code, any function defined with @code{defun}, any variable
274 defined with @code{defvar} or @code{defconst}, and in general the first
275 argument of any expression that starts with @samp{(def} in column zero is
276 a tag.
277
278 @item
279 In Scheme code, tags include anything defined with @code{def} or with a
280 construct whose name starts with @samp{def}. They also include variables
281 set with @code{set!} at top level in the file.
282 @end itemize
283
284 Several other languages are also supported:
285
286 @itemize @bullet
287
288 @item
289 In Ada code, functions, procedures, packages, tasks and types are
290 tags. Use the @samp{--packages-only} option to create tags for
291 packages only.
292
293 In Ada, the same name can be used for different kinds of entity
294 (e.g.@:, for a procedure and for a function). Also, for things like
295 packages, procedures and functions, there is the spec (i.e.@: the
296 interface) and the body (i.e.@: the implementation). To make it
297 easier to pick the definition you want, Ada tag name have suffixes
298 indicating the type of entity:
299
300 @table @samp
301 @item /b
302 package body.
303 @item /f
304 function.
305 @item /k
306 task.
307 @item /p
308 procedure.
309 @item /s
310 package spec.
311 @item /t
312 type.
313 @end table
314
315 Thus, @kbd{M-x find-tag @key{RET} bidule/b @key{RET}} will go
316 directly to the body of the package @code{bidule}, while @kbd{M-x
317 find-tag @key{RET} bidule @key{RET}} will just search for any tag
318 @code{bidule}.
319
320 @item
321 In assembler code, labels appearing at the beginning of a line,
322 followed by a colon, are tags.
323
324 @item
325 In Bison or Yacc input files, each rule defines as a tag the nonterminal
326 it constructs. The portions of the file that contain C code are parsed
327 as C code.
328
329 @item
330 In Cobol code, tags are paragraph names; that is, any word starting in
331 column 8 and followed by a period.
332
333 @item
334 In Erlang code, the tags are the functions, records and macros defined
335 in the file.
336
337 @item
338 In Fortran code, functions, subroutines and block data are tags.
339
340 @item
341 In HTML input files, the tags are the @code{title} and the @code{h1},
342 @code{h2}, @code{h3} headers. Also, tags are @code{name=} in anchors
343 and all occurrences of @code{id=}.
344
345 @item
346 In Lua input files, all functions are tags.
347
348 @item
349 In makefiles, targets are tags; additionally, variables are tags
350 unless you specify @samp{--no-globals}.
351
352 @item
353 In Objective C code, tags include Objective C definitions for classes,
354 class categories, methods and protocols. Tags for variables and
355 functions in classes are named @samp{@var{class}::@var{variable}} and
356 @samp{@var{class}::@var{function}}.
357
358 @item
359 In Pascal code, the tags are the functions and procedures defined in
360 the file.
361
362 @item
363 In Perl code, the tags are the packages, subroutines and variables
364 defined by the @code{package}, @code{sub}, @code{my} and @code{local}
365 keywords. Use @samp{--globals} if you want to tag global variables.
366 Tags for subroutines are named @samp{@var{package}::@var{sub}}. The
367 name for subroutines defined in the default package is
368 @samp{main::@var{sub}}.
369
370 @item
371 In PHP code, tags are functions, classes and defines. When using the
372 @samp{--members} option, vars are tags too.
373
374 @item
375 In PostScript code, the tags are the functions.
376
377 @item
378 In Prolog code, tags are predicates and rules at the beginning of
379 line.
380
381 @item
382 In Python code, @code{def} or @code{class} at the beginning of a line
383 generate a tag.
384 @end itemize
385
386 You can also generate tags based on regexp matching (@pxref{Etags
387 Regexps}) to handle other formats and languages.
388
389 @node Create Tags Table
390 @subsection Creating Tags Tables
391 @cindex @code{etags} program
392
393 The @code{etags} program is used to create a tags table file. It knows
394 the syntax of several languages, as described in
395 @iftex
396 the previous section.
397 @end iftex
398 @ifinfo
399 @ref{Tag Syntax}.
400 @end ifinfo
401 Here is how to run @code{etags}:
402
403 @example
404 etags @var{inputfiles}@dots{}
405 @end example
406
407 @noindent
408 The @code{etags} program reads the specified files, and writes a tags
409 table named @file{TAGS} in the current working directory.
410
411 If the specified files don't exist, @code{etags} looks for
412 compressed versions of them and uncompresses them to read them. Under
413 MS-DOS, @code{etags} also looks for file names like @file{mycode.cgz}
414 if it is given @samp{mycode.c} on the command line and @file{mycode.c}
415 does not exist.
416
417 @code{etags} recognizes the language used in an input file based on
418 its file name and contents. You can specify the language with the
419 @samp{--language=@var{name}} option, described below.
420
421 If the tags table data become outdated due to changes in the files
422 described in the table, the way to update the tags table is the same
423 way it was made in the first place. If the tags table fails to record
424 a tag, or records it for the wrong file, then Emacs cannot possibly
425 find its definition until you update the tags table. However, if the
426 position recorded in the tags table becomes a little bit wrong (due to
427 other editing), the only consequence is a slight delay in finding the
428 tag. Even if the stored position is very far wrong, Emacs will still
429 find the tag, after searching most of the file for it. Even that
430 delay is hardly noticeable with today's computers.
431
432 So you should update a tags table when you define new tags that you want
433 to have listed, or when you move tag definitions from one file to another,
434 or when changes become substantial. Normally there is no need to update
435 the tags table after each edit, or even every day.
436
437 One tags table can virtually include another. Specify the included
438 tags file name with the @samp{--include=@var{file}} option when
439 creating the file that is to include it. The latter file then acts as
440 if it covered all the source files specified in the included file, as
441 well as the files it directly contains.
442
443 If you specify the source files with relative file names when you run
444 @code{etags}, the tags file will contain file names relative to the
445 directory where the tags file was initially written. This way, you can
446 move an entire directory tree containing both the tags file and the
447 source files, and the tags file will still refer correctly to the source
448 files. If the tags file is in @file{/dev}, however, the file names are
449 made relative to the current working directory.
450
451 If you specify absolute file names as arguments to @code{etags}, then
452 the tags file will contain absolute file names. This way, the tags file
453 will still refer to the same files even if you move it, as long as the
454 source files remain in the same place. Absolute file names start with
455 @samp{/}, or with @samp{@var{device}:/} on MS-DOS and MS-Windows.
456
457 When you want to make a tags table from a great number of files, you
458 may have problems listing them on the command line, because some systems
459 have a limit on its length. The simplest way to circumvent this limit
460 is to tell @code{etags} to read the file names from its standard input,
461 by typing a dash in place of the file names, like this:
462
463 @smallexample
464 find . -name "*.[chCH]" -print | etags -
465 @end smallexample
466
467 Use the option @samp{--language=@var{name}} to specify the language
468 explicitly. You can intermix these options with file names; each one
469 applies to the file names that follow it. Specify
470 @samp{--language=auto} to tell @code{etags} to resume guessing the
471 language from the file names and file contents. Specify
472 @samp{--language=none} to turn off language-specific processing
473 entirely; then @code{etags} recognizes tags by regexp matching alone
474 (@pxref{Etags Regexps}).
475
476 The option @samp{--parse-stdin=@var{file}} is mostly useful when
477 calling @code{etags} from programs. It can be used (only once) in
478 place of a file name on the command line. @code{Etags} will read from
479 standard input and mark the produced tags as belonging to the file
480 @var{file}.
481
482 @samp{etags --help} prints the list of the languages @code{etags}
483 knows, and the file name rules for guessing the language. It also prints
484 a list of all the available @code{etags} options, together with a short
485 explanation. If followed by one or more @samp{--language=@var{lang}}
486 options, prints detailed information about how tags are generated for
487 @var{lang}.
488
489 @node Etags Regexps
490 @subsection Etags Regexps
491
492 The @samp{--regex} option provides a general way of recognizing tags
493 based on regexp matching. You can freely intermix it with file names.
494 If you specify multiple @samp{--regex} options, all of them are used
495 in parallel, but each one applies only to the source files that follow
496 it. The syntax is:
497
498 @smallexample
499 --regex=[@var{@{language@}}]/@var{tagregexp}/[@var{nameregexp}/]@var{modifiers}
500 @end smallexample
501
502 The essential part of the option value is @var{tagregexp}, the
503 regexp for matching tags. It is always used anchored, that is, it
504 only matches at the beginning of a line. If you want to allow
505 indented tags, use a regexp that matches initial whitespace; start it
506 with @samp{[ \t]*}.
507
508 In these regular expressions, @samp{\} quotes the next character, and
509 all the GCC character escape sequences are supported (@samp{\a} for
510 bell, @samp{\b} for back space, @samp{\d} for delete, @samp{\e} for
511 escape, @samp{\f} for formfeed, @samp{\n} for newline, @samp{\r} for
512 carriage return, @samp{\t} for tab, and @samp{\v} for vertical tab).
513
514 Ideally, @var{tagregexp} should not match more characters than are
515 needed to recognize what you want to tag. If the syntax requires you
516 to write @var{tagregexp} so it matches more characters beyond the tag
517 itself, you should add a @var{nameregexp}, to pick out just the tag.
518 This will enable Emacs to find tags more accurately and to do
519 completion on tag names more reliably. You can find some examples
520 below.
521
522 The @var{modifiers} are a sequence of zero or more characters that
523 modify the way @code{etags} does the matching. A regexp with no
524 modifiers is applied sequentially to each line of the input file, in a
525 case-sensitive way. The modifiers and their meanings are:
526
527 @table @samp
528 @item i
529 Ignore case when matching this regexp.
530 @item m
531 Match this regular expression against the whole file, so that
532 multi-line matches are possible.
533 @item s
534 Match this regular expression against the whole file, and allow
535 @samp{.} in @var{tagregexp} to match newlines.
536 @end table
537
538 The @samp{-R} option cancels all the regexps defined by preceding
539 @samp{--regex} options. It applies to the file names following it, as
540 you can see from the following example:
541
542 @smallexample
543 etags --regex=/@var{reg1}/i voo.doo --regex=/@var{reg2}/m \
544 bar.ber -R --lang=lisp los.er
545 @end smallexample
546
547 @noindent
548 Here @code{etags} chooses the parsing language for @file{voo.doo} and
549 @file{bar.ber} according to their contents. @code{etags} also uses
550 @var{reg1} to recognize additional tags in @file{voo.doo}, and both
551 @var{reg1} and @var{reg2} to recognize additional tags in
552 @file{bar.ber}. @var{reg1} is checked against each line of
553 @file{voo.doo} and @file{bar.ber}, in a case-insensitive way, while
554 @var{reg2} is checked against the whole @file{bar.ber} file,
555 permitting multi-line matches, in a case-sensitive way. @code{etags}
556 uses only the Lisp tags rules, with no user-specified regexp matching,
557 to recognize tags in @file{los.er}.
558
559 You can restrict a @samp{--regex} option to match only files of a
560 given language by using the optional prefix @var{@{language@}}.
561 (@samp{etags --help} prints the list of languages recognized by
562 @code{etags}.) This is particularly useful when storing many
563 predefined regular expressions for @code{etags} in a file. The
564 following example tags the @code{DEFVAR} macros in the Emacs source
565 files, for the C language only:
566
567 @smallexample
568 --regex='@{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/'
569 @end smallexample
570
571 @noindent
572 When you have complex regular expressions, you can store the list of
573 them in a file. The following option syntax instructs @code{etags} to
574 read two files of regular expressions. The regular expressions
575 contained in the second file are matched without regard to case.
576
577 @smallexample
578 --regex=@@@var{case-sensitive-file} --ignore-case-regex=@@@var{ignore-case-file}
579 @end smallexample
580
581 @noindent
582 A regex file for @code{etags} contains one regular expression per
583 line. Empty lines, and lines beginning with space or tab are ignored.
584 When the first character in a line is @samp{@@}, @code{etags} assumes
585 that the rest of the line is the name of another file of regular
586 expressions; thus, one such file can include another file. All the
587 other lines are taken to be regular expressions. If the first
588 non-whitespace text on the line is @samp{--}, that line is a comment.
589
590 For example, we can create a file called @samp{emacs.tags} with the
591 following contents:
592
593 @smallexample
594 -- This is for GNU Emacs C source files
595 @{c@}/[ \t]*DEFVAR_[A-Z_ \t(]+"\([^"]+\)"/\1/
596 @end smallexample
597
598 @noindent
599 and then use it like this:
600
601 @smallexample
602 etags --regex=@@emacs.tags *.[ch] */*.[ch]
603 @end smallexample
604
605 Here are some more examples. The regexps are quoted to protect them
606 from shell interpretation.
607
608 @itemize @bullet
609
610 @item
611 Tag Octave files:
612
613 @smallexample
614 etags --language=none \
615 --regex='/[ \t]*function.*=[ \t]*\([^ \t]*\)[ \t]*(/\1/' \
616 --regex='/###key \(.*\)/\1/' \
617 --regex='/[ \t]*global[ \t].*/' \
618 *.m
619 @end smallexample
620
621 @noindent
622 Note that tags are not generated for scripts, so that you have to add
623 a line by yourself of the form @samp{###key @var{scriptname}} if you
624 want to jump to it.
625
626 @item
627 Tag Tcl files:
628
629 @smallexample
630 etags --language=none --regex='/proc[ \t]+\([^ \t]+\)/\1/' *.tcl
631 @end smallexample
632
633 @item
634 Tag VHDL files:
635
636 @smallexample
637 etags --language=none \
638 --regex='/[ \t]*\(ARCHITECTURE\|CONFIGURATION\) +[^ ]* +OF/' \
639 --regex='/[ \t]*\(ATTRIBUTE\|ENTITY\|FUNCTION\|PACKAGE\
640 \( BODY\)?\|PROCEDURE\|PROCESS\|TYPE\)[ \t]+\([^ \t(]+\)/\3/'
641 @end smallexample
642 @end itemize
643
644 @node Select Tags Table
645 @subsection Selecting a Tags Table
646
647 @vindex tags-file-name
648 @findex visit-tags-table
649 Emacs has at any time one @dfn{selected} tags table, and all the commands
650 for working with tags tables use the selected one. To select a tags table,
651 type @kbd{M-x visit-tags-table}, which reads the tags table file name as an
652 argument. The name @file{TAGS} in the default directory is used as the
653 default file name.
654
655 All this command does is store the file name in the variable
656 @code{tags-file-name}. Emacs does not actually read in the tags table
657 contents until you try to use them. Setting this variable yourself is just
658 as good as using @code{visit-tags-table}. The variable's initial value is
659 @code{nil}; that value tells all the commands for working with tags tables
660 that they must ask for a tags table file name to use.
661
662 Using @code{visit-tags-table} when a tags table is already loaded
663 gives you a choice: you can add the new tags table to the current list
664 of tags tables, or start a new list. The tags commands use all the tags
665 tables in the current list. If you start a new list, the new tags table
666 is used @emph{instead} of others. If you add the new table to the
667 current list, it is used @emph{as well as} the others. When the tags
668 commands scan the list of tags tables, they don't always start at the
669 beginning of the list; they start with the first tags table (if any)
670 that describes the current file, proceed from there to the end of the
671 list, and then scan from the beginning of the list until they have
672 covered all the tables in the list.
673
674 @vindex tags-table-list
675 You can specify a precise list of tags tables by setting the variable
676 @code{tags-table-list} to a list of strings, like this:
677
678 @c keep this on two lines for formatting in smallbook
679 @example
680 @group
681 (setq tags-table-list
682 '("~/emacs" "/usr/local/lib/emacs/src"))
683 @end group
684 @end example
685
686 @noindent
687 This tells the tags commands to look at the @file{TAGS} files in your
688 @file{~/emacs} directory and in the @file{/usr/local/lib/emacs/src}
689 directory. The order depends on which file you are in and which tags
690 table mentions that file, as explained above.
691
692 Do not set both @code{tags-file-name} and @code{tags-table-list}.
693
694 @node Find Tag
695 @subsection Finding a Tag
696
697 The most important thing that a tags table enables you to do is to find
698 the definition of a specific tag.
699
700 @table @kbd
701 @item M-.@: @var{tag} @key{RET}
702 Find first definition of @var{tag} (@code{find-tag}).
703 @item C-u M-.
704 Find next alternate definition of last tag specified.
705 @item C-u - M-.
706 Go back to previous tag found.
707 @item C-M-. @var{pattern} @key{RET}
708 Find a tag whose name matches @var{pattern} (@code{find-tag-regexp}).
709 @item C-u C-M-.
710 Find the next tag whose name matches the last pattern used.
711 @item C-x 4 .@: @var{tag} @key{RET}
712 Find first definition of @var{tag}, but display it in another window
713 (@code{find-tag-other-window}).
714 @item C-x 5 .@: @var{tag} @key{RET}
715 Find first definition of @var{tag}, and create a new frame to select the
716 buffer (@code{find-tag-other-frame}).
717 @item M-*
718 Pop back to where you previously invoked @kbd{M-.} and friends.
719 @end table
720
721 @kindex M-.
722 @findex find-tag
723 @kbd{M-.}@: (@code{find-tag}) is the command to find the definition of
724 a specified tag. It searches through the tags table for that tag, as a
725 string, and then uses the tags table info to determine the file that the
726 definition is in and the approximate character position in the file of
727 the definition. Then @code{find-tag} visits that file, moves point to
728 the approximate character position, and searches ever-increasing
729 distances away to find the tag definition.
730
731 If an empty argument is given (just type @key{RET}), the balanced
732 expression in the buffer before or around point is used as the
733 @var{tag} argument. @xref{Expressions}.
734
735 You don't need to give @kbd{M-.} the full name of the tag; a part
736 will do. This is because @kbd{M-.} finds tags in the table which
737 contain @var{tag} as a substring. However, it prefers an exact match
738 to a substring match. To find other tags that match the same
739 substring, give @code{find-tag} a numeric argument, as in @kbd{C-u
740 M-.}; this does not read a tag name, but continues searching the tags
741 table's text for another tag containing the same substring last used.
742 If you have a real @key{META} key, @kbd{M-0 M-.}@: is an easier
743 alternative to @kbd{C-u M-.}.
744
745 @kindex C-x 4 .
746 @findex find-tag-other-window
747 @kindex C-x 5 .
748 @findex find-tag-other-frame
749 Like most commands that can switch buffers, @code{find-tag} has a
750 variant that displays the new buffer in another window, and one that
751 makes a new frame for it. The former is @kbd{C-x 4 .}, which invokes
752 the command @code{find-tag-other-window}. The latter is @kbd{C-x 5 .},
753 which invokes @code{find-tag-other-frame}.
754
755 To move back to places you've found tags recently, use @kbd{C-u -
756 M-.}; more generally, @kbd{M-.} with a negative numeric argument. This
757 command can take you to another buffer. @kbd{C-x 4 .} with a negative
758 argument finds the previous tag location in another window.
759
760 @kindex M-*
761 @findex pop-tag-mark
762 @vindex find-tag-marker-ring-length
763 As well as going back to places you've found tags recently, you can go
764 back to places @emph{from where} you found them. Use @kbd{M-*}, which
765 invokes the command @code{pop-tag-mark}, for this. Typically you would
766 find and study the definition of something with @kbd{M-.} and then
767 return to where you were with @kbd{M-*}.
768
769 Both @kbd{C-u - M-.} and @kbd{M-*} allow you to retrace your steps to
770 a depth determined by the variable @code{find-tag-marker-ring-length}.
771
772 @findex find-tag-regexp
773 @kindex C-M-.
774 The command @kbd{C-M-.} (@code{find-tag-regexp}) visits the tags that
775 match a specified regular expression. It is just like @kbd{M-.} except
776 that it does regexp matching instead of substring matching.
777
778 @node Tags Search
779 @subsection Searching and Replacing with Tags Tables
780 @cindex search and replace in multiple files
781 @cindex multiple-file search and replace
782
783 The commands in this section visit and search all the files listed in the
784 selected tags table, one by one. For these commands, the tags table serves
785 only to specify a sequence of files to search.
786
787 @table @kbd
788 @item M-x tags-search @key{RET} @var{regexp} @key{RET}
789 Search for @var{regexp} through the files in the selected tags
790 table.
791 @item M-x tags-query-replace @key{RET} @var{regexp} @key{RET} @var{replacement} @key{RET}
792 Perform a @code{query-replace-regexp} on each file in the selected tags table.
793 @item M-,
794 Restart one of the commands above, from the current location of point
795 (@code{tags-loop-continue}).
796 @end table
797
798 @findex tags-search
799 @kbd{M-x tags-search} reads a regexp using the minibuffer, then
800 searches for matches in all the files in the selected tags table, one
801 file at a time. It displays the name of the file being searched so you
802 can follow its progress. As soon as it finds an occurrence,
803 @code{tags-search} returns.
804
805 @kindex M-,
806 @findex tags-loop-continue
807 Having found one match, you probably want to find all the rest. To find
808 one more match, type @kbd{M-,} (@code{tags-loop-continue}) to resume the
809 @code{tags-search}. This searches the rest of the current buffer, followed
810 by the remaining files of the tags table.@refill
811
812 @findex tags-query-replace
813 @kbd{M-x tags-query-replace} performs a single
814 @code{query-replace-regexp} through all the files in the tags table. It
815 reads a regexp to search for and a string to replace with, just like
816 ordinary @kbd{M-x query-replace-regexp}. It searches much like @kbd{M-x
817 tags-search}, but repeatedly, processing matches according to your
818 input. @xref{Replace}, for more information on query replace.
819
820 @vindex tags-case-fold-search
821 @cindex case-sensitivity and tags search
822 You can control the case-sensitivity of tags search commands by
823 customizing the value of the variable @code{tags-case-fold-search}. The
824 default is to use the same setting as the value of
825 @code{case-fold-search} (@pxref{Search Case}).
826
827 It is possible to get through all the files in the tags table with a
828 single invocation of @kbd{M-x tags-query-replace}. But often it is
829 useful to exit temporarily, which you can do with any input event that
830 has no special query replace meaning. You can resume the query replace
831 subsequently by typing @kbd{M-,}; this command resumes the last tags
832 search or replace command that you did.
833
834 The commands in this section carry out much broader searches than the
835 @code{find-tag} family. The @code{find-tag} commands search only for
836 definitions of tags that match your substring or regexp. The commands
837 @code{tags-search} and @code{tags-query-replace} find every occurrence
838 of the regexp, as ordinary search commands and replace commands do in
839 the current buffer.
840
841 These commands create buffers only temporarily for the files that they
842 have to search (those which are not already visited in Emacs buffers).
843 Buffers in which no match is found are quickly killed; the others
844 continue to exist.
845
846 It may have struck you that @code{tags-search} is a lot like
847 @code{grep}. You can also run @code{grep} itself as an inferior of
848 Emacs and have Emacs show you the matching lines one by one. This works
849 much like running a compilation; finding the source locations of the
850 @code{grep} matches works like finding the compilation errors.
851 @xref{Compilation}.
852
853 @node List Tags
854 @subsection Tags Table Inquiries
855
856 @table @kbd
857 @item M-x list-tags @key{RET} @var{file} @key{RET}
858 Display a list of the tags defined in the program file @var{file}.
859 @item M-x tags-apropos @key{RET} @var{regexp} @key{RET}
860 Display a list of all tags matching @var{regexp}.
861 @end table
862
863 @findex list-tags
864 @kbd{M-x list-tags} reads the name of one of the files described by
865 the selected tags table, and displays a list of all the tags defined in
866 that file. The ``file name'' argument is really just a string to
867 compare against the file names recorded in the tags table; it is read as
868 a string rather than as a file name. Therefore, completion and
869 defaulting are not available, and you must enter the file name the same
870 way it appears in the tags table. Do not include a directory as part of
871 the file name unless the file name recorded in the tags table includes a
872 directory.
873
874 @findex tags-apropos
875 @vindex tags-apropos-verbose
876 @kbd{M-x tags-apropos} is like @code{apropos} for tags
877 (@pxref{Apropos}). It finds all the tags in the selected tags table
878 whose entries match @var{regexp}, and displays them. If the variable
879 @code{tags-apropos-verbose} is non-@code{nil}, it displays the names
880 of the tags files together with the tag names.
881
882 @vindex tags-tag-face
883 @vindex tags-apropos-additional-actions
884 You can customize the appearance of the output with the face
885 @code{tags-tag-face}. You can display additional output with @kbd{M-x
886 tags-apropos} by customizing the variable
887 @code{tags-apropos-additional-actions}---see its documentation for
888 details.
889
890 You can also use the collection of tag names to complete a symbol
891 name in the buffer. @xref{Symbol Completion}.
892
893 @node Emerge
894 @section Merging Files with Emerge
895 @cindex Emerge
896 @cindex merging files
897
898 It's not unusual for programmers to get their signals crossed and modify
899 the same program in two different directions. To recover from this
900 confusion, you need to merge the two versions. Emerge makes this
901 easier. See also @ref{Comparing Files}, for commands to compare
902 in a more manual fashion, and @ref{Top, Ediff,, ediff, The Ediff Manual}.
903
904 @menu
905 * Overview of Emerge:: How to start Emerge. Basic concepts.
906 * Submodes of Emerge:: Fast mode vs. Edit mode.
907 Skip Prefers mode and Auto Advance mode.
908 * State of Difference:: You do the merge by specifying state A or B
909 for each difference.
910 * Merge Commands:: Commands for selecting a difference,
911 changing states of differences, etc.
912 * Exiting Emerge:: What to do when you've finished the merge.
913 * Combining in Emerge:: How to keep both alternatives for a difference.
914 * Fine Points of Emerge:: Misc.
915 @end menu
916
917 @node Overview of Emerge
918 @subsection Overview of Emerge
919
920 To start Emerge, run one of these four commands:
921
922 @table @kbd
923 @item M-x emerge-files
924 @findex emerge-files
925 Merge two specified files.
926
927 @item M-x emerge-files-with-ancestor
928 @findex emerge-files-with-ancestor
929 Merge two specified files, with reference to a common ancestor.
930
931 @item M-x emerge-buffers
932 @findex emerge-buffers
933 Merge two buffers.
934
935 @item M-x emerge-buffers-with-ancestor
936 @findex emerge-buffers-with-ancestor
937 Merge two buffers with reference to a common ancestor in a third
938 buffer.
939 @end table
940
941 @cindex merge buffer (Emerge)
942 @cindex A and B buffers (Emerge)
943 The Emerge commands compare two files or buffers, and display the
944 comparison in three buffers: one for each input text (the @dfn{A buffer}
945 and the @dfn{B buffer}), and one (the @dfn{merge buffer}) where merging
946 takes place. The merge buffer shows the full merged text, not just the
947 differences. Wherever the two input texts differ, you can choose which
948 one of them to include in the merge buffer.
949
950 The Emerge commands that take input from existing buffers use only the
951 accessible portions of those buffers, if they are narrowed
952 (@pxref{Narrowing}).
953
954 If a common ancestor version is available, from which the two texts to
955 be merged were both derived, Emerge can use it to guess which
956 alternative is right. Wherever one current version agrees with the
957 ancestor, Emerge presumes that the other current version is a deliberate
958 change which should be kept in the merged version. Use the
959 @samp{with-ancestor} commands if you want to specify a common ancestor
960 text. These commands read three file or buffer names---variant A,
961 variant B, and the common ancestor.
962
963 After the comparison is done and the buffers are prepared, the
964 interactive merging starts. You control the merging by typing special
965 @dfn{merge commands} in the merge buffer. The merge buffer shows you a
966 full merged text, not just differences. For each run of differences
967 between the input texts, you can choose which one of them to keep, or
968 edit them both together.
969
970 The merge buffer uses a special major mode, Emerge mode, with commands
971 for making these choices. But you can also edit the buffer with
972 ordinary Emacs commands.
973
974 At any given time, the attention of Emerge is focused on one
975 particular difference, called the @dfn{selected} difference. This
976 difference is marked off in the three buffers like this:
977
978 @example
979 vvvvvvvvvvvvvvvvvvvv
980 @var{text that differs}
981 ^^^^^^^^^^^^^^^^^^^^
982 @end example
983
984 @noindent
985 Emerge numbers all the differences sequentially and the mode
986 line always shows the number of the selected difference.
987
988 Normally, the merge buffer starts out with the A version of the text.
989 But when the A version of a difference agrees with the common ancestor,
990 then the B version is initially preferred for that difference.
991
992 Emerge leaves the merged text in the merge buffer when you exit. At
993 that point, you can save it in a file with @kbd{C-x C-w}. If you give a
994 numeric argument to @code{emerge-files} or
995 @code{emerge-files-with-ancestor}, it reads the name of the output file
996 using the minibuffer. (This is the last file name those commands read.)
997 Then exiting from Emerge saves the merged text in the output file.
998
999 Normally, Emerge commands save the output buffer in its file when you
1000 exit. If you abort Emerge with @kbd{C-]}, the Emerge command does not
1001 save the output buffer, but you can save it yourself if you wish.
1002
1003 @node Submodes of Emerge
1004 @subsection Submodes of Emerge
1005
1006 You can choose between two modes for giving merge commands: Fast mode
1007 and Edit mode. In Fast mode, basic merge commands are single
1008 characters, but ordinary Emacs commands are disabled. This is
1009 convenient if you use only merge commands. In Edit mode, all merge
1010 commands start with the prefix key @kbd{C-c C-c}, and the normal Emacs
1011 commands are also available. This allows editing the merge buffer, but
1012 slows down Emerge operations.
1013
1014 Use @kbd{e} to switch to Edit mode, and @kbd{C-c C-c f} to switch to
1015 Fast mode. The mode line indicates Edit and Fast modes with @samp{E}
1016 and @samp{F}.
1017
1018 Emerge has two additional submodes that affect how particular merge
1019 commands work: Auto Advance mode and Skip Prefers mode.
1020
1021 If Auto Advance mode is in effect, the @kbd{a} and @kbd{b} commands
1022 advance to the next difference. This lets you go through the merge
1023 faster as long as you simply choose one of the alternatives from the
1024 input. The mode line indicates Auto Advance mode with @samp{A}.
1025
1026 If Skip Prefers mode is in effect, the @kbd{n} and @kbd{p} commands
1027 skip over differences in states prefer-A and prefer-B (@pxref{State of
1028 Difference}). Thus you see only differences for which neither version
1029 is presumed ``correct.'' The mode line indicates Skip Prefers mode with
1030 @samp{S}.
1031
1032 @findex emerge-auto-advance-mode
1033 @findex emerge-skip-prefers-mode
1034 Use the command @kbd{s a} (@code{emerge-auto-advance-mode}) to set or
1035 clear Auto Advance mode. Use @kbd{s s}
1036 (@code{emerge-skip-prefers-mode}) to set or clear Skip Prefers mode.
1037 These commands turn on the mode with a positive argument, turns it off
1038 with a negative or zero argument, and toggle the mode with no argument.
1039
1040 @node State of Difference
1041 @subsection State of a Difference
1042
1043 In the merge buffer, a difference is marked with lines of @samp{v} and
1044 @samp{^} characters. Each difference has one of these seven states:
1045
1046 @table @asis
1047 @item A
1048 The difference is showing the A version. The @kbd{a} command always
1049 produces this state; the mode line indicates it with @samp{A}.
1050
1051 @item B
1052 The difference is showing the B version. The @kbd{b} command always
1053 produces this state; the mode line indicates it with @samp{B}.
1054
1055 @item default-A
1056 @itemx default-B
1057 The difference is showing the A or the B state by default, because you
1058 haven't made a choice. All differences start in the default-A state
1059 (and thus the merge buffer is a copy of the A buffer), except those for
1060 which one alternative is ``preferred'' (see below).
1061
1062 When you select a difference, its state changes from default-A or
1063 default-B to plain A or B. Thus, the selected difference never has
1064 state default-A or default-B, and these states are never displayed in
1065 the mode line.
1066
1067 The command @kbd{d a} chooses default-A as the default state, and @kbd{d
1068 b} chooses default-B. This chosen default applies to all differences
1069 which you haven't ever selected and for which no alternative is preferred.
1070 If you are moving through the merge sequentially, the differences you
1071 haven't selected are those following the selected one. Thus, while
1072 moving sequentially, you can effectively make the A version the default
1073 for some sections of the merge buffer and the B version the default for
1074 others by using @kbd{d a} and @kbd{d b} between sections.
1075
1076 @item prefer-A
1077 @itemx prefer-B
1078 The difference is showing the A or B state because it is
1079 @dfn{preferred}. This means that you haven't made an explicit choice,
1080 but one alternative seems likely to be right because the other
1081 alternative agrees with the common ancestor. Thus, where the A buffer
1082 agrees with the common ancestor, the B version is preferred, because
1083 chances are it is the one that was actually changed.
1084
1085 These two states are displayed in the mode line as @samp{A*} and @samp{B*}.
1086
1087 @item combined
1088 The difference is showing a combination of the A and B states, as a
1089 result of the @kbd{x c} or @kbd{x C} commands.
1090
1091 Once a difference is in this state, the @kbd{a} and @kbd{b} commands
1092 don't do anything to it unless you give them a numeric argument.
1093
1094 The mode line displays this state as @samp{comb}.
1095 @end table
1096
1097 @node Merge Commands
1098 @subsection Merge Commands
1099
1100 Here are the Merge commands for Fast mode; in Edit mode, precede them
1101 with @kbd{C-c C-c}:
1102
1103 @table @kbd
1104 @item p
1105 Select the previous difference.
1106
1107 @item n
1108 Select the next difference.
1109
1110 @item a
1111 Choose the A version of this difference.
1112
1113 @item b
1114 Choose the B version of this difference.
1115
1116 @item C-u @var{n} j
1117 Select difference number @var{n}.
1118
1119 @item .
1120 Select the difference containing point. You can use this command in the
1121 merge buffer or in the A or B buffer.
1122
1123 @item q
1124 Quit---finish the merge.
1125
1126 @item C-]
1127 Abort---exit merging and do not save the output.
1128
1129 @item f
1130 Go into Fast mode. (In Edit mode, this is actually @kbd{C-c C-c f}.)
1131
1132 @item e
1133 Go into Edit mode.
1134
1135 @item l
1136 Recenter (like @kbd{C-l}) all three windows.
1137
1138 @item -
1139 Specify part of a prefix numeric argument.
1140
1141 @item @var{digit}
1142 Also specify part of a prefix numeric argument.
1143
1144 @item d a
1145 Choose the A version as the default from here down in
1146 the merge buffer.
1147
1148 @item d b
1149 Choose the B version as the default from here down in
1150 the merge buffer.
1151
1152 @item c a
1153 Copy the A version of this difference into the kill ring.
1154
1155 @item c b
1156 Copy the B version of this difference into the kill ring.
1157
1158 @item i a
1159 Insert the A version of this difference at point.
1160
1161 @item i b
1162 Insert the B version of this difference at point.
1163
1164 @item m
1165 Put point and mark around the difference.
1166
1167 @item ^
1168 Scroll all three windows down (like @kbd{M-v}).
1169
1170 @item v
1171 Scroll all three windows up (like @kbd{C-v}).
1172
1173 @item <
1174 Scroll all three windows left (like @kbd{C-x <}).
1175
1176 @item >
1177 Scroll all three windows right (like @kbd{C-x >}).
1178
1179 @item |
1180 Reset horizontal scroll on all three windows.
1181
1182 @item x 1
1183 Shrink the merge window to one line. (Use @kbd{C-u l} to restore it
1184 to full size.)
1185
1186 @item x c
1187 Combine the two versions of this difference (@pxref{Combining in
1188 Emerge}).
1189
1190 @item x f
1191 Show the names of the files/buffers Emerge is operating on, in a Help
1192 window. (Use @kbd{C-u l} to restore windows.)
1193
1194 @item x j
1195 Join this difference with the following one.
1196 (@kbd{C-u x j} joins this difference with the previous one.)
1197
1198 @item x s
1199 Split this difference into two differences. Before you use this
1200 command, position point in each of the three buffers at the place where
1201 you want to split the difference.
1202
1203 @item x t
1204 Trim identical lines off the top and bottom of the difference.
1205 Such lines occur when the A and B versions are
1206 identical but differ from the ancestor version.
1207 @end table
1208
1209 @node Exiting Emerge
1210 @subsection Exiting Emerge
1211
1212 The @kbd{q} command (@code{emerge-quit}) finishes the merge, storing
1213 the results into the output file if you specified one. It restores the
1214 A and B buffers to their proper contents, or kills them if they were
1215 created by Emerge and you haven't changed them. It also disables the
1216 Emerge commands in the merge buffer, since executing them later could
1217 damage the contents of the various buffers.
1218
1219 @kbd{C-]} aborts the merge. This means exiting without writing the
1220 output file. If you didn't specify an output file, then there is no
1221 real difference between aborting and finishing the merge.
1222
1223 If the Emerge command was called from another Lisp program, then its
1224 return value is @code{t} for successful completion, or @code{nil} if you
1225 abort.
1226
1227 @node Combining in Emerge
1228 @subsection Combining the Two Versions
1229
1230 Sometimes you want to keep @emph{both} alternatives for a particular
1231 difference. To do this, use @kbd{x c}, which edits the merge buffer
1232 like this:
1233
1234 @example
1235 @group
1236 #ifdef NEW
1237 @var{version from A buffer}
1238 #else /* not NEW */
1239 @var{version from B buffer}
1240 #endif /* not NEW */
1241 @end group
1242 @end example
1243
1244 @noindent
1245 @vindex emerge-combine-versions-template
1246 While this example shows C preprocessor conditionals delimiting the two
1247 alternative versions, you can specify the strings to use by setting
1248 the variable @code{emerge-combine-versions-template} to a string of your
1249 choice. In the string, @samp{%a} says where to put version A, and
1250 @samp{%b} says where to put version B. The default setting, which
1251 produces the results shown above, looks like this:
1252
1253 @example
1254 @group
1255 "#ifdef NEW\n%a#else /* not NEW */\n%b#endif /* not NEW */\n"
1256 @end group
1257 @end example
1258
1259 @node Fine Points of Emerge
1260 @subsection Fine Points of Emerge
1261
1262 During the merge, you mustn't try to edit the A and B buffers yourself.
1263 Emerge modifies them temporarily, but ultimately puts them back the way
1264 they were.
1265
1266 You can have any number of merges going at once---just don't use any one
1267 buffer as input to more than one merge at once, since the temporary
1268 changes made in these buffers would get in each other's way.
1269
1270 Starting Emerge can take a long time because it needs to compare the
1271 files fully. Emacs can't do anything else until @code{diff} finishes.
1272 Perhaps in the future someone will change Emerge to do the comparison in
1273 the background when the input files are large---then you could keep on
1274 doing other things with Emacs until Emerge is ready to accept
1275 commands.
1276
1277 @vindex emerge-startup-hook
1278 After setting up the merge, Emerge runs the hook
1279 @code{emerge-startup-hook} (@pxref{Hooks}).
1280
1281 @ignore
1282 arch-tag: b9d83dfb-82ea-4ff6-bab5-05a3617091fb
1283 @end ignore