annotate lib-src/etags.1 @ 37069:6dee6cc113a5

(Regexps): Say up front that backslashes must be doubled in a Lisp program.
author Eli Zaretskii <eliz@gnu.org>
date Thu, 29 Mar 2001 15:52:56 +0000
parents 2ce207b252dc
children bffcf33fd50d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
1 .\" Copyright (c) 1992 Free Software Foundation
Dave Love <fx@gnu.org>
parents:
diff changeset
2 .\" See section COPYING for conditions for redistribution
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
3 .TH etags 1 "14gen2001" "GNU Tools" "GNU Tools"
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
4 .de BP
Dave Love <fx@gnu.org>
parents:
diff changeset
5 .sp
Dave Love <fx@gnu.org>
parents:
diff changeset
6 .ti -.2i
Dave Love <fx@gnu.org>
parents:
diff changeset
7 \(**
Dave Love <fx@gnu.org>
parents:
diff changeset
8 ..
Dave Love <fx@gnu.org>
parents:
diff changeset
9
Dave Love <fx@gnu.org>
parents:
diff changeset
10 .SH NAME
Dave Love <fx@gnu.org>
parents:
diff changeset
11 etags, ctags \- generate tag file for Emacs, vi
Dave Love <fx@gnu.org>
parents:
diff changeset
12 .SH SYNOPSIS
Dave Love <fx@gnu.org>
parents:
diff changeset
13 .hy 0
Dave Love <fx@gnu.org>
parents:
diff changeset
14 .na
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
15 .B etags [\|\-aCDGImRVh\|] [\|\-i \fIfile\fP\|] [\|\-l \fIlanguage\fP\|]
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
16 .if n .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
17 .B [\|\-o \fItagfile\fP\|] [\|\-r \fIregexp\fP\|]
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
18 .br
35665
2ce207b252dc Many changes to the parsing capabilities of etags.
Francesco Potortì <pot@gnu.org>
parents: 35304
diff changeset
19 .B [\|\-\-append\|] [\|\-\-no\-defines\|]
35304
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
20 .B [\|\-\-no\-globals\|] [\|\-\-include=\fIfile\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
21 .B [\|\-\-ignore\-indentation\|] [\|\-\-language=\fIlanguage\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
22 .B [\|\-\-members\|] [\|\-\-output=\fItagfile\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
23 .B [\|\-\-regex=\fIregexp\fP\|] [\|\-\-no\-regex\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
24 .B [\|\-\-ignore\-case\-regex=\fIregexp\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
25 .B [\|\-\-help\|] [\|\-\-version\|]
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
26 \fIfile\fP .\|.\|.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
27
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
28 .B ctags [\|\-aCdgImRVh\|] [\|\-BtTuvwx\|] [\|\-l \fIlanguage\fP\|]
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
29 .if n .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
30 .B [\|\-o \fItagfile\fP\|] [\|\-r \fIregexp\fP\|]
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
31 .br
35665
2ce207b252dc Many changes to the parsing capabilities of etags.
Francesco Potortì <pot@gnu.org>
parents: 35304
diff changeset
32 .B [\|\-\-append\|] [\|\-\-backward\-search\|]
35304
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
33 .B [\|\-\-cxref\|] [\|\-\-defines\|] [\|\-\-forward\-search\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
34 .B [\|\-\-globals\|] [\|\-\-ignore\-indentation\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
35 .B [\|\-\-language=\fIlanguage\fP\|] [\|\-\-members\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
36 .B [\|\-\-output=\fItagfile\fP\|] [\|\-\-regex=\fIregexp\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
37 .B [\|\-\-ignore\-case\-regex=\fIregexp\fP\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
38 .B [\|\-\-typedefs\|] [\|\-\-typedefs\-and\-c++\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
39 .B [\|\-\-update\|] [\|\-\-no\-warn\|]
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
40 .B [\|\-\-help\|] [\|\-\-version\|]
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
41 \fIfile\fP .\|.\|.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
42 .ad b
Dave Love <fx@gnu.org>
parents:
diff changeset
43 .hy 1
Dave Love <fx@gnu.org>
parents:
diff changeset
44 .SH DESCRIPTION
Dave Love <fx@gnu.org>
parents:
diff changeset
45 The `\|\fBetags\fP\|' program is used to create a tag table file, in a format
Dave Love <fx@gnu.org>
parents:
diff changeset
46 understood by
Dave Love <fx@gnu.org>
parents:
diff changeset
47 .BR emacs ( 1 )\c
Dave Love <fx@gnu.org>
parents:
diff changeset
48 \&; the `\|\fBctags\fP\|' program is used to create a similar table in a
Dave Love <fx@gnu.org>
parents:
diff changeset
49 format understood by
Dave Love <fx@gnu.org>
parents:
diff changeset
50 .BR vi ( 1 )\c
35303
a1775d96a961 *** empty log message ***
Francesco Potortì <pot@gnu.org>
parents: 35297
diff changeset
51 \&. Both forms of the program understand the syntax of C, Objective C,
a1775d96a961 *** empty log message ***
Francesco Potortì <pot@gnu.org>
parents: 35297
diff changeset
52 C++, Java, Fortran, Ada, Cobol, Erlang, LaTeX, Emacs Lisp/Common Lisp,
a1775d96a961 *** empty log message ***
Francesco Potortì <pot@gnu.org>
parents: 35297
diff changeset
53 makefiles, Pascal, Perl, Postscript, Python, Prolog, Scheme and most
a1775d96a961 *** empty log message ***
Francesco Potortì <pot@gnu.org>
parents: 35297
diff changeset
54 assembler\-like syntaxes.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
55 Both forms read the files specified on the command line, and write a tag
Dave Love <fx@gnu.org>
parents:
diff changeset
56 table (defaults: `\|TAGS\|' for \fBetags\fP, `\|tags\|' for
Dave Love <fx@gnu.org>
parents:
diff changeset
57 \fBctags\fP) in the current working directory.
Dave Love <fx@gnu.org>
parents:
diff changeset
58 Files specified with relative file names will be recorded in the tag
Dave Love <fx@gnu.org>
parents:
diff changeset
59 table with file names relative to the directory where the tag table
Dave Love <fx@gnu.org>
parents:
diff changeset
60 resides. Files specified with absolute file names will be recorded
Dave Love <fx@gnu.org>
parents:
diff changeset
61 with absolute file names.
Dave Love <fx@gnu.org>
parents:
diff changeset
62 The programs recognize the language used in an input file based on its
Dave Love <fx@gnu.org>
parents:
diff changeset
63 file name and contents. The --language switch can be used to force
Dave Love <fx@gnu.org>
parents:
diff changeset
64 parsing of the file names following the switch according to the given
Dave Love <fx@gnu.org>
parents:
diff changeset
65 language, overriding guesses based on filename extensions.
Dave Love <fx@gnu.org>
parents:
diff changeset
66 .SH OPTIONS
Dave Love <fx@gnu.org>
parents:
diff changeset
67 Some options make sense only for the \fBvi\fP style tag files produced
Dave Love <fx@gnu.org>
parents:
diff changeset
68 by ctags;
Dave Love <fx@gnu.org>
parents:
diff changeset
69 \fBetags\fP does not recognize them.
Dave Love <fx@gnu.org>
parents:
diff changeset
70 The programs accept unambiguous abbreviations for long option names.
Dave Love <fx@gnu.org>
parents:
diff changeset
71 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
72 .B \-a, \-\-append
Dave Love <fx@gnu.org>
parents:
diff changeset
73 Append to existing tag file. (For vi-format tag files, see also
Dave Love <fx@gnu.org>
parents:
diff changeset
74 \fB\-\-update\fP.)
Dave Love <fx@gnu.org>
parents:
diff changeset
75 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
76 .B \-B, \-\-backward\-search
Dave Love <fx@gnu.org>
parents:
diff changeset
77 Tag files written in the format expected by \fBvi\fP contain regular
Dave Love <fx@gnu.org>
parents:
diff changeset
78 expression search instructions; the \fB\-B\fP option writes them using
Dave Love <fx@gnu.org>
parents:
diff changeset
79 the delimiter `\|\fB?\fP\|', to search \fIbackwards\fP through files.
Dave Love <fx@gnu.org>
parents:
diff changeset
80 The default is to use the delimiter `\|\fB/\fP\|', to search \fIforwards\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
81 through files.
Dave Love <fx@gnu.org>
parents:
diff changeset
82 Only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
83 .TP
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
84 .B \-\-declarations
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
85 In C and derived languages, create tags for function declarations,
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
86 and create tags for extern variables unless \-\-no\-globals is used.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
87 .TP
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
88 .B \-d, \-\-defines
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
89 Create tag entries for C preprocessor constant definitions
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
90 and enum constants, too. This is the
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
91 default behavior for \fBetags\fP.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
92 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
93 .B \-D, \-\-no\-defines
Dave Love <fx@gnu.org>
parents:
diff changeset
94 Do not create tag entries for C preprocessor constant definitions
Dave Love <fx@gnu.org>
parents:
diff changeset
95 and enum constants.
Dave Love <fx@gnu.org>
parents:
diff changeset
96 This may make the tags file much smaller if many header files are tagged.
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
97 This is the default behavior for \fBctags\fP.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
98 .TP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
99 .B \-g, \-\-globals
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
100 Create tag entries for global variables in C, C++, Objective C, Java,
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
101 and Perl.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
102 This is the default behavior for \fBetags\fP.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
103 .TP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
104 .B \-G, \-\-no\-globals
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
105 Do not tag global variables. Typically this reduces the file size by
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
106 one fourth. This is the default behavior for \fBctags\fP.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
107 .TP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
108 \fB\-i\fP \fIfile\fP, \fB\-\-include=\fIfile\fP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
109 Include a note in the tag file indicating that, when searching for a
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
110 tag, one should also consult the tags file \fIfile\fP after checking the
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
111 current file. This options is only accepted by \fBetags\fP.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
112 .TP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
113 .B \-I, \-\-ignore\-indentation
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
114 Don't rely on indentation as much as we normally do. Currently, this
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
115 means not to assume that a closing brace in the first column is the
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
116 final brace of a function or structure definition in C and C++.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
117 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
118 \fB\-l\fP \fIlanguage\fP, \fB\-\-language=\fIlanguage\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
119 Parse the following files according to the given language. More than
Dave Love <fx@gnu.org>
parents:
diff changeset
120 one such options may be intermixed with filenames. Use \fB\-\-help\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
121 to get a list of the available languages and their default filename
Dave Love <fx@gnu.org>
parents:
diff changeset
122 extensions. The `auto' language can be used to restore automatic
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
123 detection of language based on the file name. The `none'
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
124 language may be used to disable language parsing altogether; only
Dave Love <fx@gnu.org>
parents:
diff changeset
125 regexp matching is done in this case (see the \fB\-\-regex\fP option).
Dave Love <fx@gnu.org>
parents:
diff changeset
126 .TP
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
127 .B \-m, \-\-members
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
128 Create tag entries for variables that are members of structure-like
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
129 constructs in C++, Objective C, Java.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
130 .TP
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
131 .B \-M, \-\-no\-members
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
132 Do not tag member variables. This is the default behavior.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
133 .TP
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
134 .B \-\-packages\-only
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
135 Only tag packages in Ada files.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
136 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
137 \fB\-o\fP \fItagfile\fP, \fB\-\-output=\fItagfile\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
138 Explicit name of file for tag table; overrides default `\|TAGS\|' or
Dave Love <fx@gnu.org>
parents:
diff changeset
139 `\|tags\|'. (But ignored with \fB\-v\fP or \fB\-x\fP.)
Dave Love <fx@gnu.org>
parents:
diff changeset
140 .TP
35304
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
141 \fB\-r\fP \fIregexp\fP, \fB\-\-regex=\fIregexp\fP, \fB\-\-ignore\-case\-regex=\fIregexp\fP
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
142 Make tags based on regexp matching for each line of the files following
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
143 this option, in addition to the tags made with the standard parsing based
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
144 on language. When using \-\-regex, case is significant, while it is not
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
145 with \-\-ignore\-case\-regex. May be freely intermixed with filenames and
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
146 the \fB\-R\fP option. The regexps are cumulative, i.e. each option will
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
147 add to the previous ones. The regexps are of the form:
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
148 .br
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
149 \fB/\fP\fItagregexp\fP[\fB/\fP\fInameregexp\fP]\fB/\fP
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
150 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
151
Dave Love <fx@gnu.org>
parents:
diff changeset
152 where \fItagregexp\fP is used to match the lines that must be tagged.
Dave Love <fx@gnu.org>
parents:
diff changeset
153 It should not match useless characters. If the match is
Dave Love <fx@gnu.org>
parents:
diff changeset
154 such that more characters than needed are unavoidably matched by
Dave Love <fx@gnu.org>
parents:
diff changeset
155 \fItagregexp\fP, it may be useful to add a \fInameregexp\fP, to
Dave Love <fx@gnu.org>
parents:
diff changeset
156 narrow down the tag scope. \fBctags\fP ignores regexps without a
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
157 \fInameregexp\fP. The syntax of regexps is the same as in emacs,
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
158 augmented with intervals of the form \\{m,n\\}, as in ed or grep.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
159 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
160 Here are some examples. All the regexps are quoted to protect them
Dave Love <fx@gnu.org>
parents:
diff changeset
161 from shell interpretation.
Dave Love <fx@gnu.org>
parents:
diff changeset
162 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
163
Dave Love <fx@gnu.org>
parents:
diff changeset
164 Tag the DEFVAR macros in the emacs source files:
Dave Love <fx@gnu.org>
parents:
diff changeset
165 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
166 \fI\-\-regex\='/[ \\t]*DEFVAR_[A-Z_ \\t(]+"\\([^"]+\\)"\/'\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
167 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
168
Dave Love <fx@gnu.org>
parents:
diff changeset
169 Tag VHDL files (this example is a single long line, broken here for
Dave Love <fx@gnu.org>
parents:
diff changeset
170 formatting reasons):
Dave Love <fx@gnu.org>
parents:
diff changeset
171 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
172 \fI\-\-language\=none\ \-\-regex='/[\ \\t]*\\(ARCHITECTURE\\|\\
Dave Love <fx@gnu.org>
parents:
diff changeset
173 CONFIGURATION\\)\ +[^\ ]*\ +OF/'\ \-\-regex\='/[\ \\t]*\\
Dave Love <fx@gnu.org>
parents:
diff changeset
174 \\(ATTRIBUTE\\|ENTITY\\|FUNCTION\\|PACKAGE\\(\ BODY\\)?\\
Dave Love <fx@gnu.org>
parents:
diff changeset
175 \\|PROCEDURE\\|PROCESS\\|TYPE\\)[\ \\t]+\\([^\ \\t(]+\\)/\\3/'\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
176 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
177
Dave Love <fx@gnu.org>
parents:
diff changeset
178 Tag TCL files (this last example shows the usage of a \fItagregexp\fP):
Dave Love <fx@gnu.org>
parents:
diff changeset
179 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
180 \fI\-\-lang\=none \-\-regex\='/proc[\ \\t]+\\([^\ \\t]+\\)/\\1/'\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
181
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
182 .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
183 A regexp can be preceded by {lang}, thus restriciting it to match lines of
35304
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
184 files of the specified language. Use \fBetags --help\fP to obtain a list
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
185 of the recognised languages. This feature is particularly useful inside
35304
e34fbc66493b 2000-05-31 Karl M. Hegbloom <karlheg@debian.org>
Francesco Potortì <pot@gnu.org>
parents: 35303
diff changeset
186 \fBregex files\fP. A regex file contains one regex per line. Empty lines,
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
187 and those lines beginning with space or tab are ignored. Lines beginning
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
188 with @ are references to regex files whose name follows the @ sign. Other
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
189 lines are considered regular expressions like those following \-\-regex.
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
190 .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
191 For example, the command
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
192 .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
193 etags \-\-regex=@regex.file *.c
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
194 .br
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
195 reads the regexes contained in the file regex.file.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
196 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
197 .B \-R, \-\-no\-regex
Dave Love <fx@gnu.org>
parents:
diff changeset
198 Don't do any more regexp matching on the following files. May be
Dave Love <fx@gnu.org>
parents:
diff changeset
199 freely intermixed with filenames and the \fB\-\-regex\fP option.
Dave Love <fx@gnu.org>
parents:
diff changeset
200 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
201 .B \-t, \-\-typedefs
Dave Love <fx@gnu.org>
parents:
diff changeset
202 Record typedefs in C code as tags. Since this is the default behaviour
Dave Love <fx@gnu.org>
parents:
diff changeset
203 of \fBetags\fP, only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
204 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
205 .B \-T, \-\-typedefs\-and\-c++
Dave Love <fx@gnu.org>
parents:
diff changeset
206 Generate tag entries for typedefs, struct, enum, and union tags, and
Dave Love <fx@gnu.org>
parents:
diff changeset
207 C++ member functions. Since this is the default behaviour
Dave Love <fx@gnu.org>
parents:
diff changeset
208 of \fBetags\fP, only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
209 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
210 .B \-u, \-\-update
Dave Love <fx@gnu.org>
parents:
diff changeset
211 Update tag entries for \fIfiles\fP specified on command line, leaving
Dave Love <fx@gnu.org>
parents:
diff changeset
212 tag entries for other files in place. Currently, this is implemented
Dave Love <fx@gnu.org>
parents:
diff changeset
213 by deleting the existing entries for the given files and then
Dave Love <fx@gnu.org>
parents:
diff changeset
214 rewriting the new entries at the end of the tags file. It is often
Dave Love <fx@gnu.org>
parents:
diff changeset
215 faster to simply rebuild the entire tag file than to use this.
Dave Love <fx@gnu.org>
parents:
diff changeset
216 Only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
217 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
218 .B \-v, \-\-vgrind
Dave Love <fx@gnu.org>
parents:
diff changeset
219 Instead of generating a tag file, write index (in \fBvgrind\fP format)
Dave Love <fx@gnu.org>
parents:
diff changeset
220 to standard output. Only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
221 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
222 .B \-w, \-\-no\-warn
Dave Love <fx@gnu.org>
parents:
diff changeset
223 Suppress warning messages about duplicate entries. The \fBetags\fP
Dave Love <fx@gnu.org>
parents:
diff changeset
224 program does not check for duplicate entries, so this option is not
Dave Love <fx@gnu.org>
parents:
diff changeset
225 allowed with it.
Dave Love <fx@gnu.org>
parents:
diff changeset
226 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
227 .B \-x, \-\-cxref
Dave Love <fx@gnu.org>
parents:
diff changeset
228 Instead of generating a tag file, write a cross reference (in
Dave Love <fx@gnu.org>
parents:
diff changeset
229 \fBcxref\fP format) to standard output. Only \fBctags\fP accepts this option.
Dave Love <fx@gnu.org>
parents:
diff changeset
230 .TP
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
231 .B \-h, \-H, \-\-help
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
232 Print usage information.
Dave Love <fx@gnu.org>
parents:
diff changeset
233 .TP
Dave Love <fx@gnu.org>
parents:
diff changeset
234 .B \-V, \-\-version
Dave Love <fx@gnu.org>
parents:
diff changeset
235 Print the current version of the program (same as the version of the
Dave Love <fx@gnu.org>
parents:
diff changeset
236 emacs \fBetags\fP is shipped with).
Dave Love <fx@gnu.org>
parents:
diff changeset
237
Dave Love <fx@gnu.org>
parents:
diff changeset
238 .SH "SEE ALSO"
Dave Love <fx@gnu.org>
parents:
diff changeset
239 `\|\fBemacs\fP\|' entry in \fBinfo\fP; \fIGNU Emacs Manual\fP, Richard
Dave Love <fx@gnu.org>
parents:
diff changeset
240 Stallman.
Dave Love <fx@gnu.org>
parents:
diff changeset
241 .br
Dave Love <fx@gnu.org>
parents:
diff changeset
242 .BR cxref ( 1 ),
Dave Love <fx@gnu.org>
parents:
diff changeset
243 .BR emacs ( 1 ),
Dave Love <fx@gnu.org>
parents:
diff changeset
244 .BR vgrind ( 1 ),
Dave Love <fx@gnu.org>
parents:
diff changeset
245 .BR vi ( 1 ).
Dave Love <fx@gnu.org>
parents:
diff changeset
246
Dave Love <fx@gnu.org>
parents:
diff changeset
247 .SH COPYING
35297
e268b7b500f0 Changes for makefile support in etags.
Francesco Potortì <pot@gnu.org>
parents: 25859
diff changeset
248 Copyright (c) 1999 Free Software Foundation, Inc.
25859
Dave Love <fx@gnu.org>
parents:
diff changeset
249 .PP
Dave Love <fx@gnu.org>
parents:
diff changeset
250 Permission is granted to make and distribute verbatim copies of
Dave Love <fx@gnu.org>
parents:
diff changeset
251 this manual provided the copyright notice and this permission notice
Dave Love <fx@gnu.org>
parents:
diff changeset
252 are preserved on all copies.
Dave Love <fx@gnu.org>
parents:
diff changeset
253 .PP
Dave Love <fx@gnu.org>
parents:
diff changeset
254 Permission is granted to copy and distribute modified versions of this
Dave Love <fx@gnu.org>
parents:
diff changeset
255 manual under the conditions for verbatim copying, provided that the
Dave Love <fx@gnu.org>
parents:
diff changeset
256 entire resulting derived work is distributed under the terms of a
Dave Love <fx@gnu.org>
parents:
diff changeset
257 permission notice identical to this one.
Dave Love <fx@gnu.org>
parents:
diff changeset
258 .PP
Dave Love <fx@gnu.org>
parents:
diff changeset
259 Permission is granted to copy and distribute translations of this
Dave Love <fx@gnu.org>
parents:
diff changeset
260 manual into another language, under the above conditions for modified
Dave Love <fx@gnu.org>
parents:
diff changeset
261 versions, except that this permission notice may be included in
Dave Love <fx@gnu.org>
parents:
diff changeset
262 translations approved by the Free Software Foundation instead of in
Dave Love <fx@gnu.org>
parents:
diff changeset
263 the original English.