From 41c0ebdaab3382710a049634c3b03072e69500c3 Mon Sep 17 00:00:00 2001 From: Jannik ZANDER Date: Sat, 7 Jul 2018 08:59:05 +0200 Subject: [PATCH] Add global vim plugin --- .../opt/vim-gtags/plugin/gtags-cscope.vim | 273 +++++++++ .vim/pack/jaza/opt/vim-gtags/plugin/gtags.vim | 565 ++++++++++++++++++ 2 files changed, 838 insertions(+) create mode 100644 .vim/pack/jaza/opt/vim-gtags/plugin/gtags-cscope.vim create mode 100644 .vim/pack/jaza/opt/vim-gtags/plugin/gtags.vim diff --git a/.vim/pack/jaza/opt/vim-gtags/plugin/gtags-cscope.vim b/.vim/pack/jaza/opt/vim-gtags/plugin/gtags-cscope.vim new file mode 100644 index 0000000..3b6ab11 --- /dev/null +++ b/.vim/pack/jaza/opt/vim-gtags/plugin/gtags-cscope.vim @@ -0,0 +1,273 @@ +" File: gtags-cscope.vim +" Author: Tama Communications Corporation +" Version: 0.4.1 +" Last Modified: September 10, 2014 +" +" Copyright and license +" --------------------- +" Copyright (c) 2010, 2011 Tama Communications Corporation +" +" This file is part of GNU GLOBAL. +" +" This program is free software: you can redistribute it and/or modify +" it under the terms of the GNU General Public License as published by +" the Free Software Foundation, either version 3 of the License, or +" (at your option) any later version. +" +" This program is distributed in the hope that it will be useful, +" but WITHOUT ANY WARRANTY; without even the implied warranty of +" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +" GNU General Public License for more details. +" +" You should have received a copy of the GNU General Public License +" along with this program. If not, see . +" +" Overview +" -------- +" The gtags-cscope.vim plugin script integrates the GNU GLOBAL source code tagging system +" with Vim using cscope interface. +" +" Installation +" ------------ +" Drop the file in your plugin directory or source it from your vimrc. +" To use this script, you need the GNU GLOBAL-5.8 or later installed +" in your machine. +" +" Usage +" ----- +" First of all, you must execute gtags(1) at the root of source directory +" to make tag files. Assuming that your source directory is '/var/src', +" it is neccessary to execute the following commands. +" +" [Load vim] +" $ cd /var/src +" $ gtags +" $ vim +" [Load gtags-cscope] +" :GtagsCscope (in vim command line) +" +" Basic command +" ------------- +" Then you can use cs commands except for the 'd'(2) command. +" Profitable commands are assigned to keys like follows: +" +" explanation command +" ---------------------------------------------------------- +" Find symbol :cs find 0 or s +" Find definition :cs find 1 or g +" Find functions called by this function (not implemented) +" Find reference :cs find 3 or c +" Find text string :cs find 4 or t +" Find egrep pattern :cs find 6 or e +" Find path :cs find 7 or f +" Find include file :cs find 8 or i +" +" You can move tag list using: +" Go to the next tag :tn +" Go to the previous tag :tp +" Pop tag stack :pop +" +" About the other tag command, you can see the help like this: +" +" :h tagsrch +" +" Enhancing command +" ----------------- +" You can use the context jump function. To use this function, put the cursor +" on a word and type . +" If you can use mouse then please double click on the left button. +" To pop tag, please type 'g' and click on the right button. +" +" Configure +" --------- +" You can use the following variables in $HOME/.vimrc. +" +" To use the default key/mouse mapping: +" let GtagsCscope_Auto_Map = 1 +" To ignore letter case when searching: +" let GtagsCscope_Ignore_Case = 1 +" To use absolute path name: +" let GtagsCscope_Absolute_Path = 1 +" To deterring interruption: +" let GtagsCscope_Keep_Alive = 1 +" If you hope auto loading: +" let GtagsCscope_Auto_Load = 1 +" To use 'vim -t ', ':tag' and '' +" set cscopetag +" +if exists("loaded_gtags_cscope") + finish +endif +if !has("cscope") + echohl WarningMsg | + \ echomsg 'Gtags-cscope: ' . 'This vim does not include cscope support.' | + \ echohl None + finish +endif +" +" global command name +" +let s:global_command = $GTAGSGLOBAL +if s:global_command == '' + let s:global_command = "global" +endif +if !exists("GtagsCscope_Auto_Load") + let GtagsCscope_Auto_Load = 0 +endif +if !exists("GtagsCscope_Auto_Map") + let GtagsCscope_Auto_Map = 0 +endif +if !exists("GtagsCscope_Use_Old_Key_Map") + let GtagsCscope_Use_Old_Key_Map = 0 +endif +if !exists("GtagsCscope_Quiet") + let GtagsCscope_Quiet = 0 +endif +if !exists("GtagsCscope_Ignore_Case") + let GtagsCscope_Ignore_Case = 0 +endif +if !exists("GtagsCscope_Absolute_Path") + let GtagsCscope_Absolute_Path = 0 +endif +if !exists("GtagsCscope_Keep_Alive") + let GtagsCscope_Keep_Alive = 0 +endif + +" +" Display error message. +" +function! s:Error(msg) + if (g:GtagsCscope_Quiet == 0) + echohl WarningMsg | + \ echomsg 'Gtags-cscope: ' . a:msg | + \ echohl None + endif +endfunction + +function! s:GtagsCscope_GtagsRoot() + let cmd = s:global_command . " -pq" + let cmd_output = system(cmd) + if v:shell_error != 0 + if v:shell_error == 3 + call s:Error('GTAGS not found.') + else + call s:Error('global command failed. command line: ' . cmd) + endif + return '' + endif + return strpart(cmd_output, 0, strlen(cmd_output) - 1) +endfunction + +function! s:GtagsCscope() + " + " Get gtagsroot directory. + " + let gtagsroot = s:GtagsCscope_GtagsRoot() + if gtagsroot == '' + return + endif + " + " Load gtags-cscope. + " + set csprg=gtags-cscope + let s:command = "cs add " . gtagsroot . "/GTAGS" + let s:option = '' + if g:GtagsCscope_Ignore_Case == 1 + let s:option = s:option . 'C' + endif + if g:GtagsCscope_Absolute_Path == 1 + let s:option = s:option . 'a' + endif + if g:GtagsCscope_Keep_Alive == 1 + let s:option = s:option . 'i' + endif + if s:option != '' + let s:command = s:command . ' . -' . s:option + endif + set nocscopeverbose + exe s:command + set cscopeverbose + " + " Key mapping + " + if g:GtagsCscope_Auto_Map == 1 + if g:GtagsCscope_Use_Old_Key_Map == 1 + " normal command + :nmap s :cs find s =expand("") + :nmap t :cs find g =expand("") + :nmap r :cs find c =expand("") + :nmap g :cs find e =expand("") + :nmap P :cs find f + " Using 'CTRL-spacebar', the result is displayed in new horizontal window. + :nmap s :scs find s =expand("") + :nmap t :scs find g =expand("") + :nmap r :scs find c =expand("") + :nmap g :scs find e =expand("") + :nmap P :scs find f + " Hitting CTRL-space *twice*, the result is displayed in new vertical window. + :nmap s :vert scs find s =expand("") + :nmap t :vert scs find g =expand("") + :nmap r :vert scs find c =expand("") + :nmap g :vert scs find e =expand("") + :nmap P :vert scs find f + else + " + " The following key mappings are derived from 'cscope_maps.vim'. + " (The 'd' command is not implemented in gtags-cscope.) + " + " normal command + :nmap s :cs find s =expand("") + :nmap g :cs find g =expand("") + :nmap c :cs find c =expand("") + :nmap t :cs find t =expand("") + :nmap e :cs find e =expand("") + :nmap f :cs find f =expand("") + :nmap i :cs find i =expand("") + ":nmap d :cs find d =expand("") + " Using 'CTRL-spacebar', the result is displayed in new horizontal window. + :nmap s :scs find s =expand("") + :nmap g :scs find g =expand("") + :nmap c :scs find c =expand("") + :nmap t :scs find t =expand("") + :nmap e :scs find e =expand("") + :nmap f :scs find f =expand("") + :nmap i :scs find i =expand("") + ":nmap d :scs find d =expand("") + " Hitting CTRL-space *twice*, the result is displayed in new vertical window. + :nmap s :vert scs find s =expand("") + :nmap g :vert scs find g =expand("") + :nmap c :vert scs find c =expand("") + :nmap t :vert scs find t =expand("") + :nmap e :vert scs find e =expand("") + :nmap f :vert scs find f =expand("") + :nmap i :vert scs find i =expand("") + ":nmap d :vert scs find d =expand("") + endif + " tag command + :nmap :tn + :nmap :tp + :nmap :cn + :nmap :cp + " Context search. See the --from-here option of global(1). + :nmap :cs find d =expand(""):=line('.'):% + :nmap <2-LeftMouse> :cs find d =expand(""):=line('.'):% + :nmap g :cs find d =expand(""):=line('.'):% + :nmap :cs find d =expand(""):=line('.'):% + " The following mappings are unnecessary, because you can use the default mapping. + ":nmap g + ":nmap + " Short cut key + :nmap :cs find + :nmap :scs find + :nmap :vert scs find + :nmap :copen + :nmap :cs find d =expand(""):=line('.'):% + :nmap :cclose + endif +endfunction + +if g:GtagsCscope_Auto_Load == 1 + call s:GtagsCscope() +endif +command! -nargs=0 GtagsCscope call s:GtagsCscope() +let loaded_gtags_cscope = 1 diff --git a/.vim/pack/jaza/opt/vim-gtags/plugin/gtags.vim b/.vim/pack/jaza/opt/vim-gtags/plugin/gtags.vim new file mode 100644 index 0000000..947d216 --- /dev/null +++ b/.vim/pack/jaza/opt/vim-gtags/plugin/gtags.vim @@ -0,0 +1,565 @@ +" File: gtags.vim +" Author: Tama Communications Corporation +" Version: 0.6.8 +" Last Modified: Nov 9, 2015 +" +" Copyright and license +" --------------------- +" Copyright (c) 2004, 2008, 2010, 2011, 2012, 2014, 2015 +" Tama Communications Corporation +" +" This file is part of GNU GLOBAL. +" +" This program is free software: you can redistribute it and/or modify +" it under the terms of the GNU General Public License as published by +" the Free Software Foundation, either version 3 of the License, or +" (at your option) any later version. +" +" This program is distributed in the hope that it will be useful, +" but WITHOUT ANY WARRANTY; without even the implied warranty of +" MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +" GNU General Public License for more details. +" +" You should have received a copy of the GNU General Public License +" along with this program. If not, see . +" +" Overview +" -------- +" The gtags.vim plug-in script integrates the GNU GLOBAL source code tagging system +" with Vim. About the details, see http://www.gnu.org/software/global/. +" +" Installation +" ------------ +" Drop the file in your plug-in directory or source it from your vimrc. +" To use this script, you need GLOBAL-6.0 or later installed in your machine. +" +" Usage +" ----- +" First of all, you must execute gtags(1) at the root of source directory +" to make tag files. Assuming that your source directory is '/var/src', +" it is necessary to execute the following commands. +" +" $ cd /var/src +" $ gtags +" +" And you will find three tag files in the directory. +" +" $ ls G* +" GPATH GRTAGS GTAGS +" +" General form of Gtags command is as follows: +" +" :Gtags [option] pattern +" +" You can use all options of global(1) except for the -c, -p, -u and +" all long name options. They are sent to global(1) as is. +" +" To go to 'func', you can say +" +" :Gtags func +" +" Input completion is available. If you forgot the name of a function +" but recall only some characters of the head, please input them and +" press key. +" +" :Gtags fu +" :Gtags func <- Vim will append 'nc'. +" +" If you omitted an argument, vim ask it as follow: +" +" Gtags for pattern: +" +" Inputting 'main' to the prompt, vim executes `global -x main', +" parse the output, list located objects in the quickfix window +" and load the first entry. The quickfix window shows like this: +" +" gozilla/gozilla.c|200| main(int argc, char **argv) +" gtags-cscope/gtags-cscope.c|124| main(int argc, char **argv) +" gtags-parser/asm_scan.c|2056| int main() +" gtags-parser/gctags.c|157| main(int argc, char **argv) +" gtags-parser/php.c|2116| int main() +" gtags/gtags.c|152| main(int argc, char **argv) +" [Quickfix List] +" +" You can go to any entry using quickfix command. +" +" :cn' +" go to the next line. +" +" :cp' +" go to the previous line. +" +" :ccN' +" go to the Nth line. +" +" :cl' +" list all lines. +" +" You can see a help for quickfix like this: +" +" :h quickfix +" +" You can use POSIX regular expression too. It requires more execution time though. +" +" :Gtags ^[sg]et_ +" +" It will match to both of 'set_value' and 'get_value'. +" +" To go to the referenced point of 'func', add -r option. +" +" :Gtags -r func +" +" To go to any symbols which are not defined in GTAGS, try this. +" +" :Gtags -s func +" +" To go to any string other than symbol, try this. +" +" :Gtags -g ^[sg]et_ +" +" This command accomplishes the same function as grep(1) but is more convenient +" because it retrieves an entire directory structure. +" +" To get list of objects in a file 'main.c', use -f command. +" +" :Gtags -f main.c +" +" If you are editing `main.c' itself, you can use '%' instead. +" +" :Gtags -f % +" +" You can get a list of files whose path include specified pattern. +" For example: +" +" :Gtags -P /vm/ <- all files under 'vm' directory. +" :Gtags -P \.h$ <- all include files. +" :Gtags -P init <- all paths includes 'init' +" +" If you omitted an argument and input only key to the prompt, +" vim shows list of all files in the project. +" +" Since all short options are sent to global(1) as is, you can +" use the -i, -o, -O, and so on. +" +" For example, if you want to ignore case distinctions in pattern. +" +" :Gtags -gi paTtern +" +" It will match to both of 'PATTERN' and 'pattern'. +" +" If you want to search a pattern which starts with a hyphen like '-C' +" then you can use the -e option like grep(1). +" +" :Gtags -ge -C +" +" By default, Gtags command search only in source files. If you want to +" search in both source files and text files, or only in text files then +" +" :Gtags -go pattern # both source and text +" :Gtags -gO pattern # only text file +" +" See global(1) for other options. +" +" The Gtagsa (Gtags + append) command is almost the same as Gtags command. +" But it differs from Gtags in that it adds the results to the present list. +" If you want to get the union of ':Gtags -d foo' and ':Gtags -r foo' then +" you can invoke the following commands: +" +" :Gtags -d foo +" :Gtagsa -r foo +" +" The GtagsCursor command brings you to the definition or reference of +" the current token. If it is a definition, you are taken to the references. +" If it is a reference, you are taken to the definitions. +" +" :GtagsCursor +" +" If you have the hypertext generated by htags(1) then you can display +" the same place on mozilla browser. Let's load mozilla and try this: +" +" :Gozilla +" +" If you want to load vim with all main()s then following command line is useful. +" +" % vim '+Gtags main' +" +" Also see the chapter of 'vim editor' of the on-line manual of GLOBAL. +" +" % info global +" +" The following custom variables are available. +" +" Gtags_VerticalWindow open windows vitically +" Gtags_Auto_Map use a suggested key-mapping +" Gtags_Auto_Update keep tag files up-to-date automatically +" Gtags_No_Auto_Jump don't jump to the first tag at the time of search +" Gtags_Close_When_Single close quickfix windows in case of single tag +" +" You can use the variables like follows: +" +" [$HOME/.vimrc] +" let Gtags_Auto_Map = 1 +" +" If you want to use the tag stack, please use gtags-cscope.vim. +" You can use the plug-in together with this script. +" +if exists("loaded_gtags") + finish +endif + +" +" global command name +" +let s:global_command = $GTAGSGLOBAL +if s:global_command == '' + let s:global_command = "global" +endif +" Open the Gtags output window. Set this variable to zero, to not open +" the Gtags output window by default. You can open it manually by using +" the :cwindow command. +" (This code was derived from 'grep.vim'.) +if !exists("g:Gtags_OpenQuickfixWindow") + let g:Gtags_OpenQuickfixWindow = 1 +endif + +if !exists("g:Gtags_VerticalWindow") + let g:Gtags_VerticalWindow = 0 +endif + +if !exists("g:Gtags_Auto_Map") + let g:Gtags_Auto_Map = 0 +endif + +if !exists("g:Gtags_Auto_Update") + let g:Gtags_Auto_Update = 0 +endif + +" 'Dont_Jump_Automatically' is deprecated. +if !exists("g:Gtags_No_Auto_Jump") + if !exists("g:Dont_Jump_Automatically") + let g:Gtags_No_Auto_Jump = 0 + else + let g:Gtags_No_Auto_Jump = g:Dont_Jump_Automatically + endif +endif + +if !exists("g:Gtags_Close_When_Single") + let g:Gtags_Close_When_Single = 0 +endif + +" -- ctags-x format +" let Gtags_Result = "ctags-x" +" let Gtags_Efm = "%*\\S%*\\s%l%\\s%f%\\s%m" +" +" -- ctags format +" let Gtags_Result = "ctags" +" let Gtags_Efm = "%m\t%f\t%l" +" +" Gtags_Use_Tags_Format is obsoleted. +if exists("g:Gtags_Use_Tags_Format") + let g:Gtags_Result = "ctags" + let g:Gtags_Efm = "%m\t%f\t%l" +endif +if !exists("g:Gtags_Result") + let g:Gtags_Result = "ctags-mod" +endif +if !exists("g:Gtags_Efm") + let g:Gtags_Efm = "%f\t%l\t%m" +endif +" Character to use to quote patterns and file names before passing to global. +" (This code was drived from 'grep.vim'.) +if !exists("g:Gtags_Shell_Quote_Char") + if has("win32") || has("win16") || has("win95") + let g:Gtags_Shell_Quote_Char = '"' + else + let g:Gtags_Shell_Quote_Char = "'" + endif +endif +if !exists("g:Gtags_Single_Quote_Char") + if has("win32") || has("win16") || has("win95") + let g:Gtags_Single_Quote_Char = "'" + let g:Gtags_Double_Quote_Char = '\"' + else + let s:sq = "'" + let s:dq = '"' + let g:Gtags_Single_Quote_Char = s:sq . s:dq . s:sq . s:dq . s:sq + let g:Gtags_Double_Quote_Char = '"' + endif +endif + +" +" Display error message. +" +function! s:Error(msg) + echohl WarningMsg | + \ echomsg 'Error: ' . a:msg | + \ echohl None +endfunction +" +" Extract pattern or option string. +" +function! s:Extract(line, target) + let l:option = '' + let l:pattern = '' + let l:force_pattern = 0 + let l:length = strlen(a:line) + let l:i = 0 + + " skip command name. + if a:line =~# '^Gtags' + let l:i = 5 + endif + while l:i < l:length && a:line[l:i] == ' ' + let l:i = l:i + 1 + endwhile + while l:i < l:length + if a:line[l:i] == "-" && l:force_pattern == 0 + let l:i = l:i + 1 + " Ignore long name option like --help. + if l:i < l:length && a:line[l:i] == '-' + while l:i < l:length && a:line[l:i] != ' ' + let l:i = l:i + 1 + endwhile + else + while l:i < l:length && a:line[l:i] != ' ' + let l:c = a:line[l:i] + let l:option = l:option . l:c + let l:i = l:i + 1 + endwhile + if l:c ==# 'e' + let l:force_pattern = 1 + endif + endif + else + let l:pattern = '' + " allow pattern includes blanks. + while l:i < l:length + if a:line[l:i] == "'" + let l:pattern = l:pattern . g:Gtags_Single_Quote_Char + elseif a:line[l:i] == '"' + let l:pattern = l:pattern . g:Gtags_Double_Quote_Char + else + let l:pattern = l:pattern . a:line[l:i] + endif + let l:i = l:i + 1 + endwhile + if a:target == 'pattern' + return l:pattern + endif + endif + " Skip blanks. + while l:i < l:length && a:line[l:i] == ' ' + let l:i = l:i + 1 + endwhile + endwhile + if a:target == 'option' + return l:option + endif + return '' +endfunction + +" +" Trim options to avoid errors. +" +function! s:TrimOption(option) + let l:option = '' + let l:length = strlen(a:option) + let l:i = 0 + + while l:i < l:length + let l:c = a:option[l:i] + if l:c !~# '[cenpquv]' + let l:option = l:option . l:c + endif + let l:i = l:i + 1 + endwhile + return l:option +endfunction + +" +" Execute global and load the result into quickfix window. +" +function! s:ExecLoad(option, long_option, pattern, flags) + " Execute global(1) command and write the result to a temporary file. + let l:isfile = 0 + let l:option = '' + let l:result = '' + + if a:option =~# 'f' + let l:isfile = 1 + if filereadable(a:pattern) == 0 + call s:Error('File ' . a:pattern . ' not found.') + return + endif + endif + if a:long_option != '' + let l:option = a:long_option . ' ' + endif + let l:option = l:option . '--result=' . g:Gtags_Result . ' -q' + let l:option = l:option . s:TrimOption(a:option) + if l:isfile == 1 + let l:cmd = s:global_command . ' ' . l:option . ' ' . g:Gtags_Shell_Quote_Char . a:pattern . g:Gtags_Shell_Quote_Char + else + let l:cmd = s:global_command . ' ' . l:option . 'e ' . g:Gtags_Shell_Quote_Char . a:pattern . g:Gtags_Shell_Quote_Char + endif + + let l:result = system(l:cmd) + if v:shell_error != 0 + if v:shell_error != 0 + if v:shell_error == 2 + call s:Error('invalid arguments. please use the latest GLOBAL.') + elseif v:shell_error == 3 + call s:Error('GTAGS not found.') + else + call s:Error('global command failed. command line: ' . l:cmd) + endif + endif + return + endif + if l:result == '' + if l:option =~# 'f' + call s:Error('Tag not found in ' . a:pattern . '.') + elseif l:option =~# 'P' + call s:Error('Path which matches to ' . a:pattern . ' not found.') + elseif l:option =~# 'g' + call s:Error('Line which matches to ' . a:pattern . ' not found.') + else + call s:Error('Tag which matches to ' . g:Gtags_Shell_Quote_Char . a:pattern . g:Gtags_Shell_Quote_Char . ' not found.') + endif + return + endif + + " Open the quickfix window + if g:Gtags_OpenQuickfixWindow == 1 + let l:open = 1 + if g:Gtags_Close_When_Single == 1 + let l:open = 0 + let l:idx = stridx(l:result, "\n") + if l:idx > 0 && stridx(l:result, "\n", l:idx + 1) > 0 + let l:open = 1 + endif + endif + if l:open == 0 + cclose + elseif g:Gtags_VerticalWindow == 1 + topleft vertical copen + else + botright copen + endif + endif + " Parse the output of 'global -x or -t' and show in the quickfix window. + let l:efm_org = &efm + let &efm = g:Gtags_Efm + if a:flags =~# 'a' + cadde l:result " append mode + elseif g:Gtags_No_Auto_Jump == 1 + cgete l:result " does not jump + else + cexpr! l:result " jump + endif + let &efm = l:efm_org +endfunction + +" +" RunGlobal() +" +function! s:RunGlobal(line, flags) + let l:pattern = s:Extract(a:line, 'pattern') + + if l:pattern == '%' + let l:pattern = expand('%') + elseif l:pattern == '#' + let l:pattern = expand('#') + endif + let l:option = s:Extract(a:line, 'option') + " If no pattern supplied then get it from user. + if l:pattern == '' + let s:option = l:option + if l:option =~# 'f' + let l:line = input("Gtags for file: ", expand('%'), 'file') + else + let l:line = input("Gtags for pattern: ", expand(''), 'custom,GtagsCandidateCore') + endif + let l:pattern = s:Extract(l:line, 'pattern') + if l:pattern == '' + call s:Error('Pattern not specified.') + return + endif + endif + call s:ExecLoad(l:option, '', l:pattern, a:flags) +endfunction + +" +" Execute RunGlobal() depending on the current position. +" +function! s:GtagsCursor() + let l:pattern = expand("") + let l:option = "--from-here=\"" . line('.') . ":" . expand("%") . "\"" + call s:ExecLoad('', l:option, l:pattern, '') +endfunction + +" +" Show the current position on mozilla. +" (You need to execute htags(1) in your source directory.) +" +function! s:Gozilla() + let l:lineno = line('.') + let l:filename = expand("%") + let l:result = system('gozilla +' . l:lineno . ' ' . l:filename) +endfunction +" +" Auto update of tag files using incremental update facility. +" +function! s:GtagsAutoUpdate() + let l:result = system(s:global_command . " -u --single-update=\"" . expand("%") . "\"") +endfunction + +" +" Custom completion. +" +function! GtagsCandidate(lead, line, pos) + let s:option = s:Extract(a:line, 'option') + return GtagsCandidateCore(a:lead, a:line, a:pos) +endfunction + +function! GtagsCandidateCore(lead, line, pos) + if s:option ==# 'g' + return '' + elseif s:option ==# 'f' + if isdirectory(a:lead) + if a:lead =~ '/$' + let l:pattern = a:lead . '*' + else + let l:pattern = a:lead . '/*' + endif + else + let l:pattern = a:lead . '*' + endif + return glob(l:pattern) + else + return system(s:global_command . ' ' . '-c' . s:option . ' ' . a:lead) + endif +endfunction + +" Define the set of Gtags commands +command! -nargs=* -complete=custom,GtagsCandidate Gtags call s:RunGlobal(, '') +command! -nargs=* -complete=custom,GtagsCandidate Gtagsa call s:RunGlobal(, 'a') +command! -nargs=0 GtagsCursor call s:GtagsCursor() +command! -nargs=0 Gozilla call s:Gozilla() +command! -nargs=0 GtagsUpdate call s:GtagsAutoUpdate() +if g:Gtags_Auto_Update == 1 + :autocmd! BufWritePost * call s:GtagsAutoUpdate() +endif +" Suggested map: +if g:Gtags_Auto_Map == 1 + :nmap :copen + :nmap :cclose + :nmap :Gtags + :nmap :Gtags -f % + :nmap :GtagsCursor + :nmap :Gozilla + :nmap :cn + :nmap :cp + :nmap :GtagsCursor +endif +let loaded_gtags = 1 -- 2.43.0