cscope_maps.vim 7.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165
  1. """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
  2. " CSCOPE settings for vim
  3. """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
  4. "
  5. " This file contains some boilerplate settings for vim's cscope interface,
  6. " plus some keyboard mappings that I've found useful.
  7. "
  8. " USAGE:
  9. " -- vim 6: Stick this file in your ~/.vim/plugin directory (or in a
  10. " 'plugin' directory in some other directory that is in your
  11. " 'runtimepath'.
  12. "
  13. " -- vim 5: Stick this file somewhere and 'source cscope.vim' it from
  14. " your ~/.vimrc file (or cut and paste it into your .vimrc).
  15. "
  16. " NOTE:
  17. " These key maps use multiple keystrokes (2 or 3 keys). If you find that vim
  18. " keeps timing you out before you can complete them, try changing your timeout
  19. " settings, as explained below.
  20. "
  21. " Happy cscoping,
  22. "
  23. " Jason Duell jduell@alumni.princeton.edu 2002/3/7
  24. """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
  25. " This tests to see if vim was configured with the '--enable-cscope' option
  26. " when it was compiled. If it wasn't, time to recompile vim...
  27. if has("cscope")
  28. """"""""""""" Standard cscope/vim boilerplate
  29. " use both cscope and ctag for 'ctrl-]', ':ta', and 'vim -t'
  30. set cscopetag
  31. " check cscope for definition of a symbol before checking ctags: set to 1
  32. " if you want the reverse search order.
  33. set csto=0
  34. " add any cscope database in current directory
  35. if filereadable("cscope.out")
  36. cs add cscope.out
  37. " else add the database pointed to by environment variable
  38. elseif $CSCOPE_DB != ""
  39. cs add $CSCOPE_DB
  40. endif
  41. " show msg when any other cscope db added
  42. set cscopeverbose
  43. """"""""""""" My cscope/vim key mappings
  44. "
  45. " The following maps all invoke one of the following cscope search types:
  46. "
  47. " 's' symbol: find all references to the token under cursor
  48. " 'g' global: find global definition(s) of the token under cursor
  49. " 'c' calls: find all calls to the function name under cursor
  50. " 't' text: find all instances of the text under cursor
  51. " 'e' egrep: egrep search for the word under cursor
  52. " 'f' file: open the filename under cursor
  53. " 'i' includes: find files that include the filename under cursor
  54. " 'd' called: find functions that function under cursor calls
  55. "
  56. " Below are three sets of the maps: one set that just jumps to your
  57. " search result, one that splits the existing vim window horizontally and
  58. " diplays your search result in the new window, and one that does the same
  59. " thing, but does a vertical split instead (vim 6 only).
  60. "
  61. " I've used CTRL-\ and CTRL-@ as the starting keys for these maps, as it's
  62. " unlikely that you need their default mappings (CTRL-\'s default use is
  63. " as part of CTRL-\ CTRL-N typemap, which basically just does the same
  64. " thing as hitting 'escape': CTRL-@ doesn't seem to have any default use).
  65. " If you don't like using 'CTRL-@' or CTRL-\, , you can change some or all
  66. " of these maps to use other keys. One likely candidate is 'CTRL-_'
  67. " (which also maps to CTRL-/, which is easier to type). By default it is
  68. " used to switch between Hebrew and English keyboard mode.
  69. "
  70. " All of the maps involving the <cfile> macro use '^<cfile>$': this is so
  71. " that searches over '#include <time.h>" return only references to
  72. " 'time.h', and not 'sys/time.h', etc. (by default cscope will return all
  73. " files that contain 'time.h' as part of their name).
  74. " To do the first type of search, hit 'CTRL-\', followed by one of the
  75. " cscope search types above (s,g,c,t,e,f,i,d). The result of your cscope
  76. " search will be displayed in the current window. You can use CTRL-T to
  77. " go back to where you were before the search.
  78. "
  79. nmap <C-\>s :cs find s <C-R>=expand("<cword>")<CR><CR>
  80. nmap <C-\>g :cs find g <C-R>=expand("<cword>")<CR><CR>
  81. nmap <C-\>c :cs find c <C-R>=expand("<cword>")<CR><CR>
  82. nmap <C-\>t :cs find t <C-R>=expand("<cword>")<CR><CR>
  83. nmap <C-\>e :cs find e <C-R>=expand("<cword>")<CR><CR>
  84. nmap <C-\>f :cs find f <C-R>=expand("<cfile>")<CR><CR>
  85. nmap <C-\>i :cs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
  86. nmap <C-\>d :cs find d <C-R>=expand("<cword>")<CR><CR>
  87. " Using 'CTRL-spacebar' (intepreted as CTRL-@ by vim) then a search type
  88. " makes the vim window split horizontally, with search result displayed in
  89. " the new window.
  90. "
  91. " (Note: earlier versions of vim may not have the :scs command, but it
  92. " can be simulated roughly via:
  93. " nmap <C-@>s <C-W><C-S> :cs find s <C-R>=expand("<cword>")<CR><CR>
  94. nmap <C-@>s :scs find s <C-R>=expand("<cword>")<CR><CR>
  95. nmap <C-@>g :scs find g <C-R>=expand("<cword>")<CR><CR>
  96. nmap <C-@>c :scs find c <C-R>=expand("<cword>")<CR><CR>
  97. nmap <C-@>t :scs find t <C-R>=expand("<cword>")<CR><CR>
  98. nmap <C-@>e :scs find e <C-R>=expand("<cword>")<CR><CR>
  99. nmap <C-@>f :scs find f <C-R>=expand("<cfile>")<CR><CR>
  100. nmap <C-@>i :scs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
  101. nmap <C-@>d :scs find d <C-R>=expand("<cword>")<CR><CR>
  102. " Hitting CTRL-space *twice* before the search type does a vertical
  103. " split instead of a horizontal one (vim 6 and up only)
  104. "
  105. " (Note: you may wish to put a 'set splitright' in your .vimrc
  106. " if you prefer the new window on the right instead of the left
  107. nmap <C-@><C-@>s :vert scs find s <C-R>=expand("<cword>")<CR><CR>
  108. nmap <C-@><C-@>g :vert scs find g <C-R>=expand("<cword>")<CR><CR>
  109. nmap <C-@><C-@>c :vert scs find c <C-R>=expand("<cword>")<CR><CR>
  110. nmap <C-@><C-@>t :vert scs find t <C-R>=expand("<cword>")<CR><CR>
  111. nmap <C-@><C-@>e :vert scs find e <C-R>=expand("<cword>")<CR><CR>
  112. nmap <C-@><C-@>f :vert scs find f <C-R>=expand("<cfile>")<CR><CR>
  113. nmap <C-@><C-@>i :vert scs find i ^<C-R>=expand("<cfile>")<CR>$<CR>
  114. nmap <C-@><C-@>d :vert scs find d <C-R>=expand("<cword>")<CR><CR>
  115. """"""""""""" key map timeouts
  116. "
  117. " By default Vim will only wait 1 second for each keystroke in a mapping.
  118. " You may find that too short with the above typemaps. If so, you should
  119. " either turn off mapping timeouts via 'notimeout'.
  120. "
  121. "set notimeout
  122. "
  123. " Or, you can keep timeouts, by uncommenting the timeoutlen line below,
  124. " with your own personal favorite value (in milliseconds):
  125. "
  126. "set timeoutlen=4000
  127. "
  128. " Either way, since mapping timeout settings by default also set the
  129. " timeouts for multicharacter 'keys codes' (like <F1>), you should also
  130. " set ttimeout and ttimeoutlen: otherwise, you will experience strange
  131. " delays as vim waits for a keystroke after you hit ESC (it will be
  132. " waiting to see if the ESC is actually part of a key code like <F1>).
  133. "
  134. "set ttimeout
  135. "
  136. " personally, I find a tenth of a second to work well for key code
  137. " timeouts. If you experience problems and have a slow terminal or network
  138. " connection, set it higher. If you don't set ttimeoutlen, the value for
  139. " timeoutlent (default: 1000 = 1 second, which is sluggish) is used.
  140. "
  141. "set ttimeoutlen=100
  142. endif