Answers:
ctags具有两个功能:允许您从函数调用跳转到其定义,以及全方位完成。第一种意味着,当您结束对某个方法的调用时,点击g]
或CTRL-]
将跳至定义或实现该方法的位置。第二个功能意味着,当您键入foo.
或时foo->
,并且如果foo是一个结构,则将显示一个带有字段完成功能的弹出菜单。
cscope还具有第一个功能-使用set cscopetag
-但没有最后一个功能。但是,cscope还增加了跳转到任何调用函数的地方的功能。
因此,就跳转代码库而言,ctags只会将您引向实现该功能的地方,而cscope可以向您显示调用函数的位置。
为什么要选择一个?好吧,我都用。ctags易于设置,运行速度更快,如果您只关心一种跳跃方式,它将显示更少的行。您可以运行:!ctags -R .
并g]
运行。它还使该功能变得完整。
Cscope适用于更大,未知的代码库。设置很麻烦,因为cscope需要一个包含要解析的文件名列表的文件。同样在vim中,默认情况下没有设置键绑定-您需要:cscope blah blah
手动运行。
为了解决第一个问题,我有一个bash脚本cscope_gen.sh
,如下所示:
#!/bin/sh
find . -name '*.py' \
-o -name '*.java' \
-o -iname '*.[CH]' \
-o -name '*.cpp' \
-o -name '*.cc' \
-o -name '*.hpp' \
> cscope.files
# -b: just build
# -q: create inverted index
cscope -b -q
这将搜索我感兴趣的代码,创建cscope.files列表并创建数据库。这样,我可以运行“:!cscope_gen.sh”,而不必记住所有设置步骤。
我使用此代码段将cscope搜索映射到ctrl-space x 2,这减轻了cscope的其他缺点:
nmap <C-@><C-@> :cs find s <C-R>=expand("<cword>")<CR><CR>
有一个cscope_maps.vim插件,它设置了许多类似的绑定。我永远都不记得所有选项的含义,因此倾向于使用ctrl-space。
因此可以得出结论:ctags更易于设置,并且无需做很多其他事情就可以正常工作,这对于全面实现也是至关重要的。如果您必须维护大型且几乎未知的代码库,则cscope提供了更多功能,但是需要更多的工作。
cscopetag
(cst
),使:tag
and CTRL-]
命令首先通过cscope搜索,然后搜索标签
g C-]
,vim将向您显示与名称匹配的标签列表。您仍然需要手动查找正确的定义。
几个月前我处于同样的情况...
ctags的精度不足是一个麻烦..,我发现cscope对于所有与宏相关的东西都更好(并且Linux内核中有很多宏)。
关于用法,这实际上很简单……您只需在内核根目录下键入cscope -R,然后您就不必担心了。
然后,键绑定全部基于Ctrl-\(如果您对Ctrl过敏,可以重新映射它),主要使用s和g ....,
为内核而开发,我并不需要那么多的完成。
无论如何,使用cscope,这更加方便,准确。
嗯...您可能应该使用etags而不是ctags ...
如果使用cscope,则可以看到调用链,即谁调用了此函数,以及该函数调用了哪些函数?
我不确定是否可以使用etags / ctags完成...
那只是一个功能...找出包含特定函数定义的文件该怎么办?这只能在cscope中获得。
我用这两个 cscope的和ETag的,他们都是很好的不同的东西,有一个大的代码库工作特别是,如Linux内核。实际上,当我开始使用Linux Kernel / Xen时,我就开始使用cscope和etags。
LXR并不是很好,因为您必须单击,通过网络等,而您可以在内核代码上构建cscope和标记数据库,而不必通过网络(与lxr不同)。
make tags
在内核根目录中进行操作,并且一直在跳来跳去,大部分时间都放在错误的位置。我读到ctags在c预处理器上有问题,但是考虑到lxr中使用了ctags,显然必须可以做一些事情。