[llvm-commits] [llvm] r112204 - /llvm/trunk/utils/vim/vimrc
    Jim Grosbach 
    grosbach at apple.com
       
    Thu Aug 26 11:46:43 PDT 2010
    
    
  
Oh my....
<rubs hands together....>
On Aug 26, 2010, at 11:12 AM, Dan Gohman wrote:
> Author: djg
> Date: Thu Aug 26 13:12:22 2010
> New Revision: 112204
> 
> URL: http://llvm.org/viewvc/llvm-project?rev=112204&view=rev
> Log:
> Experimental clang-based code-completion support for vim. This currently
> depends on some clang patches which are not yet upstream.
> 
> Modified:
>    llvm/trunk/utils/vim/vimrc
> 
> Modified: llvm/trunk/utils/vim/vimrc
> URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/vim/vimrc?rev=112204&r1=112203&r2=112204&view=diff
> ==============================================================================
> --- llvm/trunk/utils/vim/vimrc (original)
> +++ llvm/trunk/utils/vim/vimrc Thu Aug 26 13:12:22 2010
> @@ -91,3 +91,127 @@
> "set showmode
> "set incsearch
> "set ruler
> +
> +" Clang code-completion support. This is highly experimental!
> +
> +" TODO: code-completing on
> +"          cast_cast<
> +" turns up some peculiarities -- "asm("? 
> +
> +" A path to the a executable.
> +let g:clang_path = "Release/bin/clang++"
> +
> +" A list of options to add to the clang commandline, for example to add
> +" include paths, predefined macros, and language options.
> +let g:clang_opts = [
> +  \ "-x","c++",
> +  \ "-D__STDC_LIMIT_MACROS=1","-D__STDC_CONSTANT_MACROS=1",
> +  \ "-Iinclude" ]
> +
> +function! ClangComplete(findstart, base)
> +   if a:findstart == 1
> +      " In findstart mode, look for the beginning of the current identifier.
> +      let l:line = getline('.')
> +      let l:start = col('.') - 1
> +      while l:start > 0 && l:line[l:start - 1] =~ '\i'
> +         let l:start -= 1
> +      endwhile
> +      return l:start
> +   endif
> +
> +   " Get the current line and column numbers.
> +   let l:l = line('.')
> +   let l:c = col('.')
> +
> +   " Build a clang commandline to do code completion on stdin.
> +   let l:the_command = shellescape(g:clang_path) .
> +                     \ " -cc1 -code-completion-at=-:" . l:l . ":" . l:c
> +   for l:opt in g:clang_opts
> +      let l:the_command .= " " . shellescape(l:opt)
> +   endfor
> +
> +   " Copy the contents of the current buffer into a string for stdin.
> +   " TODO: The extra space at the end is for working around clang's
> +   " apparent inability to do code completion at the very end of the
> +   " input.
> +   " TODO: Is it better to feed clang the entire file instead of truncating
> +   " it at the current line?
> +   let l:process_input = join(getline(1, l:l), "\n") . " "
> +
> +   " Run it!
> +   let l:input_lines = split(system(l:the_command, l:process_input), "\n")
> +
> +   " Parse the output.
> +   for l:input_line in l:input_lines
> +      " Vim's substring operator is annoyingly inconsistent with python's.
> +      if l:input_line[:11] == 'COMPLETION: '
> +         let l:value = l:input_line[12:]
> +
> +        " Chop off anything after " : ", if present, and move it to the menu.
> +        let l:menu = ""
> +        let l:spacecolonspace = stridx(l:value, " : ")
> +        if l:spacecolonspace != -1
> +           let l:menu = l:value[l:spacecolonspace+3:]
> +           let l:value = l:value[:l:spacecolonspace-1]
> +        endif
> +
> +        " Handle Pattern. TODO: Make clang less weird.
> +        if l:value == "Pattern"
> +           let l:value = l:menu
> +           let l:pound = stridx(l:value, "#")
> +           " Truncate the at the first [#, <#, or {#.
> +           if l:pound != -1
> +              let l:value = l:value[:l:pound-2]
> +           endif
> +        endif
> +
> +         " Filter out results which don't match the base string.
> +         if a:base != ""
> +            if l:value[:strlen(a:base)-1] != a:base
> +               continue
> +            end
> +         endif
> +
> +        " TODO: Don't dump the raw input into info, though it's nice for now.
> +        " TODO: The kind string?
> +        let l:item = {
> +          \ "word": l:value,
> +          \ "menu": l:menu,
> +          \ "info": l:input_line,
> +          \ "dup": 1 }
> +
> +        " Report a result.
> +        if complete_add(l:item) == 0
> +           return []
> +        endif
> +        if complete_check()
> +           return []
> +        endif
> +
> +      elseif l:input_line[:9] == "OVERLOAD: "
> +         " An overload candidate. Use a crazy hack to get vim to
> +         " display the results. TODO: Make this better.
> +         let l:value = l:input_line[10:]
> +         let l:item = {
> +           \ "word": " ",
> +           \ "menu": l:value,
> +           \ "info": l:input_line,
> +           \ "dup": 1}
> +
> +        " Report a result.
> +        if complete_add(l:item) == 0
> +           return []
> +        endif
> +        if complete_check()
> +           return []
> +        endif
> +
> +      endif
> +   endfor
> +
> +
> +   return []
> +endfunction ClangComplete
> +
> +" Uncomment this to enable the highly-broken autocompletion support.
> +"set omnifunc=ClangComplete
> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at cs.uiuc.edu
> http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits
    
    
More information about the llvm-commits
mailing list