⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 faq

📁 Exuberant Ctags is a multilanguage reimplementation of the much-underused ctags(1) program and is i
💻
📖 第 1 页 / 共 2 页
字号:
There are a few ways of approaching this:1.  A local tag file in each directory containing only the tags for source    files in that directory.2.  One single big, global tag file present in the root directory of your    hierarchy, containing all tags present in all source files in the    hierarchy.3.  A local tag file in each directory containing only the tags for source    files in that directory, in addition to one single global tag file    present in the root directory of your hierarchy, containing all    non-static tags present in all source files in the hierarchy.4.  A local tag file in each directory of the hierarchy, each one    containing all tags present in source files in that directory and all    non-static tags in every directory below it (note that this implies    also having one big tag file in the root directory of the hierarchy).Each of these approaches has its own set of advantages and disadvantages,depending upon your particular conditions. Which approach is deemed bestdepends upon the following factors:A.  The ability of your editor to use multiple tag files.    If your editor cannot make use of multiple tag files (original vi    implementations could not), then one large tag file is the only way to    go if you ever desire to jump to tags located in other directories. If    you never need to jump to tags in another directory (i.e. the source    in each directory is entirely self-contained), then a local tag file    in each directory will fit your needs.B.  The time is takes for your editor to look up a tag in the tag file.    The significance of this factor depends upon the size of your source    tree and on whether the source files are located on a local or remote    file system. For source and tag files located on a local file system,    looking up a tag is not as big a hit as one might first imagine, since    vi implementations typically perform a binary search on a sorted tag    file. This may or may not be true for the editor you use. For files    located on a remote file system, reading a large file is an expensive    operation.C.  Whether or not you expect the source code to change and the time it    takes to rebuild a tag file to account for changes to the source code.    While Exuberant Ctags is particularly fast in scanning source code    (around 1-2 MB/sec), a large project may still result in objectionable    delays if one wishes to keep their tag file(s) up to date on a    frequent basis, or if the files are located on a remote file system.D.  The presence of duplicate tags in the source code and the ability to    handle them.    The impact of this factor is influenced by the following three issues:    1.  How common are duplicate tags in your project?    2.  Does your editor provide any facilities for dealing with duplicate        tags?        While standard vi does not, many modern vi implementations, such        as Vim have good facilities for selecting the desired match from        the list of duplicates. If your editor does not support duplicate        tags, then it will typically send you to only one of them, whether        or not that is the one you wanted (and not even notifying you that        there are other potential matches).    3.  What is the significance of duplicate tags?        For example, if you have two tags of the same name from entirely        isolated software components, jumping first to the match found        in component B while working in component A may be entirely        misleading, distracting or inconvenient (to keep having to choose        which one if your editor provides you with a list of matches).        However, if you have two tags of the same name for parallel builds        (say two initialization routines for different hosts), you may        always want to specify which one you want.Of the approaches listed above, I tend to favor Approach 3. My editor ofchoice is Vim, which provides a rich set of features for handling multipletag files, which partly influences my choice. If you are working withsource files on a remote file system, then I would recommend eitherApproach 3 or Approach 4, depending upon the hit when reading the globaltag file.The advantages of Approach 3 are many (assuming that your editor hasthe ability to support both multiple tag files and duplicate tags). Alllookups of tag located in the currect directory are fast and the localtag file can be quickly and easily regenerated in one second or less(I have even mapped a keystroke to do this easily). A lookup of a(necessarily non-static) tag found in another directory fails a lookup inthe local tag file, but is found in the global tag file, which satisfiesall cross-directory lookups. The global tag file can be automaticallyregenerated periodically with a cron job (and perhaps the local tag filesalso).Now I give an example of how you would implement Approach 3. Means ofimplementing the other approaches can be performed in a similar manner.Here is a visual representation of an example directory hierarchy:project  `-----misccomp  |       `...  `-----sysint          `-----client          |       `-----hdrs          |       `-----lib          |       `-----src          |       `-----test          `-----common          |       `-----hdrs          |       `-----lib          |       `-----src          |       `-----test          `-----server                  `-----hdrs                  `-----lib                  `-----src                  `-----testHere is a recommended solution (conceptually) to build the tag files:1.  Within each of the leaf nodes (i.e. hdrs, lib, src, test) build a tag    file using "ctags *.[ch]". This can be easily be done for the whole    hierarchy by making a shell script, call it "dirtags", containing the    following lines:        #!/bin/sh	cd $1	ctags *    Now execute the following command:        find * -type d -exec dirtags {} \;    These tag files are trivial (and extremely quick) to rebuild while    making changes within a directory. The following Vim key mapping is    quite useful to rebuild the tag file in the directory of the current    source file:        :nmap ,t :!(cd %:p:h;ctags *.[ch])&<CR><CR>2.  Build the global tag file:        cd ~/project        ctags --file-scope=no -R    thus constructing a tag file containing only non-static tags for all    source files in all descendent directories.3.  Configure your editor to read the local tag file first, then consult    the global tag file when not found in the local tag file. In Vim,    this is done as follows:        :set tags=./tags,tags,~/project/tagsIf you wish to implement Approach 4, you would need to replace the"dirtags" script of step 1 with the following:        #!/bin/sh	cd $1	ctags *	# Now append the non-static tags from descendent directories	find * -type d -prune -print | ctags -aR --file-scope=no -L-And replace the configuration of step 3 with this:        :set tags=./tags,./../tags,./../../tags,./../../../tags,tagsAs a caveat, it should be noted that step 2 builds a global tag file whosefile names will be relative to the directory in which the global tag fileis being built. This takes advantage of the Vim 'tagrelative' option,which causes the path to be interpreted a relative to the location of thetag file instead of the current directory. For standard vi, which alwaysinterprets the paths as relative to the current directory, we need tobuild the global tag file with absolute path names. This can beaccomplished by replacing step 2 with the following:        cd ~/project	ctags --file-scope=no -R `pwd`--

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -