tomkersten-vixploder 0.1.1 → 0.1.2

Sign up to get free protection for your applications and to get access to all the features.
Files changed (106) hide show
  1. data/History.txt +4 -0
  2. data/Manifest.txt +105 -0
  3. data/PostInstall.txt +21 -0
  4. data/README.rdoc +131 -0
  5. data/Rakefile +21 -0
  6. data/bin/256colors2.pl +63 -0
  7. data/bin/colortest +365 -0
  8. data/bin/vixplode +10 -0
  9. data/lib/dotfiles/aliases +30 -0
  10. data/lib/dotfiles/gvimrc +20 -0
  11. data/lib/dotfiles/vim/.VimballRecord +2 -0
  12. data/lib/dotfiles/vim/after/ftplugin/actionscript_snippets.vim +9 -0
  13. data/lib/dotfiles/vim/after/ftplugin/aspvbs_snippets.vim +17 -0
  14. data/lib/dotfiles/vim/after/ftplugin/c_snippets.vim +58 -0
  15. data/lib/dotfiles/vim/after/ftplugin/css_snippets.vim +30 -0
  16. data/lib/dotfiles/vim/after/ftplugin/django_model_snippets.vim +61 -0
  17. data/lib/dotfiles/vim/after/ftplugin/django_template_snippets.vim +32 -0
  18. data/lib/dotfiles/vim/after/ftplugin/f-script_snippets.vim +14 -0
  19. data/lib/dotfiles/vim/after/ftplugin/haskell_snippets.vim +9 -0
  20. data/lib/dotfiles/vim/after/ftplugin/html_snippets.vim +57 -0
  21. data/lib/dotfiles/vim/after/ftplugin/java_snippets.vim +52 -0
  22. data/lib/dotfiles/vim/after/ftplugin/javascript_snippets.vim +10 -0
  23. data/lib/dotfiles/vim/after/ftplugin/latex_snippets.vim +13 -0
  24. data/lib/dotfiles/vim/after/ftplugin/logo_snippets.vim +9 -0
  25. data/lib/dotfiles/vim/after/ftplugin/markdown_snippets.vim +10 -0
  26. data/lib/dotfiles/vim/after/ftplugin/movable_type_snippets.vim +14 -0
  27. data/lib/dotfiles/vim/after/ftplugin/objc_snippets.vim +53 -0
  28. data/lib/dotfiles/vim/after/ftplugin/ocaml_snippets.vim +26 -0
  29. data/lib/dotfiles/vim/after/ftplugin/perl_snippets.vim +23 -0
  30. data/lib/dotfiles/vim/after/ftplugin/php_snippets.vim +30 -0
  31. data/lib/dotfiles/vim/after/ftplugin/phpdoc_snippets.vim +19 -0
  32. data/lib/dotfiles/vim/after/ftplugin/propel_snippets.vim +14 -0
  33. data/lib/dotfiles/vim/after/ftplugin/python_snippets.vim +202 -0
  34. data/lib/dotfiles/vim/after/ftplugin/rails_snippets.vim +54 -0
  35. data/lib/dotfiles/vim/after/ftplugin/ruby_snippets.vim +32 -0
  36. data/lib/dotfiles/vim/after/ftplugin/sh_snippets.vim +12 -0
  37. data/lib/dotfiles/vim/after/ftplugin/slate_snippets.vim +19 -0
  38. data/lib/dotfiles/vim/after/ftplugin/smarty_snippets.vim +35 -0
  39. data/lib/dotfiles/vim/after/ftplugin/symfony_snippets.vim +21 -0
  40. data/lib/dotfiles/vim/after/ftplugin/tcl_snippets.vim +14 -0
  41. data/lib/dotfiles/vim/after/ftplugin/template_toolkit_snippets.vim +13 -0
  42. data/lib/dotfiles/vim/after/ftplugin/tex_snippets.vim +13 -0
  43. data/lib/dotfiles/vim/after/ftplugin/xhtml_snippets.vim +48 -0
  44. data/lib/dotfiles/vim/autoload/fakeclip.vim +253 -0
  45. data/lib/dotfiles/vim/autoload/rails.vim +4377 -0
  46. data/lib/dotfiles/vim/autoload/rubycomplete.vim +802 -0
  47. data/lib/dotfiles/vim/colors/inkpot.vim +212 -0
  48. data/lib/dotfiles/vim/colors/ir_black.vim +212 -0
  49. data/lib/dotfiles/vim/colors/ir_black_mod.vim +213 -0
  50. data/lib/dotfiles/vim/colors/railscasts.vim +100 -0
  51. data/lib/dotfiles/vim/colors/rubyblue.vim +74 -0
  52. data/lib/dotfiles/vim/colors/twilight.vim +75 -0
  53. data/lib/dotfiles/vim/colors/twilight2.vim +74 -0
  54. data/lib/dotfiles/vim/colors/wombat256.vim +302 -0
  55. data/lib/dotfiles/vim/compiler/eruby.vim +41 -0
  56. data/lib/dotfiles/vim/compiler/ruby.vim +68 -0
  57. data/lib/dotfiles/vim/compiler/rubyunit.vim +35 -0
  58. data/lib/dotfiles/vim/doc/NERD_tree.txt +1235 -0
  59. data/lib/dotfiles/vim/doc/fakeclip.txt +190 -0
  60. data/lib/dotfiles/vim/doc/matchit.txt +406 -0
  61. data/lib/dotfiles/vim/doc/project.txt +710 -0
  62. data/lib/dotfiles/vim/doc/rails.txt +1123 -0
  63. data/lib/dotfiles/vim/doc/snippets_emu.txt +354 -0
  64. data/lib/dotfiles/vim/doc/surround.txt +218 -0
  65. data/lib/dotfiles/vim/doc/tags +433 -0
  66. data/lib/dotfiles/vim/filetype.vim +13 -0
  67. data/lib/dotfiles/vim/ftdetect/gist.vim +3 -0
  68. data/lib/dotfiles/vim/ftdetect/ruby.vim +14 -0
  69. data/lib/dotfiles/vim/ftplugin/eruby.vim +101 -0
  70. data/lib/dotfiles/vim/ftplugin/ruby.vim +230 -0
  71. data/lib/dotfiles/vim/indent/eruby.vim +73 -0
  72. data/lib/dotfiles/vim/indent/ruby.vim +373 -0
  73. data/lib/dotfiles/vim/plugin/NERD_tree.vim +3536 -0
  74. data/lib/dotfiles/vim/plugin/comments.vim +321 -0
  75. data/lib/dotfiles/vim/plugin/fakeclip.vim +174 -0
  76. data/lib/dotfiles/vim/plugin/fuzzyfinder.vim +1676 -0
  77. data/lib/dotfiles/vim/plugin/fuzzyfinder_textmate.vim +150 -0
  78. data/lib/dotfiles/vim/plugin/gist.vim +241 -0
  79. data/lib/dotfiles/vim/plugin/gitdiff.vim +141 -0
  80. data/lib/dotfiles/vim/plugin/matchit.vim +812 -0
  81. data/lib/dotfiles/vim/plugin/mru.vim +787 -0
  82. data/lib/dotfiles/vim/plugin/rails.vim +310 -0
  83. data/lib/dotfiles/vim/plugin/rspec.vim +12 -0
  84. data/lib/dotfiles/vim/plugin/snippets.vim +17 -0
  85. data/lib/dotfiles/vim/plugin/snippetsEmu.vim +973 -0
  86. data/lib/dotfiles/vim/plugin/supertab.vim +531 -0
  87. data/lib/dotfiles/vim/plugin/surround.vim +632 -0
  88. data/lib/dotfiles/vim/ref_vimrc +80 -0
  89. data/lib/dotfiles/vim/ruby/fuzzy_file_finder.rb +353 -0
  90. data/lib/dotfiles/vim/syntax/eruby.vim +85 -0
  91. data/lib/dotfiles/vim/syntax/haml.vim +113 -0
  92. data/lib/dotfiles/vim/syntax/mkd.vim +86 -0
  93. data/lib/dotfiles/vim/syntax/ruby.vim +324 -0
  94. data/lib/dotfiles/vim/syntax/sass.vim +93 -0
  95. data/lib/dotfiles/vimrc +269 -0
  96. data/lib/vixplode/cli.rb +73 -0
  97. data/lib/vixploder.rb +6 -0
  98. data/script/console +10 -0
  99. data/script/destroy +14 -0
  100. data/script/generate +14 -0
  101. data/spec/spec.opts +1 -0
  102. data/spec/spec_helper.rb +10 -0
  103. data/spec/vixplode_cli_spec.rb +15 -0
  104. data/spec/vixploder_spec.rb +7 -0
  105. data/tasks/rspec.rake +21 -0
  106. metadata +202 -8
@@ -0,0 +1,531 @@
1
+ " Author:
2
+ " Original: Gergely Kontra <kgergely@mcl.hu>
3
+ " Current: Eric Van Dewoestine <ervandew@gmail.com> (as of version 0.4)
4
+ " Please direct all correspondence to Eric.
5
+ " Version: 0.46
6
+ "
7
+ " Description: {{{
8
+ " Use your tab key to do all your completion in insert mode!
9
+ " You can cycle forward and backward with the <Tab> and <S-Tab> keys
10
+ " Note: you must press <Tab> once to be able to cycle back
11
+ "
12
+ " http://www.vim.org/scripts/script.php?script_id=1643
13
+ " }}}
14
+ "
15
+ " License: {{{
16
+ " Software License Agreement (BSD License)
17
+ "
18
+ " Copyright (c) 2002 - 2007
19
+ " All rights reserved.
20
+ "
21
+ " Redistribution and use of this software in source and binary forms, with
22
+ " or without modification, are permitted provided that the following
23
+ " conditions are met:
24
+ "
25
+ " * Redistributions of source code must retain the above
26
+ " copyright notice, this list of conditions and the
27
+ " following disclaimer.
28
+ "
29
+ " * Redistributions in binary form must reproduce the above
30
+ " copyright notice, this list of conditions and the
31
+ " following disclaimer in the documentation and/or other
32
+ " materials provided with the distribution.
33
+ "
34
+ " * Neither the name of Gergely Kontra or Eric Van Dewoestine nor the names
35
+ " of its contributors may be used to endorse or promote products derived
36
+ " from this software without specific prior written permission of Gergely
37
+ " Kontra or Eric Van Dewoestine.
38
+ "
39
+ " THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
40
+ " IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
41
+ " THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
42
+ " PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
43
+ " CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
44
+ " EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
45
+ " PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
46
+ " PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
47
+ " LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
48
+ " NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
49
+ " SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
50
+ " }}}
51
+
52
+ if exists('complType') " Integration with other completion functions.
53
+ finish
54
+ endif
55
+
56
+ " Global Variables {{{
57
+
58
+ " Used to set the default completion type.
59
+ " There is no need to escape this value as that will be done for you when
60
+ " the type is set.
61
+ " Ex. let g:SuperTabDefaultCompletionType = "<c-x><c-u>"
62
+ "
63
+ " Note that a special value of 'context' is supported which will result in
64
+ " super tab attempting to use the text preceding the cursor to decide which
65
+ " type of completion to attempt. Currently super tab can recognize method
66
+ " calls or attribute references via '.', '::' or '->', and file path
67
+ " references containing '/'.
68
+ " Ex. let g:SuperTabDefaultCompletionType = 'context'
69
+ " /usr/l<tab> # will use filename completion
70
+ " myvar.t # will use user completion if completefunc set, or omni
71
+ " # completion if omnifunc set.
72
+ " myvar-> # same as above
73
+ "
74
+ " When using context completion, super tab will fall back to a secondary
75
+ " default completion type set by g:SuperTabContextDefaultCompletionType.
76
+ if !exists("g:SuperTabDefaultCompletionType")
77
+ let g:SuperTabDefaultCompletionType = "<c-p>"
78
+ endif
79
+
80
+ " Sets the default completion type used when g:SuperTabDefaultCompletionType
81
+ " is set to 'context' and the text preceding the cursor does not match any
82
+ " patterns mapped to other specific completion types.
83
+ if !exists("g:SuperTabContextDefaultCompletionType")
84
+ let g:SuperTabContextDefaultCompletionType = "<c-p>"
85
+ endif
86
+
87
+ " When 'context' completion is enabled, this setting can be used to fallback
88
+ " to g:SuperTabContextDefaultCompletionType as the default for files whose
89
+ " file type occurs in this configured list. This allows you to provide an
90
+ " exclusion for which 'context' completion is not activated.
91
+ if !exists("g:SuperTabContextFileTypeExclusions")
92
+ let g:SuperTabContextFileTypeExclusions = []
93
+ endif
94
+
95
+ " Used to set a list of variable, completion type pairs used to determine
96
+ " the default completion type to use for the current buffer. If the
97
+ " variable is non-zero and non-empty then the associated completion type
98
+ " will be used.
99
+ " Ex. To use omni or user completion when available, but fall back to the
100
+ " global default otherwise:
101
+ " let g:SuperTabDefaultCompletionTypeDiscovery = [
102
+ " \ "&completefunc:<c-x><c-u>",
103
+ " \ "&omnifunc:<c-x><c-o>",
104
+ " \ ]
105
+ if !exists("g:SuperTabDefaultCompletionTypeDiscovery")
106
+ let g:SuperTabDefaultCompletionTypeDiscovery = []
107
+ endif
108
+
109
+ " Determines if, and for how long, the current completion type is retained.
110
+ " The possible values include:
111
+ " 0 - The current completion type is only retained for the current completion.
112
+ " Once you have chosen a completion result or exited the completion
113
+ " mode, the default completion type is restored.
114
+ " 1 - The current completion type is saved for the duration of your vim
115
+ " session or until you enter a different completion mode.
116
+ " (SuperTab default).
117
+ " 2 - The current completion type is saved until you exit insert mode (via
118
+ " ESC). Once you exit insert mode the default completion type is
119
+ " restored.
120
+ if !exists("g:SuperTabRetainCompletionType")
121
+ let g:SuperTabRetainCompletionType = 1
122
+ endif
123
+
124
+ " Sets whether or not mid word completion is enabled.
125
+ " When enabled, <tab> will kick off completion when ever a word character is
126
+ " to the left of the cursor. When disabled, completion will only occur if
127
+ " the char to the left is a word char and the char to the right is not (you
128
+ " are at the end of the word).
129
+ if !exists("g:SuperTabMidWordCompletion")
130
+ let g:SuperTabMidWordCompletion = 1
131
+ endif
132
+
133
+ " The following two variables allow you to set the key mapping used to kick
134
+ " off the current completion. By default this is <tab> and <s-tab>. To
135
+ " change to something like <c-space> and <s-c-space>, you can add the
136
+ " following to your vimrc.
137
+ "
138
+ " let g:SuperTabMappingForward = '<c-space>'
139
+ " let g:SuperTabMappingBackward = '<s-c-space>'
140
+ "
141
+ " Note: if the above does not have the desired effect (which may happen in
142
+ " console version of vim), you can try the following mappings. Although the
143
+ " backwards mapping still doesn't seem to work in the console for me, your
144
+ " milage may vary.
145
+ "
146
+ " let g:SuperTabMappingForward = '<nul>'
147
+ " let g:SuperTabMappingBackward = '<s-nul>'
148
+ "
149
+ if !exists("g:SuperTabMappingForward")
150
+ let g:SuperTabMappingForward = '<tab>'
151
+ endif
152
+ if !exists("g:SuperTabMappingBackward")
153
+ let g:SuperTabMappingBackward = '<s-tab>'
154
+ endif
155
+
156
+ " Sets the key mapping used to insert a literal tab where supertab would
157
+ " otherwise attempt to kick off insert completion.
158
+ " The default is '<c-tab>' (ctrl-tab) which unfortunately might not work at
159
+ " the console. So if you are using a console vim and want this
160
+ " functionality, you'll have to change it to something that is supported.
161
+ if !exists("g:SuperTabMappingTabLiteral")
162
+ let g:SuperTabMappingTabLiteral = '<c-tab>'
163
+ endif
164
+
165
+ " Sets whether or not to pre-highlight first match when completeopt has
166
+ " the popup menu enabled and the 'longest' option as well.
167
+ " When enabled, <tab> will kick off completion and pre-select the first
168
+ " entry in the popup menu, allowing you to simply hit <enter> to use it.
169
+ if !exists("g:SuperTabLongestHighlight")
170
+ let g:SuperTabLongestHighlight = 0
171
+ endif
172
+
173
+ " }}}
174
+
175
+ " Script Variables {{{
176
+
177
+ " construct the help text.
178
+ let s:tabHelp =
179
+ \ "Hit <CR> or CTRL-] on the completion type you wish to switch to.\n" .
180
+ \ "Use :help ins-completion for more information.\n" .
181
+ \ "\n" .
182
+ \ "|<c-n>| - Keywords in 'complete' searching down.\n" .
183
+ \ "|<c-p>| - Keywords in 'complete' searching up (SuperTab default).\n" .
184
+ \ "|<c-x><c-l>| - Whole lines.\n" .
185
+ \ "|<c-x><c-n>| - Keywords in current file.\n" .
186
+ \ "|<c-x><c-k>| - Keywords in 'dictionary'.\n" .
187
+ \ "|<c-x><c-t>| - Keywords in 'thesaurus', thesaurus-style.\n" .
188
+ \ "|<c-x><c-i>| - Keywords in the current and included files.\n" .
189
+ \ "|<c-x><c-]>| - Tags.\n" .
190
+ \ "|<c-x><c-f>| - File names.\n" .
191
+ \ "|<c-x><c-d>| - Definitions or macros.\n" .
192
+ \ "|<c-x><c-v>| - Vim command-line."
193
+ if v:version >= 700
194
+ let s:tabHelp = s:tabHelp . "\n" .
195
+ \ "|<c-x><c-u>| - User defined completion.\n" .
196
+ \ "|<c-x><c-o>| - Omni completion.\n" .
197
+ \ "|<c-x>s| - Spelling suggestions."
198
+ endif
199
+
200
+ " set the available completion types and modes.
201
+ let s:types =
202
+ \ "\<C-E>\<C-Y>\<C-L>\<C-N>\<C-K>\<C-T>\<C-I>\<C-]>\<C-F>\<C-D>\<C-V>\<C-N>\<C-P>"
203
+ let s:modes = '/^E/^Y/^L/^N/^K/^T/^I/^]/^F/^D/^V/^P'
204
+ if v:version >= 700
205
+ let s:types = s:types . "\<C-U>\<C-O>\<C-N>\<C-P>s"
206
+ let s:modes = s:modes . '/^U/^O/s'
207
+ endif
208
+ let s:types = s:types . "np"
209
+ let s:modes = s:modes . '/n/p'
210
+
211
+ " }}}
212
+
213
+ " CtrlXPP() {{{
214
+ " Handles entrance into completion mode.
215
+ function! CtrlXPP ()
216
+ if &smd
217
+ echo '' | echo '-- ^X++ mode (' . s:modes . ')'
218
+ endif
219
+ let complType = nr2char(getchar())
220
+ if stridx(s:types, complType) != -1
221
+ if stridx("\<C-E>\<C-Y>", complType) != -1 " no memory, just scroll...
222
+ return "\<C-x>" . complType
223
+ elseif stridx('np', complType) != -1
224
+ let complType = nr2char(char2nr(complType) - 96) " char2nr('n')-char2nr("\<C-n")
225
+ else
226
+ let complType="\<C-x>" . complType
227
+ endif
228
+
229
+ if g:SuperTabRetainCompletionType
230
+ let b:complType = complType
231
+ endif
232
+
233
+ return complType
234
+ else
235
+ echohl "Unknown mode"
236
+ return complType
237
+ endif
238
+ endfunction " }}}
239
+
240
+ " SuperTabSetCompletionType(type) {{{
241
+ " Globally available function that user's can use to create mappings to
242
+ " quickly switch completion modes. Useful when a user wants to restore the
243
+ " default or switch to another mode without having to kick off a completion
244
+ " of that type or use SuperTabHelp.
245
+ " Example mapping to restore SuperTab default:
246
+ " nmap <F6> :call SetSuperTabCompletionType("<C-P>")<cr>
247
+ function! SuperTabSetCompletionType (type)
248
+ exec "let b:complType = \"" . escape(a:type, '<') . "\""
249
+ endfunction " }}}
250
+
251
+ " s:Init {{{
252
+ " Global initilization when supertab is loaded.
253
+ function! s:Init ()
254
+ augroup supertab_init
255
+ autocmd!
256
+ autocmd BufEnter * call <SID>InitBuffer()
257
+ augroup END
258
+ " ensure InitBuffer gets called for the first buffer.
259
+ call s:InitBuffer()
260
+
261
+ " Setup mechanism to restore orignial completion type upon leaving insert
262
+ " mode if g:SuperTabRetainCompletionType == 2
263
+ if g:SuperTabRetainCompletionType == 2
264
+ " pre vim 7, must map <esc>
265
+ if v:version < 700
266
+ im <silent> <ESC> <ESC>:call s:SetDefaultCompletionType()<cr>
267
+
268
+ " since vim 7, we can use InsertLeave autocmd.
269
+ else
270
+ augroup supertab_retain
271
+ autocmd!
272
+ autocmd InsertLeave * call s:SetDefaultCompletionType()
273
+ augroup END
274
+ endif
275
+ endif
276
+ endfunction " }}}
277
+
278
+ " s:InitBuffer {{{
279
+ " Per buffer initilization.
280
+ function! s:InitBuffer ()
281
+ if exists("b:complType")
282
+ return
283
+ endif
284
+
285
+ if !exists("b:SuperTabDefaultCompletionType")
286
+ " loop through discovery list to find the default
287
+ if !empty(g:SuperTabDefaultCompletionTypeDiscovery)
288
+ " backward compatiability with old string value.
289
+ if type(g:SuperTabDefaultCompletionTypeDiscovery) == 1
290
+ let dlist = split(g:SuperTabDefaultCompletionTypeDiscovery, ',')
291
+ else
292
+ let dlist = g:SuperTabDefaultCompletionTypeDiscovery
293
+ endif
294
+ for pair in dlist
295
+ let var = substitute(pair, '\(.*\):.*', '\1', '')
296
+ let type = substitute(pair, '.*:\(.*\)', '\1', '')
297
+ exec 'let value = ' . var
298
+ if value !~ '^\s*$' && value != '0'
299
+ let b:SuperTabDefaultCompletionType = type
300
+ break
301
+ endif
302
+ endfor
303
+ endif
304
+
305
+ " fallback to configured default.
306
+ if !exists("b:SuperTabDefaultCompletionType")
307
+ let b:SuperTabDefaultCompletionType = g:SuperTabDefaultCompletionType
308
+ endif
309
+ endif
310
+
311
+ " set the default completion type.
312
+ call SuperTabSetCompletionType(b:SuperTabDefaultCompletionType)
313
+ endfunction " }}}
314
+
315
+ " s:IsWordChar(char) {{{
316
+ " Determines if the supplied character is a word character or matches value
317
+ " defined by 'iskeyword'.
318
+ function! s:IsWordChar (char)
319
+ if a:char =~ '\w'
320
+ return 1
321
+ endif
322
+
323
+ " check against 'iskeyword'
324
+ let values = &iskeyword
325
+ let index = stridx(values, ',')
326
+ while index > 0 || values != ''
327
+ if index > 0
328
+ let value = strpart(values, 0, index)
329
+ let values = strpart(values, index + 1)
330
+ else
331
+ let value = values
332
+ let values = ''
333
+ endif
334
+
335
+ " exception case for '^,'
336
+ if value == '^'
337
+ let value = '^,'
338
+
339
+ " execption case for ','
340
+ elseif value =~ '^,,'
341
+ let values .= strpart(value, 2)
342
+ let value = ','
343
+
344
+ " execption case after a ^,
345
+ elseif value =~ '^,'
346
+ let value = strpart(value, 1)
347
+ endif
348
+
349
+ " keyword values in an ascii number range
350
+ if value =~ '[0-9]\+-[0-9]\+'
351
+ let charnum = char2nr(a:char)
352
+ exec 'let start = ' . substitute(value, '\([0-9]\+\)-.*', '\1', '')
353
+ exec 'let end = ' . substitute(value, '.*-\([0-9]\+\)', '\1', '')
354
+
355
+ if charnum >= start && charnum <= end
356
+ return 1
357
+ endif
358
+
359
+ " keyword value is a set of include or exclude characters
360
+ else
361
+ let include = 1
362
+ if value =~ '^\^'
363
+ let value = strpart(value, 1)
364
+ let include = 0
365
+ endif
366
+
367
+ if a:char =~ '[' . escape(value, '[]') . ']'
368
+ return include
369
+ endif
370
+ endif
371
+ let index = stridx(values, ',')
372
+ endwhile
373
+
374
+ return 0
375
+ endfunction " }}}
376
+
377
+ " s:SetCompletionType() {{{
378
+ " Sets the completion type based on what the user has chosen from the help
379
+ " buffer.
380
+ function! s:SetCompletionType ()
381
+ let chosen = substitute(getline('.'), '.*|\(.*\)|.*', '\1', '')
382
+ if chosen != getline('.')
383
+ let winnr = b:winnr
384
+ close
385
+ exec winnr . 'winc w'
386
+ call SuperTabSetCompletionType(chosen)
387
+ endif
388
+ endfunction " }}}
389
+
390
+ " s:SetDefaultCompletionType() {{{
391
+ function! s:SetDefaultCompletionType ()
392
+ if exists('b:SuperTabDefaultCompletionType')
393
+ call SuperTabSetCompletionType(b:SuperTabDefaultCompletionType)
394
+ endif
395
+ endfunction " }}}
396
+
397
+ " s:SuperTab(command) {{{
398
+ " Used to perform proper cycle navigation as the user requests the next or
399
+ " previous entry in a completion list, and determines whether or not to simply
400
+ " retain the normal usage of <tab> based on the cursor position.
401
+ function! s:SuperTab (command)
402
+ if s:WillComplete()
403
+ let key = ''
404
+ " highlight first result if longest enabled
405
+ if g:SuperTabLongestHighlight && !pumvisible() && &completeopt =~ 'longest'
406
+ let key = (b:complType == "\<c-p>") ? "\<c-p>" : "\<c-n>"
407
+ endif
408
+
409
+ " exception: if in <c-p> mode, then <c-n> should move up the list, and
410
+ " <c-p> down the list.
411
+ if a:command == 'p' &&
412
+ \ (b:complType == "\<c-p>" ||
413
+ \ (b:complType == 'context' &&
414
+ \ tolower(g:SuperTabContextDefaultCompletionType) == '<c-p>'))
415
+ return "\<c-n>"
416
+ endif
417
+
418
+ if b:complType == 'context'
419
+ if index(g:SuperTabContextFileTypeExclusions, &ft) == -1
420
+ let curline = getline('.')
421
+ let cnum = col('.')
422
+ let synname = synIDattr(synID(line('.'), cnum - 1, 1), 'name')
423
+ if curline =~ '.*/\w*\%' . cnum . 'c' ||
424
+ \ ((has('win32') || has('win64')) && curline =~ '.*\\\w*\%' . cnum . 'c')
425
+ return "\<c-x>\<c-f>" . key
426
+ elseif curline =~ '.*\(\w\|[\])]\)\(\.\|::\|->\)\w*\%' . cnum . 'c' &&
427
+ \ synname !~ '\(String\|Comment\)'
428
+ if &completefunc != ''
429
+ return "\<c-x>\<c-u>" . key
430
+ elseif &omnifunc != ''
431
+ return "\<c-x>\<c-o>" . key
432
+ endif
433
+ endif
434
+ endif
435
+ exec "let complType = \"" . escape(g:SuperTabContextDefaultCompletionType, '<') . "\""
436
+ return complType . key
437
+ endif
438
+
439
+ return b:complType . key
440
+ endif
441
+
442
+ return "\<tab>"
443
+ endfunction " }}}
444
+
445
+ " s:SuperTabHelp() {{{
446
+ " Opens a help window where the user can choose a completion type to enter.
447
+ function! s:SuperTabHelp ()
448
+ let winnr = winnr()
449
+ if bufwinnr("SuperTabHelp") == -1
450
+ botright split SuperTabHelp
451
+
452
+ setlocal noswapfile
453
+ setlocal buftype=nowrite
454
+ setlocal bufhidden=delete
455
+
456
+ let saved = @"
457
+ let @" = s:tabHelp
458
+ silent put
459
+ call cursor(1, 1)
460
+ silent 1,delete
461
+ call cursor(4, 1)
462
+ let @" = saved
463
+ exec "resize " . line('$')
464
+
465
+ syntax match Special "|.\{-}|"
466
+
467
+ setlocal readonly
468
+ setlocal nomodifiable
469
+
470
+ nmap <silent> <buffer> <cr> :call <SID>SetCompletionType()<cr>
471
+ nmap <silent> <buffer> <c-]> :call <SID>SetCompletionType()<cr>
472
+ else
473
+ exec bufwinnr("SuperTabHelp") . "winc w"
474
+ endif
475
+ let b:winnr = winnr
476
+ endfunction " }}}
477
+
478
+ " s:WillComplete() {{{
479
+ " Determines if completion should be kicked off at the current location.
480
+ function! s:WillComplete ()
481
+ let line = getline('.')
482
+ let cnum = col('.')
483
+
484
+ " Start of line.
485
+ let prev_char = strpart(line, cnum - 2, 1)
486
+ if prev_char =~ '^\s*$'
487
+ return 0
488
+ endif
489
+
490
+ " Within a word, but user does not have mid word completion enabled.
491
+ let next_char = strpart(line, cnum - 1, 1)
492
+ if !g:SuperTabMidWordCompletion && s:IsWordChar(next_char)
493
+ return 0
494
+ endif
495
+
496
+ " In keyword completion mode and no preceding word characters.
497
+ "if (b:complType == "\<c-n>" || b:complType == "\<c-p>") && !s:IsWordChar(prev_char)
498
+ " return 0
499
+ "endif
500
+
501
+ return 1
502
+ endfunction " }}}
503
+
504
+ " Key Mappings {{{
505
+ " map a regular tab to ctrl-tab (note: doesn't work in console vim)
506
+ exec 'inoremap ' . g:SuperTabMappingTabLiteral . ' <tab>'
507
+
508
+ im <c-x> <c-r>=CtrlXPP()<cr>
509
+
510
+ " From the doc |insert.txt| improved
511
+ exec 'im ' . g:SuperTabMappingForward . ' <c-n>'
512
+ exec 'im ' . g:SuperTabMappingBackward . ' <c-p>'
513
+
514
+ " After hitting <Tab>, hitting it once more will go to next match
515
+ " (because in XIM mode <c-n> and <c-p> mappings are ignored)
516
+ " and wont start a brand new completion
517
+ " The side effect, that in the beginning of line <c-n> and <c-p> inserts a
518
+ " <Tab>, but I hope it may not be a problem...
519
+ ino <c-n> <c-r>=<SID>SuperTab('n')<cr>
520
+ ino <c-p> <c-r>=<SID>SuperTab('p')<cr>
521
+ " }}}
522
+
523
+ " Command Mappings {{{
524
+ if !exists(":SuperTabHelp")
525
+ command SuperTabHelp :call <SID>SuperTabHelp()
526
+ endif
527
+ " }}}
528
+
529
+ call <SID>Init()
530
+
531
+ " vim:ft=vim:fdm=marker