1 " LLVM coding guidelines conformance for VIM 2 " $Revision$ 3 " 4 " Maintainer: The LLVM Team, http://llvm.org 5 " WARNING: Read before you source in all these commands and macros! Some 6 " of them may change VIM behavior that you depend on. 7 " 8 " You can run VIM with these settings without changing your current setup with: 9 " $ vim -u /path/to/llvm/utils/vim/vimrc 10 11 " It's VIM, not VI 12 set nocompatible 13 14 " A tab produces a 2-space indentation 15 set softtabstop=2 16 set shiftwidth=2 17 set expandtab 18 19 " Highlight trailing whitespace and lines longer than 80 columns. 20 highlight LongLine ctermbg=DarkYellow guibg=DarkYellow 21 highlight WhitespaceEOL ctermbg=DarkYellow guibg=DarkYellow 22 if v:version >= 702 23 " Lines longer than 80 columns. 24 au BufWinEnter * let w:m0=matchadd('LongLine', '\%>80v.\+', -1) 25 26 " Whitespace at the end of a line. This little dance suppresses 27 " whitespace that has just been typed. 28 au BufWinEnter * let w:m1=matchadd('WhitespaceEOL', '\s\+$', -1) 29 au InsertEnter * call matchdelete(w:m1) 30 au InsertEnter * let w:m2=matchadd('WhitespaceEOL', '\s\+\%#\@<!$', -1) 31 au InsertLeave * call matchdelete(w:m2) 32 au InsertLeave * let w:m1=matchadd('WhitespaceEOL', '\s\+$', -1) 33 else 34 au BufRead,BufNewFile * syntax match LongLine /\%>80v.\+/ 35 au InsertEnter * syntax match WhitespaceEOL /\s\+\%#\@<!$/ 36 au InsertLeave * syntax match WhitespaceEOL /\s\+$/ 37 endif 38 39 " Enable filetype detection 40 filetype on 41 42 " Optional 43 " C/C++ programming helpers 44 augroup csrc 45 au! 46 autocmd FileType * set nocindent smartindent 47 autocmd FileType c,cpp set cindent 48 augroup END 49 " Set a few indentation parameters. See the VIM help for cinoptions-values for 50 " details. These aren't absolute rules; they're just an approximation of 51 " common style in LLVM source. 52 set cinoptions=:0,g0,(0,Ws,l1 53 " Add and delete spaces in increments of `shiftwidth' for tabs 54 set smarttab 55 56 " Highlight syntax in programming languages 57 syntax on 58 59 " LLVM Makefiles can have names such as Makefile.rules or TEST.nightly.Makefile, 60 " so it's important to categorize them as such. 61 augroup filetype 62 au! BufRead,BufNewFile *Makefile* set filetype=make 63 augroup END 64 65 " In Makefiles, don't expand tabs to spaces, since we need the actual tabs 66 autocmd FileType make set noexpandtab 67 68 " Useful macros for cleaning up code to conform to LLVM coding guidelines 69 70 " Delete trailing whitespace and tabs at the end of each line 71 command! DeleteTrailingWs :%s/\s\+$// 72 73 " Convert all tab characters to two spaces 74 command! Untab :%s/\t/ /g 75 76 " Enable syntax highlighting for LLVM files. To use, copy 77 " utils/vim/llvm.vim to ~/.vim/syntax . 78 augroup filetype 79 au! BufRead,BufNewFile *.ll set filetype=llvm 80 augroup END 81 82 " Enable syntax highlighting for tablegen files. To use, copy 83 " utils/vim/tablegen.vim to ~/.vim/syntax . 84 augroup filetype 85 au! BufRead,BufNewFile *.td set filetype=tablegen 86 augroup END 87 88 " Enable syntax highlighting for reStructuredText files. To use, copy 89 " rest.vim (http://www.vim.org/scripts/script.php?script_id=973) 90 " to ~/.vim/syntax . 91 augroup filetype 92 au! BufRead,BufNewFile *.rst set filetype=rest 93 augroup END 94 95 " Additional vim features to optionally uncomment. 96 "set showcmd 97 "set showmatch 98 "set showmode 99 "set incsearch 100 "set ruler 101 102 " Clang code-completion support. This is somewhat experimental! 103 104 " A path to a clang executable. 105 let g:clang_path = "clang++" 106 107 " A list of options to add to the clang commandline, for example to add 108 " include paths, predefined macros, and language options. 109 let g:clang_opts = [ 110 \ "-x","c++", 111 \ "-D__STDC_LIMIT_MACROS=1","-D__STDC_CONSTANT_MACROS=1", 112 \ "-Iinclude" ] 113 114 function! ClangComplete(findstart, base) 115 if a:findstart == 1 116 " In findstart mode, look for the beginning of the current identifier. 117 let l:line = getline('.') 118 let l:start = col('.') - 1 119 while l:start > 0 && l:line[l:start - 1] =~ '\i' 120 let l:start -= 1 121 endwhile 122 return l:start 123 endif 124 125 " Get the current line and column numbers. 126 let l:l = line('.') 127 let l:c = col('.') 128 129 " Build a clang commandline to do code completion on stdin. 130 let l:the_command = shellescape(g:clang_path) . 131 \ " -cc1 -code-completion-at=-:" . l:l . ":" . l:c 132 for l:opt in g:clang_opts 133 let l:the_command .= " " . shellescape(l:opt) 134 endfor 135 136 " Copy the contents of the current buffer into a string for stdin. 137 " TODO: The extra space at the end is for working around clang's 138 " apparent inability to do code completion at the very end of the 139 " input. 140 " TODO: Is it better to feed clang the entire file instead of truncating 141 " it at the current line? 142 let l:process_input = join(getline(1, l:l), "\n") . " " 143 144 " Run it! 145 let l:input_lines = split(system(l:the_command, l:process_input), "\n") 146 147 " Parse the output. 148 for l:input_line in l:input_lines 149 " Vim's substring operator is annoyingly inconsistent with python's. 150 if l:input_line[:11] == 'COMPLETION: ' 151 let l:value = l:input_line[12:] 152 153 " Chop off anything after " : ", if present, and move it to the menu. 154 let l:menu = "" 155 let l:spacecolonspace = stridx(l:value, " : ") 156 if l:spacecolonspace != -1 157 let l:menu = l:value[l:spacecolonspace+3:] 158 let l:value = l:value[:l:spacecolonspace-1] 159 endif 160 161 " Chop off " (Hidden)", if present, and move it to the menu. 162 let l:hidden = stridx(l:value, " (Hidden)") 163 if l:hidden != -1 164 let l:menu .= " (Hidden)" 165 let l:value = l:value[:l:hidden-1] 166 endif 167 168 " Handle "Pattern". TODO: Make clang less weird. 169 if l:value == "Pattern" 170 let l:value = l:menu 171 let l:pound = stridx(l:value, "#") 172 " Truncate the at the first [#, <#, or {#. 173 if l:pound != -1 174 let l:value = l:value[:l:pound-2] 175 endif 176 endif 177 178 " Filter out results which don't match the base string. 179 if a:base != "" 180 if l:value[:strlen(a:base)-1] != a:base 181 continue 182 end 183 endif 184 185 " TODO: Don't dump the raw input into info, though it's nice for now. 186 " TODO: The kind string? 187 let l:item = { 188 \ "word": l:value, 189 \ "menu": l:menu, 190 \ "info": l:input_line, 191 \ "dup": 1 } 192 193 " Report a result. 194 if complete_add(l:item) == 0 195 return [] 196 endif 197 if complete_check() 198 return [] 199 endif 200 201 elseif l:input_line[:9] == "OVERLOAD: " 202 " An overload candidate. Use a crazy hack to get vim to 203 " display the results. TODO: Make this better. 204 let l:value = l:input_line[10:] 205 let l:item = { 206 \ "word": " ", 207 \ "menu": l:value, 208 \ "info": l:input_line, 209 \ "dup": 1} 210 211 " Report a result. 212 if complete_add(l:item) == 0 213 return [] 214 endif 215 if complete_check() 216 return [] 217 endif 218 219 endif 220 endfor 221 222 223 return [] 224 endfunction ClangComplete 225 226 " This to enables the somewhat-experimental clang-based 227 " autocompletion support. 228 set omnifunc=ClangComplete 229