" Copyright (c) 2004 " Michael Sharpe " " We grant permission to use, copy modify, distribute, and sell this " software for any purpose without fee, provided that the above copyright " notice and this text are not removed. We make no guarantee about the " suitability of this software for any purpose and we are not liable " for any damages resulting from its use. Further, we are under no " obligation to maintain or extend this software. It is provided on an " "as is" basis without any expressed or implied warranty. " TODO + allow for saving of the quick-fix window...by default it is " nonmodifiable " + when the quick fix window is modified it needs to be saved a reloaded " to have any effect. if exists("loaded_qf") finish endif let loaded_qf = 1 " Function : QF_addProgramAndFormat (PUBLIC) " Purpose : Alls for the registration of a grepprg which will be used with the " quick-fix buffer " Args : id -- unique id for lookup " program -- program to run (will be a &grepprg program) " format -- quick-fix format for the program (can be empty) " Returns : nothing " Author : Michael Sharpe function! QF_addProgramAndFormat(id, program, format) let varName = "g:QFProgram_".a:id if (!exists(varName)) let g:QFProgram_{a:id} = a:program let g:QFFormat_{a:id} = a:format " add the corresponding QF command to save some typing exe 'command -nargs=* -bang QF'.a:id.' call QF_doExecute("'.a:id.'", "", "")' endif endfunction " Register some default programs. These seem to work well on linux (redhat9) " should include the -f/--file option if (!exists("g:QF_IDUtilsDB")) let g:QF_IDUtilsDB = "" endif call QF_addProgramAndFormat('lid', 'lid '. g:QF_IDUtilsDB .' -R grep "$*"', "") call QF_addProgramAndFormat('grep', 'grep -n $*', "") call QF_addProgramAndFormat('rgrep', 'grep -n -r $* /dev/null', "") call QF_addProgramAndFormat('locate', 'locate $*', '%f') call QF_addProgramAndFormat('find', 'find $* -print', '%f') call QF_addProgramAndFormat('global', 'global -x "$*"','%\\D%#%\\s%l%\\s%f%\\s%m') call QF_addProgramAndFormat('globalr', 'global -rx "$*"', '%\\D%#%\\s%l%\\s%f%\\s%m') call QF_addProgramAndFormat('lglobal', 'global -lx "$*"', '%\\D%#%\\s%l%\\s%f%\\s%m') call QF_addProgramAndFormat('lglobalr', 'global -lrx "$*"', '%\\D%#%\\s%l%\\s%f%\\s%m') call QF_addProgramAndFormat('findn', 'find -name $* -print', '%f') call QF_addProgramAndFormat('glimpse', 'glimpse -nyH . $*', '%f: %l: %m') " should include the -d/--database option if (!exists("g:QF_SlocateDB")) let g:QF_SlocateDB = "" endif call QF_addProgramAndFormat('slocate', 'slocate ' . g:QF_SlocateDB .' $*', '%f') call QF_addProgramAndFormat('findgrep', 'find . \| grep $*', "%f") " Some special case helpers which can be useful call QF_addProgramAndFormat('raw', '$*', '') call QF_addProgramAndFormat('load', 'cat $*', '%f|%l|%m,%f||%m,%f') " Function : QF_execProgram (PUBLIC) " Purpose : Executes a specified program via using vim's builtin grep command " in conjuction with the quick-fix functionality " Args : program -- program to execute (via &grepprg) " format -- format for the quick-fix window " args -- args for the program (args to :grep command) " addFlag -- if non-empty results are add to existing quick-fix list " Returns : Nothing " Author : Michael Sharpe function! QF_execProgram(program, format, args, addFlag) " save the old grepprg and grepformat so that they can be restored later let old_grepprg=&grepprg let old_grepformat=&grepformat " install the specified grepprg let &grepprg=a:program " and install the format if one was specified (TODO should support appending) if (a:format != "") let &grepformat=a:format endif " Run vim's builtin grep command which will invoke the grepprg if (a:addFlag != "") exec "grepadd ".a:args else exec "grep ".a:args endif " Open the quick-fix window (TODO should be configurable via global?) exec "cwin" " Restore the old settings let &grepprg=old_grepprg let &grepformat=old_grepformat endfunction " Function : QF_doExecute (PUBLIC) " Purpose : Looks up a registered program and executes it via vim's builtin " grep command " Args : id -- id of the program " args -- arguments for the program " addFlag -- if non-empty result are added to existing quickfix list " Returns : Nothing " Author : Michael Sharpe function! QF_doExecute(id, args, addFlag) let varName = "g:QFProgram_".a:id " if the command identified by id exists, execute it if (exists(varName)) call QF_execProgram(g:QFProgram_{a:id}, g:QFFormat_{a:id}, a:args, a:addFlag) endif endfunction " Function : QF_lookupAndRunProgram (PUBLIC) " Purpose : Looks up a registered program and executes it, as above, and using " above actually. This is simply a wrapper for QF_doExecute() " Args : allArgs -- argument of the form " " for use with " QF_doExecute() " Returns : Nothing " Author : Michael Sharpe function! QF_lookupAndRunProgram(allArgs, addFlag) " find the first space let pos = stridx(a:allArgs, ' ') if (pos) " first field is the id of the command let id = strpart(a:allArgs, 0, pos) " rest of the string is the arguments for the corresponding program let args = strpart(a:allArgs, pos) call QF_doExecute(id, args, a:addFlag) endif endfunction " In all cases below, the ! (i.e. will append new results to existing " quick-fix window. " Allows any registered quick-fix command to be executed " QF <-- finds the program corresponding to "id" in the " table and executes it with the specified arguments "args" " e.g. :QF grep foobar *.cpp <-- will grep all cpp files for foobar command -nargs=* -bang QF call QF_lookupAndRunProgram("", "") " Allows the entry of a raw command, useful in some cases, and for testing command -nargs=+ -bang QFE call QF_execProgram(, "") " Allows the entry of a raw command command -nargs=* -bang QFR call QF_doExecute('raw', "", "") " The following commands are short cuts for the QF command (very short short " cuts....in that they really do not save too much typing :) They are all " commented out because the commands are automagically added above now. " E.g. :QFlid static <-- will find all lines with the word "static" using GNU " id-utils "command -nargs=* -bang QFlid call QF_doExecute('lid', "", "") " E.g. :QFglobal '^[sg]et' <-- will find all defintions of functions starting " with set or get. "command -nargs=* -bang QFglobal call QF_doExecute('global', "", "") " E.g. :QFglobal '^[sg]et' <-- will find all references to functions starting " with set or get. "command -nargs=* -bang QFglobalr call QF_doExecute('globalr', "", "") " E.g. :QFglobal '^[sg]et' <-- will find all defintions of functions starting " with set or get under the current directory "command -nargs=* -bang QFlglobal call QF_doExecute('lglobal', "", "") " E.g. :QFglobal '^[sg]et' <-- will find all references to functions starting " with set or get under the current directory "command -nargs=* -bang QFlglobalr call QF_doExecute('lglobalr', "", "") " E.g. :QFgrep static *.cpp <-- will find all lines matching "static" in the " .cpp files of the current directory "command -nargs=* -bang QFgrep call QF_doExecute('grep', "", "") " E.g. :QFrgrep static src <-- will recursively grep the src directory for all " files containing static "command -nargs=* -bang QFrgrep call QF_doExecute('rgrep',"", "") " E.g. :QFlocate pattern <-- will locate all files matching pattern via the " slocate functionality available on linux and elsewhere "command -nargs=* -bang QFlocate call QF_doExecute('locate', "", "") " E.g. QFfind . -name '*.cpp' <-- will find all cpp files under the current " directory "command -nargs=* -bang QFfind call QF_doExecute('find', "", "") " Allows a saved Quick-fix window which was previously saved to be restored " E.g. :QFload /tmp/foo <-- will load contents of /tmp/foo into quick-fix " buffer assuming /tmp/foo contains the contents of a previously save quick-fix " buffer "command -nargs=* -bang -complete=file QFload call QF_doExecute('loadfile', "", "")