annotate runtime/doc/usr_29.txt @ 34:e170173ecb68 current-release

before ack base protocol.
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Wed, 26 Nov 2008 15:02:10 +0900
parents 76efa0be13f1
children c16898406ff2
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
1 *usr_29.txt* For Vim version 7.2. Last change: 2008 Jun 28
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
3 VIM USER MANUAL - by Bram Moolenaar
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
4
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
5 Moving through programs
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
6
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
7
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
8 The creator of Vim is a computer programmer. It's no surprise that Vim
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
9 contains many features to aid in writing programs. Jump around to find where
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
10 identifiers are defined and used. Preview declarations in a separate window.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
11 There is more in the next chapter.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
12
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
13 |29.1| Using tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
14 |29.2| The preview window
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
15 |29.3| Moving through a program
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
16 |29.4| Finding global identifiers
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
17 |29.5| Finding local identifiers
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
18
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
19 Next chapter: |usr_30.txt| Editing programs
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
20 Previous chapter: |usr_28.txt| Folding
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
21 Table of contents: |usr_toc.txt|
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
22
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
23 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
24 *29.1* Using tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
25
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
26 What is a tag? It is a location where an identifier is defined. An example
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
27 is a function definition in a C or C++ program. A list of tags is kept in a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
28 tags file. This can be used by Vim to directly jump from any place to the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
29 tag, the place where an identifier is defined.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
30 To generate the tags file for all C files in the current directory, use the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
31 following command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
32
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
33 ctags *.c
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
34
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
35 "ctags" is a separate program. Most Unix systems already have it installed.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
36 If you do not have it yet, you can find Exuberant ctags here:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
37
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
38 http://ctags.sf.net ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
39
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
40 Now when you are in Vim and you want to go to a function definition, you can
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
41 jump to it by using the following command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
42
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
43 :tag startlist
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
44
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
45 This command will find the function "startlist" even if it is in another file.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
46 The CTRL-] command jumps to the tag of the word that is under the cursor.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
47 This makes it easy to explore a tangle of C code. Suppose, for example, that
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
48 you are in the function "write_block". You can see that it calls
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
49 "write_line". But what does "write_line" do? By placing the cursor on the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
50 call to "write_line" and pressing CTRL-], you jump to the definition of this
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
51 function.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
52 The "write_line" function calls "write_char". You need to figure out what
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
53 it does. So you position the cursor over the call to "write_char" and press
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
54 CTRL-]. Now you are at the definition of "write_char".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
55
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
56 +-------------------------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
57 |void write_block(char **s; int cnt) |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
58 |{ |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
59 | int i; |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
60 | for (i = 0; i < cnt; ++i) |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
61 | write_line(s[i]); |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
62 |} | |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
63 +-----------|-------------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
64 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
65 CTRL-] |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
66 | +----------------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
67 +--> |void write_line(char *s) |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
68 |{ |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
69 | while (*s != 0) |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
70 | write_char(*s++); |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
71 |} | |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
72 +--------|-------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
73 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
74 CTRL-] |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
75 | +------------------------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
76 +--> |void write_char(char c) |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
77 |{ |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
78 | putchar((int)(unsigned char)c); |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
79 |} |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
80 +------------------------------------+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
81
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
82 The ":tags" command shows the list of tags that you traversed through:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
83
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
84 :tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
85 # TO tag FROM line in file/text ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
86 1 1 write_line 8 write_block.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
87 2 1 write_char 7 write_line.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
88 > ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
89 >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
90 Now to go back. The CTRL-T command goes to the preceding tag. In the example
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
91 above you get back to the "write_line" function, in the call to "write_char".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
92 This command takes a count argument that indicates how many tags to jump
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
93 back. You have gone forward, and now back. Let's go forward again. The
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
94 following command goes to the tag on top of the list: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
95
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
96 :tag
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
97
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
98 You can prefix it with a count and jump forward that many tags. For example:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
99 ":3tag". CTRL-T also can be preceded with a count.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
100 These commands thus allow you to go down a call tree with CTRL-] and back
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
101 up again with CTRL-T. Use ":tags" to find out where you are.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
102
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
103
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
104 SPLIT WINDOWS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
105
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
106 The ":tag" command replaces the file in the current window with the one
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
107 containing the new function. But suppose you want to see not only the old
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
108 function but also the new one? You can split the window using the ":split"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
109 command followed by the ":tag" command. Vim has a shorthand command that does
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
110 both: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
111 :stag tagname
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
112
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
113 To split the current window and jump to the tag under the cursor use this
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
114 command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
115
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
116 CTRL-W ]
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
117
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
118 If a count is specified, the new window will be that many lines high.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
119
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
120
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
121 MORE TAGS FILES
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
122
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
123 When you have files in many directories, you can create a tags file in each of
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
124 them. Vim will then only be able to jump to tags within that directory.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
125 To find more tags files, set the 'tags' option to include all the relevant
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
126 tags files. Example: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
127
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
128 :set tags=./tags,./../tags,./*/tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
129
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
130 This finds a tags file in the same directory as the current file, one
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
131 directory level higher and in all subdirectories.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
132 This is quite a number of tags files, but it may still not be enough. For
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
133 example, when editing a file in "~/proj/src", you will not find the tags file
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
134 "~/proj/sub/tags". For this situation Vim offers to search a whole directory
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
135 tree for tags files. Example: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
136
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
137 :set tags=~/proj/**/tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
138
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
139
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
140 ONE TAGS FILE
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
141
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
142 When Vim has to search many places for tags files, you can hear the disk
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
143 rattling. It may get a bit slow. In that case it's better to spend this
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
144 time while generating one big tags file. You might do this overnight.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
145 This requires the Exuberant ctags program, mentioned above. It offers an
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
146 argument to search a whole directory tree: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
147
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
148 cd ~/proj
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
149 ctags -R .
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
150
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
151 The nice thing about this is that Exuberant ctags recognizes various file
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
152 types. Thus this doesn't work just for C and C++ programs, also for Eiffel
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
153 and even Vim scripts. See the ctags documentation to tune this.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
154 Now you only need to tell Vim where your big tags file is: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
155
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
156 :set tags=~/proj/tags
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
157
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
158
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
159 MULTIPLE MATCHES
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
160
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
161 When a function is defined multiple times (or a method in several classes),
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
162 the ":tag" command will jump to the first one. If there is a match in the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
163 current file, that one is used first.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
164 You can now jump to other matches for the same tag with: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
165
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
166 :tnext
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
167
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
168 Repeat this to find further matches. If there are many, you can select which
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
169 one to jump to: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
170
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
171 :tselect tagname
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
172
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
173 Vim will present you with a list of choices:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
174
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
175 # pri kind tag file ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
176 1 F f mch_init os_amiga.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
177 mch_init() ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
178 2 F f mch_init os_mac.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
179 mch_init() ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
180 3 F f mch_init os_msdos.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
181 mch_init(void) ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
182 4 F f mch_init os_riscos.c ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
183 mch_init() ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
184 Enter nr of choice (<CR> to abort): ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
185
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
186 You can now enter the number (in the first column) of the match that you would
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
187 like to jump to. The information in the other columns give you a good idea of
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
188 where the match is defined.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
189
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
190 To move between the matching tags, these commands can be used:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
191
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
192 :tfirst go to first match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
193 :[count]tprevious go to [count] previous match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
194 :[count]tnext go to [count] next match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
195 :tlast go to last match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
196
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
197 If [count] is omitted then one is used.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
198
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
199
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
200 GUESSING TAG NAMES
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
201
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
202 Command line completion is a good way to avoid typing a long tag name. Just
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
203 type the first bit and press <Tab>: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
204
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
205 :tag write_<Tab>
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
206
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
207 You will get the first match. If it's not the one you want, press <Tab> until
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
208 you find the right one.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
209 Sometimes you only know part of the name of a function. Or you have many
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
210 tags that start with the same string, but end differently. Then you can tell
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
211 Vim to use a pattern to find the tag.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
212 Suppose you want to jump to a tag that contains "block". First type
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
213 this: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
214
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
215 :tag /block
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
216
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
217 Now use command line completion: press <Tab>. Vim will find all tags that
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
218 contain "block" and use the first match.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
219 The "/" before a tag name tells Vim that what follows is not a literal tag
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
220 name, but a pattern. You can use all the items for search patterns here. For
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
221 example, suppose you want to select a tag that starts with "write_": >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
222
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
223 :tselect /^write_
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
224
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
225 The "^" specifies that the tag starts with "write_". Otherwise it would also
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
226 be found halfway a tag name. Similarly "$" at the end makes sure the pattern
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
227 matches until the end of a tag.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
228
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
229
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
230 A TAGS BROWSER
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
231
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
232 Since CTRL-] takes you to the definition of the identifier under the cursor,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
233 you can use a list of identifier names as a table of contents. Here is an
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
234 example.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
235 First create a list of identifiers (this requires Exuberant ctags): >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
236
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
237 ctags --c-types=f -f functions *.c
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
238
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
239 Now start Vim without a file, and edit this file in Vim, in a vertically split
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
240 window: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
241
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
242 vim
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
243 :vsplit functions
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
244
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
245 The window contains a list of all the functions. There is some more stuff,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
246 but you can ignore that. Do ":setlocal ts=99" to clean it up a bit.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
247 In this window, define a mapping: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
248
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
249 :nnoremap <buffer> <CR> 0ye<C-W>w:tag <C-R>"<CR>
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
250
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
251 Move the cursor to the line that contains the function you want to go to.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
252 Now press <Enter>. Vim will go to the other window and jump to the selected
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
253 function.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
254
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
255
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
256 RELATED ITEMS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
257
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
258 You can set 'ignorecase' to make case in tag names be ignored.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
259
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
260 The 'tagbsearch' option tells if the tags file is sorted or not. The default
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
261 is to assume a sorted tags file, which makes a tags search a lot faster, but
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
262 doesn't work if the tags file isn't sorted.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
263
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
264 The 'taglength' option can be used to tell Vim the number of significant
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
265 characters in a tag.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
266
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
267 When you use the SNiFF+ program, you can use the Vim interface to it |sniff|.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
268 SNiFF+ is a commercial program.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
269
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
270 Cscope is a free program. It does not only find places where an identifier is
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
271 declared, but also where it is used. See |cscope|.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
272
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
273 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
274 *29.2* The preview window
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
275
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
276 When you edit code that contains a function call, you need to use the correct
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
277 arguments. To know what values to pass you can look at how the function is
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
278 defined. The tags mechanism works very well for this. Preferably the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
279 definition is displayed in another window. For this the preview window can be
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
280 used.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
281 To open a preview window to display the function "write_char": >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
282
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
283 :ptag write_char
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
284
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
285 Vim will open a window, and jumps to the tag "write_char". Then it takes you
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
286 back to the original position. Thus you can continue typing without the need
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
287 to use a CTRL-W command.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
288 If the name of a function appears in the text, you can get its definition
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
289 in the preview window with: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
290
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
291 CTRL-W }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
292
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
293 There is a script that automatically displays the text where the word under
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
294 the cursor was defined. See |CursorHold-example|.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
295
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
296 To close the preview window use this command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
297
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
298 :pclose
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
299
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
300 To edit a specific file in the preview window, use ":pedit". This can be
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
301 useful to edit a header file, for example: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
302
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
303 :pedit defs.h
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
304
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
305 Finally, ":psearch" can be used to find a word in the current file and any
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
306 included files and display the match in the preview window. This is
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
307 especially useful when using library functions, for which you do not have a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
308 tags file. Example: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
309
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
310 :psearch popen
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
311
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
312 This will show the "stdio.h" file in the preview window, with the function
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
313 prototype for popen():
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
314
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
315 FILE *popen __P((const char *, const char *)); ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
316
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
317 You can specify the height of the preview window, when it is opened, with the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
318 'previewheight' option.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
319
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
320 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
321 *29.3* Moving through a program
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
322
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
323 Since a program is structured, Vim can recognize items in it. Specific
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
324 commands can be used to move around.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
325 C programs often contain constructs like this:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
326
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
327 #ifdef USE_POPEN ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
328 fd = popen("ls", "r") ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
329 #else ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
330 fd = fopen("tmp", "w") ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
331 #endif ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
332
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
333 But then much longer, and possibly nested. Position the cursor on the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
334 "#ifdef" and press %. Vim will jump to the "#else". Pressing % again takes
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
335 you to the "#endif". Another % takes you to the "#ifdef" again.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
336 When the construct is nested, Vim will find the matching items. This is a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
337 good way to check if you didn't forget an "#endif".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
338 When you are somewhere inside a "#if" - "#endif", you can jump to the start
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
339 of it with: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
340
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
341 [#
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
342
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
343 If you are not after a "#if" or "#ifdef" Vim will beep. To jump forward to
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
344 the next "#else" or "#endif" use: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
345
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
346 ]#
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
347
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
348 These two commands skip any "#if" - "#endif" blocks that they encounter.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
349 Example:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
350
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
351 #if defined(HAS_INC_H) ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
352 a = a + inc(); ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
353 # ifdef USE_THEME ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
354 a += 3; ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
355 # endif ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
356 set_width(a); ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
357
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
358 With the cursor in the last line, "[#" moves to the first line. The "#ifdef"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
359 - "#endif" block in the middle is skipped.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
360
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
361
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
362 MOVING IN CODE BLOCKS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
363
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
364 In C code blocks are enclosed in {}. These can get pretty long. To move to
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
365 the start of the outer block use the "[[" command. Use "][" to find the end.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
366 This assumes that the "{" and "}" are in the first column.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
367 The "[{" command moves to the start of the current block. It skips over
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
368 pairs of {} at the same level. "]}" jumps to the end.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
369 An overview:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
370
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
371 function(int a)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
372 +-> {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
373 | if (a)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
374 | +-> {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
375 [[ | | for (;;) --+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
376 | | +-> { |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
377 | [{ | | foo(32); | --+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
378 | | [{ | if (bar(a)) --+ | ]} |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
379 +-- | +-- break; | ]} | |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
380 | } <-+ | | ][
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
381 +-- foobar(a) | |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
382 } <-+ |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
383 } <-+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
384
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
385 When writing C++ or Java, the outer {} block is for the class. The next level
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
386 of {} is for a method. When somewhere inside a class use "[m" to find the
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
387 previous start of a method. "]m" finds the next start of a method.
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
388
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
389 Additionally, "[]" moves backward to the end of a function and "]]" moves
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
390 forward to the start of the next function. The end of a function is defined
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
391 by a "}" in the first column.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
392
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
393 int func1(void)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
394 {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
395 return 1;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
396 +----------> }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
397 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
398 [] | int func2(void)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
399 | +-> {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
400 | [[ | if (flag)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
401 start +-- +-- return flag;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
402 | ][ | return 2;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
403 | +-> }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
404 ]] |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
405 | int func3(void)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
406 +----------> {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
407 return 3;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
408 }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
409
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
410 Don't forget you can also use "%" to move between matching (), {} and [].
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
411 That also works when they are many lines apart.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
412
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
413
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
414 MOVING IN BRACES
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
415
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
416 The "[(" and "])" commands work similar to "[{" and "]}", except that they
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
417 work on () pairs instead of {} pairs.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
418 >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
419 [(
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
420 < <--------------------------------
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
421 <-------
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
422 if (a == b && (c == d || (e > f)) && x > y) ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
423 -------------->
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
424 --------------------------------> >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
425 ])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
426
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
427 MOVING IN COMMENTS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
428
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
429 To move back to the start of a comment use "[/". Move forward to the end of a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
430 comment with "]/". This only works for /* - */ comments.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
431
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
432 +-> +-> /*
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
433 | [/ | * A comment about --+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
434 [/ | +-- * wonderful life. | ]/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
435 | */ <-+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
436 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
437 +-- foo = bar * 3; --+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
438 | ]/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
439 /* a short comment */ <-+
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
440
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
441 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
442 *29.4* Finding global identifiers
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
443
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
444 You are editing a C program and wonder if a variable is declared as "int" or
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
445 "unsigned". A quick way to find this is with the "[I" command.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
446 Suppose the cursor is on the word "column". Type: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
447
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
448 [I
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
449
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
450 Vim will list the matching lines it can find. Not only in the current file,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
451 but also in all included files (and files included in them, etc.). The result
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
452 looks like this:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
453
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
454 structs.h ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
455 1: 29 unsigned column; /* column number */ ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
456
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
457 The advantage over using tags or the preview window is that included files are
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
458 searched. In most cases this results in the right declaration to be found.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
459 Also when the tags file is out of date. Also when you don't have tags for the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
460 included files.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
461 However, a few things must be right for "[I" to do its work. First of all,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
462 the 'include' option must specify how a file is included. The default value
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
463 works for C and C++. For other languages you will have to change it.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
464
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
465
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
466 LOCATING INCLUDED FILES
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
467
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
468 Vim will find included files in the places specified with the 'path'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
469 option. If a directory is missing, some include files will not be found. You
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
470 can discover this with this command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
471
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
472 :checkpath
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
473
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
474 It will list the include files that could not be found. Also files included
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
475 by the files that could be found. An example of the output:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
476
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
477 --- Included files not found in path --- ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
478 <io.h> ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
479 vim.h --> ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
480 <functions.h> ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
481 <clib/exec_protos.h> ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
482
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
483 The "io.h" file is included by the current file and can't be found. "vim.h"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
484 can be found, thus ":checkpath" goes into this file and checks what it
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
485 includes. The "functions.h" and "clib/exec_protos.h" files, included by
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
486 "vim.h" are not found.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
487
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
488 Note:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
489 Vim is not a compiler. It does not recognize "#ifdef" statements.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
490 This means every "#include" statement is used, also when it comes
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
491 after "#if NEVER".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
492
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
493 To fix the files that could not be found, add a directory to the 'path'
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
494 option. A good place to find out about this is the Makefile. Look out for
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
495 lines that contain "-I" items, like "-I/usr/local/X11". To add this directory
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
496 use: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
497
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
498 :set path+=/usr/local/X11
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
499
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
500 When there are many subdirectories, you can use the "*" wildcard. Example: >
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
501
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
502 :set path+=/usr/*/include
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
503
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
504 This would find files in "/usr/local/include" as well as "/usr/X11/include".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
505
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
506 When working on a project with a whole nested tree of included files, the "**"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
507 items is useful. This will search down in all subdirectories. Example: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
508
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
509 :set path+=/projects/invent/**/include
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
510
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
511 This will find files in the directories:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
512
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
513 /projects/invent/include ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
514 /projects/invent/main/include ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
515 /projects/invent/main/os/include ~
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
516 etc.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
517
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
518 There are even more possibilities. Check out the 'path' option for info.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
519 If you want to see which included files are actually found, use this
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
520 command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
521
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
522 :checkpath!
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
523
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
524 You will get a (very long) list of included files, the files they include, and
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
525 so on. To shorten the list a bit, Vim shows "(Already listed)" for files that
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
526 were found before and doesn't list the included files in there again.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
527
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
528
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
529 JUMPING TO A MATCH
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
530
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
531 "[I" produces a list with only one line of text. When you want to have a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
532 closer look at the first item, you can jump to that line with the command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
533
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
534 [<Tab>
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
535
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
536 You can also use "[ CTRL-I", since CTRL-I is the same as pressing <Tab>.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
537
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
538 The list that "[I" produces has a number at the start of each line. When you
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
539 want to jump to another item than the first one, type the number first: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
540
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
541 3[<Tab>
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
542
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
543 Will jump to the third item in the list. Remember that you can use CTRL-O to
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
544 jump back to where you started from.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
545
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
546
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
547 RELATED COMMANDS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
548
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
549 [i only lists the first match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
550 ]I only lists items below the cursor
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
551 ]i only lists the first item below the cursor
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
552
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
553
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
554 FINDING DEFINED IDENTIFIERS
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
555
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
556 The "[I" command finds any identifier. To find only macros, defined with
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
557 "#define" use: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
558
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
559 [D
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
560
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
561 Again, this searches in included files. The 'define' option specifies what a
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
562 line looks like that defines the items for "[D". You could change it to make
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
563 it work with other languages than C or C++.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
564 The commands related to "[D" are:
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
565
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
566 [d only lists the first match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
567 ]D only lists items below the cursor
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
568 ]d only lists the first item below the cursor
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
569
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
570 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
571 *29.5* Finding local identifiers
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
572
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
573 The "[I" command searches included files. To search in the current file only,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
574 and jump to the first place where the word under the cursor is used: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
575
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
576 gD
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
577
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
578 Hint: Goto Definition. This command is very useful to find a variable or
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
579 function that was declared locally ("static", in C terms). Example (cursor on
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
580 "counter"):
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
581
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
582 +-> static int counter = 0;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
583 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
584 | int get_counter(void)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
585 gD | {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
586 | ++counter;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
587 +-- return counter;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
588 }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
589
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
590 To restrict the search even further, and look only in the current function,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
591 use this command: >
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
592
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
593 gd
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
594
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
595 This will go back to the start of the current function and find the first
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
596 occurrence of the word under the cursor. Actually, it searches backwards to
34
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
597 an empty line above a "{" in the first column. From there it searches forward
e170173ecb68 before ack base protocol.
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 0
diff changeset
598 for the identifier. Example (cursor on "idx"):
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
599
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
600 int find_entry(char *name)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
601 {
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
602 +-> int idx;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
603 |
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
604 gd | for (idx = 0; idx < table_len; ++idx)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
605 | if (strcmp(table[idx].name, name) == 0)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
606 +-- return idx;
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
607 }
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
608
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
609 ==============================================================================
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
610
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
611 Next chapter: |usr_30.txt| Editing programs
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
612
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
613 Copyright: see |manual-copyright| vim:tw=78:ts=8:ft=help:norl: