summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJason Linehan <patientulysses@gmail.com>2012-08-21 14:51:29 -0400
committerJason Linehan <patientulysses@gmail.com>2012-08-21 14:51:29 -0400
commit0bfe142afb467ed0fff48edde4b290081e780b2f (patch)
tree2a208f0315d8a25ee50aad91213ea2ba20203a66
parent9ee6f4070f4f911748aa85b41190d011fdd7a765 (diff)
parentdb071c39899d5a274000d52b82ff596cfcaa5ffa (diff)
Merge dev3.pathwaysystems.com:src/mine/ovimjason
Unable to send to github from the dev3 remote.
-rw-r--r--bundle/indent/html.vim254
-rw-r--r--bundle/indent/javascript.vim407
-rw-r--r--hubert.vimrc42
3 files changed, 699 insertions, 4 deletions
diff --git a/bundle/indent/html.vim b/bundle/indent/html.vim
new file mode 100644
index 0000000..ada5cc3
--- /dev/null
+++ b/bundle/indent/html.vim
@@ -0,0 +1,254 @@
+
+" Description: html indenter
+" Author: Johannes Zellner <johannes@zellner.org>
+" Last Change: Mo, 05 Jun 2006 22:32:41 CEST
+" Restoring 'cpo' and 'ic' added by Bram 2006 May 5
+" Globals: g:html_indent_tags -- indenting tags
+" g:html_indent_strict -- inhibit 'O O' elements
+" g:html_indent_strict_table -- inhibit 'O -' elements
+
+" Only load this indent file when no other was loaded.
+"if exists("b:did_indent")
+ "finish
+"endif
+"let b:did_indent = 1
+
+if exists("g:js_indent")
+ so g:js_indent
+else
+ ru! indent/javascript.vim
+endif
+
+echo "Sourcing html indent"
+
+
+" [-- local settings (must come before aborting the script) --]
+setlocal indentexpr=HtmlIndentGetter(v:lnum)
+setlocal indentkeys=o,O,*<Return>,<>>,{,}
+
+
+if exists('g:html_indent_tags')
+ unlet g:html_indent_tags
+endif
+
+" [-- helper function to assemble tag list --]
+fun! <SID>HtmlIndentPush(tag)
+ if exists('g:html_indent_tags')
+ let g:html_indent_tags = g:html_indent_tags.'\|'.a:tag
+ else
+ let g:html_indent_tags = a:tag
+ endif
+endfun
+
+
+" [-- <ELEMENT ? - - ...> --]
+call <SID>HtmlIndentPush('a')
+call <SID>HtmlIndentPush('abbr')
+call <SID>HtmlIndentPush('acronym')
+call <SID>HtmlIndentPush('address')
+call <SID>HtmlIndentPush('b')
+call <SID>HtmlIndentPush('bdo')
+call <SID>HtmlIndentPush('big')
+call <SID>HtmlIndentPush('blockquote')
+call <SID>HtmlIndentPush('button')
+call <SID>HtmlIndentPush('caption')
+call <SID>HtmlIndentPush('center')
+call <SID>HtmlIndentPush('cite')
+call <SID>HtmlIndentPush('code')
+call <SID>HtmlIndentPush('colgroup')
+call <SID>HtmlIndentPush('del')
+call <SID>HtmlIndentPush('dfn')
+call <SID>HtmlIndentPush('dir')
+call <SID>HtmlIndentPush('div')
+call <SID>HtmlIndentPush('dl')
+call <SID>HtmlIndentPush('em')
+call <SID>HtmlIndentPush('fieldset')
+call <SID>HtmlIndentPush('font')
+call <SID>HtmlIndentPush('form')
+call <SID>HtmlIndentPush('frameset')
+call <SID>HtmlIndentPush('h1')
+call <SID>HtmlIndentPush('h2')
+call <SID>HtmlIndentPush('h3')
+call <SID>HtmlIndentPush('h4')
+call <SID>HtmlIndentPush('h5')
+call <SID>HtmlIndentPush('h6')
+call <SID>HtmlIndentPush('i')
+call <SID>HtmlIndentPush('iframe')
+call <SID>HtmlIndentPush('ins')
+call <SID>HtmlIndentPush('kbd')
+call <SID>HtmlIndentPush('label')
+call <SID>HtmlIndentPush('legend')
+call <SID>HtmlIndentPush('map')
+call <SID>HtmlIndentPush('menu')
+call <SID>HtmlIndentPush('noframes')
+call <SID>HtmlIndentPush('noscript')
+call <SID>HtmlIndentPush('object')
+call <SID>HtmlIndentPush('ol')
+call <SID>HtmlIndentPush('optgroup')
+" call <SID>HtmlIndentPush('pre')
+call <SID>HtmlIndentPush('q')
+call <SID>HtmlIndentPush('s')
+call <SID>HtmlIndentPush('samp')
+call <SID>HtmlIndentPush('script')
+call <SID>HtmlIndentPush('select')
+call <SID>HtmlIndentPush('small')
+call <SID>HtmlIndentPush('span')
+call <SID>HtmlIndentPush('strong')
+call <SID>HtmlIndentPush('style')
+call <SID>HtmlIndentPush('sub')
+call <SID>HtmlIndentPush('sup')
+call <SID>HtmlIndentPush('table')
+call <SID>HtmlIndentPush('textarea')
+call <SID>HtmlIndentPush('title')
+call <SID>HtmlIndentPush('tt')
+call <SID>HtmlIndentPush('u')
+call <SID>HtmlIndentPush('ul')
+call <SID>HtmlIndentPush('var')
+
+
+" [-- <ELEMENT ? O O ...> --]
+if !exists('g:html_indent_strict')
+ call <SID>HtmlIndentPush('body')
+ call <SID>HtmlIndentPush('head')
+ call <SID>HtmlIndentPush('html')
+ call <SID>HtmlIndentPush('tbody')
+endif
+
+
+" [-- <ELEMENT ? O - ...> --]
+if !exists('g:html_indent_strict_table')
+ call <SID>HtmlIndentPush('th')
+ call <SID>HtmlIndentPush('td')
+ call <SID>HtmlIndentPush('tr')
+ call <SID>HtmlIndentPush('tfoot')
+ call <SID>HtmlIndentPush('thead')
+endif
+
+delfun <SID>HtmlIndentPush
+
+let s:cpo_save = &cpo
+set cpo-=C
+
+" [-- count indent-increasing tags of line a:lnum --]
+fun! <SID>HtmlIndentOpen(lnum, pattern)
+ let s = substitute('x'.getline(a:lnum),
+ \ '.\{-}\(\(<\)\('.a:pattern.'\)\>\)', "\1", 'g')
+ let s = substitute(s, "[^\1].*$", '', '')
+ return strlen(s)
+endfun
+
+" [-- count indent-decreasing tags of line a:lnum --]
+fun! <SID>HtmlIndentClose(lnum, pattern)
+ let s = substitute('x'.getline(a:lnum),
+ \ '.\{-}\(\(<\)/\('.a:pattern.'\)\>>\)', "\1", 'g')
+ let s = substitute(s, "[^\1].*$", '', '')
+ return strlen(s)
+endfun
+
+" [-- count indent-increasing '{' of (java|css) line a:lnum --]
+fun! <SID>HtmlIndentOpenAlt(lnum)
+ return strlen(substitute(getline(a:lnum), '[^{]\+', '', 'g'))
+endfun
+
+" [-- count indent-decreasing '}' of (java|css) line a:lnum --]
+fun! <SID>HtmlIndentCloseAlt(lnum)
+ return strlen(substitute(getline(a:lnum), '[^}]\+', '', 'g'))
+endfun
+
+" [-- return the sum of indents respecting the syntax of a:lnum --]
+fun! <SID>HtmlIndentSum(lnum, style)
+ if a:style == match(getline(a:lnum), '^\s*</')
+ if a:style == match(getline(a:lnum), '^\s*</\<\('.g:html_indent_tags.'\)\>')
+ let open = <SID>HtmlIndentOpen(a:lnum, g:html_indent_tags)
+ let close = <SID>HtmlIndentClose(a:lnum, g:html_indent_tags)
+ if 0 != open || 0 != close
+ return open - close
+ endif
+ endif
+ endif
+ if '' != &syntax &&
+ \ synIDattr(synID(a:lnum, 1, 1), 'name') =~ '\(css\|java\).*' &&
+ \ synIDattr(synID(a:lnum, strlen(getline(a:lnum)), 1), 'name')
+ \ =~ '\(css\|java\).*'
+ if a:style == match(getline(a:lnum), '^\s*}')
+ return <SID>HtmlIndentOpenAlt(a:lnum) - <SID>HtmlIndentCloseAlt(a:lnum)
+ endif
+ endif
+ return 0
+endfun
+
+fun! HtmlIndentGetter(lnum)
+
+ echo "Grabbing html indent for line: " . a:lnum
+ " Find a non-empty line above the current line.
+ let lnum = prevnonblank(a:lnum - 1)
+
+ " Hit the start of the file, use zero indent.
+ if lnum == 0
+ return 0
+ endif
+
+ let restore_ic = &ic
+ setlocal ic " ignore case
+
+ " [-- special handling for <pre>: no indenting --]
+ if getline(a:lnum) =~ '\c</pre>'
+ \ || 0 < searchpair('\c<pre>', '', '\c</pre>', 'nWb')
+ \ || 0 < searchpair('\c<pre>', '', '\c</pre>', 'nW')
+ " we're in a line with </pre> or inside <pre> ... </pre>
+ if restore_ic == 0
+ setlocal noic
+ endif
+ return -1
+ endif
+
+ " [-- special handling for <javascript>: use cindent --]
+ let js = '<script.*type\s*=.*javascript'
+
+ """"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""
+ " by Tye Zdrojewski <zdro@yahoo.com>, 05 Jun 2006
+ " ZDR: This needs to be an AND (we are 'after the start of the pair' AND
+ " we are 'before the end of the pair'). Otherwise, indentation
+ " before the start of the script block will be affected; the end of
+ " the pair will still match if we are before the beginning of the
+ " pair.
+ "
+ if 0 < searchpair(js, '', '</script>', 'nWb')
+ \ && 0 < searchpair(js, '', '</script>', 'nW')
+ " we're inside javascript
+
+ if getline(lnum) !~ js && getline(a:lnum) !~ '</script>'
+ if restore_ic == 0
+ setlocal noic
+ endif
+ return GetJsIndent(a:lnum)
+ endif
+ endif
+
+ if getline(lnum) =~ '\c</pre>'
+ " line before the current line a:lnum contains
+ " a closing </pre>. --> search for line before
+ " starting <pre> to restore the indent.
+ let preline = prevnonblank(search('\c<pre>', 'bW') - 1)
+ if preline > 0
+ if restore_ic == 0
+ setlocal noic
+ endif
+ return indent(preline)
+ endif
+ endif
+
+ let ind = <SID>HtmlIndentSum(lnum, -1)
+ let ind = ind + <SID>HtmlIndentSum(a:lnum, 0)
+
+ if restore_ic == 0
+ setlocal noic
+ endif
+
+ return indent(lnum) + (&sw * ind)
+endfun
+
+let &cpo = s:cpo_save
+unlet s:cpo_save
+
+" [-- EOF <runtime>/indent/html.vim --]
diff --git a/bundle/indent/javascript.vim b/bundle/indent/javascript.vim
new file mode 100644
index 0000000..b0e190c
--- /dev/null
+++ b/bundle/indent/javascript.vim
@@ -0,0 +1,407 @@
+" Vim indent file Language: JavaScript
+" Author: Preston Koprivica (pkopriv2@gmail.com)
+" URL:
+" Last Change: April 30, 2010
+
+" 0. Standard Stuff
+" =================
+
+" Only load one indent script per buffer
+if exists('b:did_indent')
+ finish
+endif
+
+let b:did_indent = 1
+
+" Set the global log variable 1 = logging enabled, 0 = logging disabled
+if !exists("g:js_indent_log")
+ let g:js_indent_log = 0
+endif
+
+setlocal indentexpr=GetJsIndent(v:lnum)
+setlocal indentkeys=
+
+
+setlocal cindent
+setlocal autoindent
+
+
+" 1. Variables
+" ============
+
+" Inline comments (for anchoring other statements)
+let s:js_mid_line_comment = '\s*\(\/\*.*\*\/\)*\s*'
+let s:js_end_line_comment = s:js_mid_line_comment . '\s*\(//.*\)*'
+let s:js_line_comment = s:js_end_line_comment
+
+" Comment/String Syntax Key
+let s:syn_comment = '\(Comment\|String\|Regexp\)'
+
+
+" 2. Aux. Functions
+" =================
+
+" = Method: IsInComment
+"
+" Determines whether the specified position is contained in a comment. "Note:
+" This depends on a
+function! s:IsInComment(lnum, cnum)
+ return synIDattr(synID(a:lnum, a:cnum, 1), 'name') =~? s:syn_comment
+endfunction
+
+
+" = Method: IsComment
+"
+" Determines whether a line is a comment or not.
+function! s:IsComment(lnum)
+ let line = getline(a:lnum)
+
+ return s:IsInComment(a:lnum, 1) && s:IsInComment(a:lnum, strlen(line)) "Doesn't absolutely work. Only Probably!
+endfunction
+
+
+" = Method: GetNonCommentLine
+"
+" Grabs the nearest non-commented line
+function! s:GetNonCommentLine(lnum)
+ let lnum = prevnonblank(a:lnum)
+
+ while lnum > 0
+ if s:IsComment(lnum)
+ let lnum = prevnonblank(lnum - 1)
+ else
+ return lnum
+ endif
+ endwhile
+
+ return lnum
+endfunction
+
+" = Method: SearchForPair
+"
+" Returns the beginning tag of a given pair starting from the given line.
+function! s:SearchForPair(lnum, beg, end)
+ " Save the cursor position.
+ let curpos = getpos(".")
+
+ " Set the cursor position to the beginning of the line (default
+ " behavior when using ==)
+ call cursor(a:lnum, 0)
+
+ " Search for the opening tag
+ let mnum = searchpair(a:beg, '', a:end, 'bW',
+ \ 'synIDattr(synID(line("."), col("."), 0), "name") =~? s:syn_comment' )
+
+ "Restore the cursor position
+ call cursor(curpos)
+
+ " Finally, return the matched line number
+ return mnum
+endfunction
+
+
+" Object Helpers
+" ==============
+let s:object_beg = '{[^}]*' . s:js_end_line_comment . '$'
+let s:object_end = '^' . s:js_mid_line_comment . '}[;,]\='
+
+
+function! s:IsObjectBeg(line)
+ return a:line =~ s:object_beg
+endfunction
+
+function! s:IsObjectEnd(line)
+ return a:line =~ s:object_end
+endfunction
+
+function! s:GetObjectBeg(lnum)
+ return s:SearchForPair(a:lnum, '{', '}')
+endfunction
+
+
+" Array Helpers
+" ==============
+let s:array_beg = '\[[^\]]*' . s:js_end_line_comment . '$'
+let s:array_end = '^' . s:js_mid_line_comment . '[^\[]*\][;,]*' . s:js_end_line_comment . '$'
+
+
+function! s:IsArrayBeg(line)
+ return a:line =~ s:array_beg
+endfunction
+
+function! s:IsArrayEnd(line)
+ return a:line =~ s:array_end
+endfunction
+
+function! s:GetArrayBeg(lnum)
+ return s:SearchForPair(a:lnum, '\[', '\]')
+endfunction
+
+
+" MultiLine Declaration/Invocation Helpers
+" ========================================
+let s:paren_beg = '([^)]*' . s:js_end_line_comment . '$'
+let s:paren_end = '^' . s:js_mid_line_comment . '[^(]*)[;,]*'
+
+function! s:IsParenBeg(line)
+ return a:line =~ s:paren_beg
+endfunction
+
+function! s:IsParenEnd(line)
+ return a:line =~ s:paren_end
+endfunction
+
+function! s:GetParenBeg(lnum)
+ return s:SearchForPair(a:lnum, '(', ')')
+endfunction
+
+
+
+" Continuation Helpers
+" ====================
+let s:continuation = '\(+\|\\\)\{1}' . s:js_line_comment . '$'
+
+function! s:IsContinuationLine(line)
+ return a:line =~ s:continuation
+endfunction
+
+function! s:GetContinuationBegin(lnum)
+ let cur = a:lnum
+
+ while s:IsContinuationLine(getline(cur))
+ let cur -= 1
+ endwhile
+
+ return cur + 1
+endfunction
+
+
+" Switch Helpers
+" ==============
+let s:switch_beg_next_line = 'switch\s*(.*)\s*' . s:js_mid_line_comment . s:js_end_line_comment . '$'
+let s:switch_beg_same_line = 'switch\s*(.*)\s*' . s:js_mid_line_comment . '{\s*' . s:js_line_comment . '$'
+let s:switch_mid = '^.*\(case.*\|default\)\s*:\s*'
+
+function! s:IsSwitchBeginNextLine(line)
+ return a:line =~ s:switch_beg_next_line
+endfunction
+
+function! s:IsSwitchBeginSameLine(line)
+ return a:line =~ s:switch_beg_same_line
+endfunction
+
+function! s:IsSwitchMid(line)
+ return a:line =~ s:switch_mid
+endfunction
+
+
+" Control Helpers
+" ===============
+let s:cntrl_beg_keys = '\(\(\(if\|for\|with\|while\)\s*(.*)\)\|\(try\|do\)\)\s*'
+let s:cntrl_mid_keys = '\(\(\(else\s*if\|catch\)\s*(.*)\)\|\(finally\|else\)\)\s*'
+
+let s:cntrl_beg = s:cntrl_beg_keys . s:js_end_line_comment . '$'
+let s:cntrl_mid = s:cntrl_mid_keys . s:js_end_line_comment . '$'
+
+let s:cntrl_end = '\(while\s*(.*)\)\s*;\=\s*' . s:js_end_line_comment . '$'
+
+function! s:IsControlBeg(line)
+ return a:line =~ s:cntrl_beg
+endfunction
+
+function! s:IsControlMid(line)
+ return a:line =~ s:cntrl_mid
+endfunction
+
+function! s:IsControlMidStrict(line)
+ return a:line =~ s:cntrl_mid
+endfunction
+
+function! s:IsControlEnd(line)
+ return a:line =~ s:cntrl_end
+endfunction
+
+" = Method: Log
+"
+" Logs a message to the stdout.
+function! s:Log(msg)
+ if g:js_indent_log
+ echo "LOG: " . a:msg
+ endif
+endfunction
+
+
+" 3. Indenter
+" ===========
+function! GetJsIndent(lnum)
+ " Grab the first non-comment line prior to this line
+ let pnum = s:GetNonCommentLine(a:lnum-1)
+
+ " First line, start at indent = 0
+ if pnum == 0
+ call s:Log("No, noncomment lines prior to the current line.")
+ return 0
+ endif
+
+ " Grab the second non-comment line prior to this line
+ let ppnum = s:GetNonCommentLine(pnum-1)
+
+ call s:Log("Line: " . a:lnum)
+ call s:Log("PLine: " . pnum)
+ call s:Log("PPLine: " . ppnum)
+
+ " Grab the lines themselves.
+ let line = getline(a:lnum)
+ let pline = getline(pnum)
+ let ppline = getline(ppnum)
+
+ " Determine the current level of indentation
+ let ind = indent(pnum)
+
+
+ " Handle: Object Closers (ie })
+ " =============================
+ if s:IsObjectEnd(line) && !s:IsComment(a:lnum)
+ call s:Log("Line matched object end")
+
+ let obeg = s:GetObjectBeg(a:lnum)
+ let oind = indent(obeg)
+ let oline = getline(obeg)
+
+ call s:Log("The object beg was found at: " . obeg)
+ return oind
+ endif
+
+ if s:IsObjectBeg(pline)
+ call s:Log("Pline matched object beg")
+ return ind + &sw
+ endif
+
+
+ " Handle: Array Closer (ie ])
+ " ============================
+ if s:IsArrayEnd(line) && !s:IsComment(a:lnum)
+ call s:Log("Line matched array end")
+
+ let abeg = s:GetArrayBeg(a:lnum)
+ let aind = indent(abeg)
+
+ call s:Log("The array beg was found at: " . abeg)
+ return aind
+ endif
+
+ if s:IsArrayBeg(pline)
+ call s:Log("Pline matched array beg")
+ return ind + &sw
+ endif
+
+ " Handle: Parens
+ " ==============
+ if s:IsParenEnd(line) && !s:IsComment(a:lnum)
+ call s:Log("Line matched paren end")
+
+ let abeg = s:GetParenBeg(a:lnum)
+ let aind = indent(abeg)
+
+ call s:Log("The paren beg was found at: " . abeg)
+ return aind
+ endif
+
+ if s:IsParenBeg(pline)
+ call s:Log("Pline matched paren beg")
+ return ind + &sw
+ endif
+
+
+ " Handle: Continuation Lines.
+ " ========================================================
+ if s:IsContinuationLine(pline)
+ call s:Log('Pline is a continuation line.')
+
+ let cbeg = s:GetContinuationBegin(pnum)
+ let cind = indent(cbeg)
+
+ call s:Log('The continuation block begin found at: ' . cbeg)
+ return cind + &sw
+ endif
+
+ if s:IsContinuationLine(ppline)
+ call s:Log('PPline was a continuation line but pline wasnt.')
+ return ind - &sw
+ endif
+
+ " Handle: Switch Control Blocks
+ " =============================
+ if s:IsSwitchMid(pline)
+ call s:Log("PLine matched switch cntrl mid")
+ if s:IsSwitchMid(line) || s:IsObjectEnd(line)
+ call s:Log("Line matched a cntrl mid")
+ return ind
+ else
+ call s:Log("Line didnt match a cntrl mid")
+ return ind + &sw
+ endif
+ endif
+
+ if s:IsSwitchMid(line)
+ call s:Log("Line matched switch cntrl mid")
+ return ind - &sw
+ endif
+
+
+ " Handle: Single Line Control Blocks
+ " ==================================
+ if s:IsControlBeg(pline)
+ call s:Log("Pline matched control beginning")
+
+ if s:IsControlMid(line)
+ call s:Log("Line matched a control mid")
+ return ind
+ elseif line =~ '^\s*{\s*$'
+ call s:Log("Line matched an object beg")
+ return ind
+ else
+ return ind + &sw
+ endif
+
+ endif
+
+ if s:IsControlMid(pline)
+ call s:Log("Pline matched a control mid")
+
+ if s:IsControlMid(line)
+ call s:Log("Line matched a control mid")
+ return ind
+ elseif s:IsObjectBeg(line)
+ call s:Log("Line matched an object beg")
+ return ind
+ else
+ call s:Log("Line didn't match a control mid or object beg."
+ return ind + &sw
+ endif
+ endif
+
+ if s:IsControlMid(line)
+ call s:Log("Line matched a control mid.")
+
+ if s:IsControlEnd(pline) || s:IsObjectEnd(pline)
+ call s:Log("PLine matched control end")
+ return ind
+ else
+ call s:Log("Pline didn't match object end")
+ return ind - &sw
+ endif
+ endif
+
+
+ if ( s:IsControlBeg(ppline) || s:IsControlMid(ppline) ) &&
+ \ !s:IsObjectBeg(pline) && !s:IsObjectEnd(pline)
+ call s:Log("PPLine matched single line control beg or mid")
+ return ind - &sw
+ endif
+
+ " Handle: No matches
+ " ==================
+ "call s:Log("Line didn't match anything. Retaining indent")
+ return ind
+endfunction
diff --git a/hubert.vimrc b/hubert.vimrc
index 81d461b..7c98b4a 100644
--- a/hubert.vimrc
+++ b/hubert.vimrc
@@ -100,10 +100,11 @@
set showmode
" Execute python file being edited
noremap <buffer> <S-e> :w<CR>:!/usr/bin/env python2 % <CR>
-" Turn the color column on and off
+
+" Colorcolumn stuff
noremap <Leader>8 <Esc>:call <SID>ToggleColorColumn()<CR>
-" Turn the 72-col color column on and off
noremap <Leader>7 <Esc>:call <SID>ToggleFormatColumn()<CR>
+
" Close a buffer
noremap <Leader><F1> <Esc>:call CleanClose(1)<CR>
" Set 4-space tabs
@@ -124,7 +125,7 @@
" `````````````````````````````````````````````````````````````````````````````
let NERDTreeMinimalUI=1 " Disable the goofy '? for help' message
let NERDChristmasTree=1 " Tells the NERD tree to make itself colourful
- let NERDTreeWinSize=20 " Default is 31
+ let NERDTreeWinSize=31 " Default is 31
" buftabs
" `````````````````````````````````````````````````````````````````````````````
@@ -143,7 +144,9 @@
" ToggleColorColumn()
" `````````````````````````````````````````````````````````````````````````````
hi ColorColumn ctermbg=108
- set colorcolumn=81 " The column to be colored
+ if exists('+colorcolumn')
+ set colorcolumn=81 " The column to be colored
+ endif
let s:color_column_old=0 " ToggleColorColumn by default
function! s:ToggleColorColumn()
@@ -176,6 +179,37 @@
exe "bd".todelbufNr
call Buftabs_show(todelbufNr)
endfunction
+
+" QFDo() -- Run a command on each item in the quickfix buffer.
+" ````````````````````````````````````````````````````````````
+function! QFDo(command)
+ " Create a dictionary so that we can get the list of
+ " buffers rather than the list of lines in buffers
+ " (easy way to get unique entries).
+ let buffer_numbers = {}
+ " For each entry, use the buffer number as a dictionary
+ " key (won't get repeats).
+ for fixlist_entry in getqflist()
+ let buffer_numbers[fixlist_entry['bufnr']] = 1
+ endfor
+ " Make it into a list as it seems cleaner
+ let buffer_number_list = keys(buffer_numbers)
+
+ " For each buffer
+ for num in buffer_number_list
+ " Select the buffer
+ exe 'buffer' num
+ " Run the command that's passed as an argument
+ exe a:command
+ " Save if necessary
+ update
+ endfor
+endfunction
+
+" Define a command to make it easier to use
+command! -nargs=+ QFDo call QFDo(<q-args>)
+
+
" =============================================================================