diff --git a/plugin/delimitMate.vim b/plugin/delimitMate.vim index 9791158..4945d3d 100644 --- a/plugin/delimitMate.vim +++ b/plugin/delimitMate.vim @@ -18,7 +18,8 @@ " - Vim Scripts: " http://www.vim.org/scripts/ -if exists("g:loaded_delimitMate") "{{{1 +" Initialization: {{{ +if exists("g:loaded_delimitMate") "{{{ " User doesn't want this plugin, let's get out! finish endif @@ -36,19 +37,21 @@ if v:version < 700 finish endif -let s:loaded_delimitMate = 1 " }}}1 +let s:loaded_delimitMate = 1 " }}} -function! s:Init() "{{{1 +function! s:Init() "{{{ - if !exists("b:delimitMate_autoclose") && !exists("g:delimitMate_autoclose") " {{{ - let s:autoclose = 1 - elseif exists("b:delimitMate_autoclose") - let s:autoclose = b:delimitMate_autoclose + " delimitMate_autoclose {{{ + if !exists("b:delimitMate_autoclose") && !exists("g:delimitMate_autoclose") + let b:delimitMate_autoclose = 1 + elseif !exists("b:delimitMate_autoclose") && exists("g:delimitMate_autoclose") + let b:delimitMate_autoclose = g:delimitMate_autoclose else - let s:autoclose = g:delimitMate_autoclose + " Nothing to do. endif " }}} - if !exists("b:delimitMate_matchpairs") && !exists("g:delimitMate_matchpairs") " {{{ + " delimitMate_matchpairs {{{ + if !exists("b:delimitMate_matchpairs") && !exists("g:delimitMate_matchpairs") if s:ValidMatchpairs(&matchpairs) == 1 let s:matchpairs_temp = &matchpairs else @@ -82,7 +85,8 @@ function! s:Init() "{{{1 endif " }}} - if exists("b:delimitMate_quotes") " {{{ + " delimitMate_quotes {{{ + if exists("b:delimitMate_quotes") if b:delimitMate_quotes =~ '^\(\S\)\(\s\S\)*$' || b:delimitMate_quotes == "" let s:quotes = split(b:delimitMate_quotes) else @@ -98,62 +102,75 @@ function! s:Init() "{{{1 endif else let s:quotes = split("\" ' `") - endif " }}} + endif + if exists('b:delimitMate_quotes') | unlet b:delimitMate_quotes | endif + let b:delimitMate_quotes = s:quotes " }}} - if !exists("b:delimitMate_visual_leader") && !exists("g:delimitMate_visual_leader") " {{{ - if !exists("g:mapleader") - let s:visual_leader = "\\" - else - let s:visual_leader = g:mapleader - endif - elseif exists("b:delimitMate_visual_leader") - let s:visual_leader = b:delimitMate_visual_leader + " delimitMate_visual_leader {{{ + if !exists("b:delimitMate_visual_leader") && !exists("g:delimitMate_visual_leader") + let b:delimitMate_visual_leader = exists('g:maplocalleader') ? g:maplocalleader : + \ exists('mapleader') ? g:mapleader : "\\" + elseif !exists("b:delimitMate_visual_leader") && exists("g:delimitMate_visual_leader") + let b:delimitMate_visual_leader = g:delimitMate_visual_leader else - let s:visual_leader = g:delimitMate_visual_leader + " Nothing to do. endif " }}} - if !exists("b:delimitMate_expand_space") && !exists("g:delimitMate_expand_space") " {{{ - let s:expand_space = 0 - elseif exists("b:delimitMate_expand_space") - let s:expand_space = b:delimitMate_expand_space + " delimitMate_expand_space {{{ + if !exists("b:delimitMate_expand_space") && !exists("g:delimitMate_expand_space") + let b:delimitMate_expand_space = 0 + elseif !exists("b:delimitMate_expand_space") && !exists("g:delimitMate_expand_space") + let b:delimitMate_expand_space = g:delimitMate_expand_space else - let s:expand_space = g:delimitMate_expand_space + " Nothing to do. endif " }}} - if !exists("b:delimitMate_expand_cr") && !exists("g:delimitMate_expand_cr") " {{{ - let s:expand_cr = 0 - elseif exists("b:delimitMate_expand_cr") - let s:expand_cr = b:delimitMate_expand_cr + " delimitMate_expand_cr {{{ + if !exists("b:delimitMate_expand_cr") && !exists("g:delimitMate_expand_cr") + let b:delimitMate_expand_cr = 0 + elseif !exists("b:delimitMate_expand_cr") && exists("g:delimitMate_expand_cr") + let b:delimitMate_expand_cr = g:delimitMate_expand_cr else - let s:expand_cr = g:delimitMate_expand_cr + " Nothing to do. endif " }}} - if !exists("b:delimitMate_apostrophes") && !exists("g:delimitMate_apostrophes") " {{{ + " delimitMate_smart_quotes {{{ + if !exists("b:delimitMate_smart_quotes") && !exists("g:delimitMate_smart_quotes") + let b:delimitMate_smart_quotes = 1 + elseif !exists("b:delimitMate_smart_quotes") && exists("g:delimitMate_smart_quotes") + let b:delimitMate_smart_quotes = split(g:delimitMate_smart_quotes) + else + " Nothing to do. + endif " }}} + + " delimitMate_apostrophes {{{ + if !exists("b:delimitMate_apostrophes") && !exists("g:delimitMate_apostrophes") "let s:apostrophes = split("n't:'s:'re:'m:'d:'ll:'ve:s'",':') - let s:apostrophes = [] - - elseif exists("b:delimitMate_apostrophes") + let b:delimitMate_apostrophes = [] + elseif !exists("b:delimitMate_apostrophes") && exists("g:delimitMate_apostrophes") + let b:delimitMate_apostrophes = split(g:delimitMate_apostrophes) + else let s:apostrophes = split(b:delimitMate_apostrophes) - else - let s:apostrophes = split(g:delimitMate_apostrophes) + unlet b:delimitMate_apostrophes + let b:delimitMate_apostrophes = s:apostrophes endif " }}} - if !exists("b:delimitMate_tab2exit") && !exists("g:delimitMate_tab2exit") " {{{ - let s:tab2exit = 1 - - elseif exists("b:delimitMate_tab2exit") - let s:tab2exit = split(b:delimitMate_tab2exit) + " delimitMate_tab2exit {{{ + if !exists("b:delimitMate_tab2exit") && !exists("g:delimitMate_tab2exit") + let b:delimitMate_tab2exit = 1 + elseif !exists("b:delimitMate_tab2exit") && exists("g:delimitMate_tab2exit") + let b:delimitMate_tab2exit = g:delimitMate_tab2exit else - let s:tab2exit = split(g:delimitMate_tab2exit) + " Nothing to do. endif " }}} - let s:matchpairs = split(s:matchpairs_temp, ',') - let s:left_delims = split(s:matchpairs_temp, ':.,\=') - let s:right_delims = split(s:matchpairs_temp, ',\=.:') + let b:delimitMate_matchpairs = split(s:matchpairs_temp, ',') + let b:delimitMate_left_delims = split(s:matchpairs_temp, ':.,\=') + let b:delimitMate_right_delims = split(s:matchpairs_temp, ',\=.:') let s:VMapMsg = "delimitMate: delimitMate is disabled on blockwise visual mode." - "call s:UnMap() - if s:autoclose + call s:UnMap() + if b:delimitMate_autoclose call s:AutoClose() else call s:NoAutoClose() @@ -162,9 +179,11 @@ function! s:Init() "{{{1 call s:ExtraMappings() let b:loaded_delimitMate = 1 -endfunction "}}}1 Init() +endfunction "}}} Init() +"}}} -function! s:ValidMatchpairs(str) "{{{1 +" Utilities: {{{ +function! s:ValidMatchpairs(str) "{{{ if a:str !~ '^.:.\(,.:.\)*$' return 0 endif @@ -174,46 +193,59 @@ function! s:ValidMatchpairs(str) "{{{1 endif endfor return 1 -endfunction "}}}1 +endfunction "}}} -function! DelimitMate_ShouldJump() "{{{1 +function! DelimitMate_ShouldJump() "{{{ let char = getline('.')[col('.') - 1] - for pair in s:matchpairs + for pair in b:delimitMate_matchpairs if char == split( pair, ':' )[1] " Same character on the rigth, jump over it. return 1 endif endfor - for quote in s:quotes + for quote in b:delimitMate_quotes if char == quote " Same character on the rigth, jump over it. return 1 endif endfor return 0 -endfunction "}}}1 +endfunction "}}} -function! s:JumpIn(char) " {{{ - let line = getline('.') - let col = col('.')-2 - if (col) < 0 - call setline('.',a:char.line) - else - echom string(col).':'.line[:(col)].'|'.line[(col+1):] - call setline('.',line[:(col)].a:char.line[(col+1):]) - endif - return '' -endfunction " }}} - -function! s:JumpOut(char) "{{{ - let line = getline('.') - let col = col('.')-2 - if line[col+1] == a:char - call setline('.',line[:(col)].line[(col+2):]) +function! s:IsBlockVisual() " {{{ + if visualmode() == "" + return 1 endif - return a:char + " Store unnamed register values for later use in s:RestoreRegister(). + let s:save_reg = getreg('"') + let s:save_reg_mode = getregtype('"') + + if len(getline('.')) == 0 + " This for proper wrap of empty lines. + let @" = "\n" + endif + return 0 endfunction " }}} +function! s:IsEmptyPair(str) "{{{ + for pair in b:delimitMate_matchpairs + if a:str == join( split( pair, ':' ),'' ) + return 1 + endif + endfor + for quote in b:delimitMate_quotes + if a:str == quote . quote + return 1 + endif + endfor + return 0 +endfunction "}}} + +function! DelimitMate_WithinEmptyPair() "{{{ + let cur = strpart( getline('.'), col('.')-2, 2 ) + return s:IsEmptyPair( cur ) +endfunction "}}} + function! s:WriteBefore(str) "{{{ let len = len(a:str) let line = getline('.') @@ -238,26 +270,36 @@ function! s:WriteAfter(str) "{{{ return '' endfunction " }}} -function! s:IsEmptyPair(str) "{{{1 - for pair in s:matchpairs - if a:str == join( split( pair, ':' ),'' ) - return 1 - endif - endfor - for quote in s:quotes - if a:str == quote . quote - return 1 - endif - endfor - return 0 -endfunction "}}}1 +function! s:RestoreRegister() " {{{ + " Restore unnamed register values store in s:IsBlockVisual(). + call setreg('"', s:save_reg, s:save_reg_mode) + echo "" +endfunction " }}} +" }}} -function! DelimitMate_WithinEmptyPair() "{{{1 - let cur = strpart( getline('.'), col('.')-2, 2 ) - return s:IsEmptyPair( cur ) -endfunction "}}}1 +" Doers: {{{ +function! s:JumpIn(char) " {{{ + let line = getline('.') + let col = col('.')-2 + if (col) < 0 + call setline('.',a:char.line) + else + echom string(col).':'.line[:(col)].'|'.line[(col+1):] + call setline('.',line[:(col)].a:char.line[(col+1):]) + endif + return '' +endfunction " }}} -function! s:SkipDelim(char) "{{{1 +function! s:JumpOut(char) "{{{ + let line = getline('.') + let col = col('.')-2 + if line[col+1] == a:char + call setline('.',line[:(col)].line[(col+2):]) + endif + return a:char +endfunction " }}} + +function! s:SkipDelim(char) "{{{ let cur = strpart( getline('.'), col('.')-2, 3 ) if cur[0] == "\\" " Escaped character @@ -275,9 +317,9 @@ function! s:SkipDelim(char) "{{{1 " Nothing special here, return the same character. return a:char endif -endfunction "}}}1 +endfunction "}}} -function! s:QuoteDelim(char) "{{{1 +function! s:QuoteDelim(char) "{{{ let line = getline('.') let col = col('.') - 2 if line[col] == "\\" @@ -286,54 +328,33 @@ function! s:QuoteDelim(char) "{{{1 elseif line[col + 1] == a:char " Get out of the string. return s:WriteBefore(a:char) - elseif line[col] == a:char && line[col + 1 ] != a:char - " Seems like we have an unbalanced quote, insert one quotation mark. + elseif ((line[col] == a:char && line[col + 1 ] != a:char) + \ || line[col] =~ '[a-zA-Z0-9]') + \ && b:delimitMate_smart_quotes + " Seems like we have an unbalanced quote or a closing quote, + " insert one quotation mark and jump to tthe middle. return s:WriteAfter(a:char) - elseif line[col] =~ '[a-zA-Z0-9]' - " Seems like we closing quotes, insert a single quote. + elseif line[col] =~ '[a-zA-Z0-9]' && a:char == "'" + " Seems like an apostrophe, insert a single quote. return a:char else " Insert a pair and jump to the middle. - "call setline('.',line[:(col)].a:char.line[(col+3):]) call s:WriteAfter(a:char) return a:char endif -endfunction "}}}1 +endfunction "}}} -function! s:ClosePair(char) "{{{1 - "if getline('.')[col('.') - 1] == a:char - "" Same character on the rigth, jump it. - ""return "\" - "else - "" Insert character. - "return a:char - "endif - let line = getline('.') - let col = col('.')-2 - if line[col+1] == a:char - call setline('.',line[:(col)].line[(col+2):]) - endif - return a:char -endfunction "}}}1 - -function! s:ResetMappings() "{{{1 - for delim in s:right_delims + s:left_delims + s:quotes - silent! exec 'iunmap ' . delim - silent! exec 'vunmap ' . s:visual_leader . delim - endfor - silent! iunmap - silent! iunmap -endfunction "}}}1 - -function! s:MapMsg(msg) "{{{1 +function! s:MapMsg(msg) "{{{ redraw echomsg a:msg return "" -endfunction "}}}1 +endfunction "}}} +"}}} +" Mappings: {{{ function! s:NoAutoClose() "{{{ " inoremap ) =SkipDelim('\)') - for delim in s:right_delims + s:quotes + for delim in b:delimitMate_right_delims + b:delimitMate_quotes exec 'inoremap ' . delim . ' =SkipDelim("' . escape(delim,'"') . '")' endfor endfunction "}}} @@ -341,28 +362,26 @@ endfunction "}}} function! s:AutoClose() "{{{ " Add matching pair and jump to the midle: " inoremap ( () - let s:i = 0 - while s:i < len(s:matchpairs) - "exec 'inoremap ' . s:left_delims[s:i] . ' ' . s:left_delims[s:i] . s:right_delims[s:i] . '' - exec 'inoremap ' . s:left_delims[s:i] . ' ' . s:left_delims[s:i] . '=JumpIn("' . s:right_delims[s:i] . '")' - let s:i += 1 + let i = 0 + while i < len(b:delimitMate_matchpairs) + exec 'inoremap ' . b:delimitMate_left_delims[i] . ' ' . b:delimitMate_left_delims[i] . '=JumpIn("' . b:delimitMate_right_delims[i] . '")' + let i += 1 endwhile " Add matching quote and jump to the midle, or exit if inside a pair of matching quotes: " inoremap " =QuoteDelim("\"") - for delim in s:quotes + for delim in b:delimitMate_quotes exec 'inoremap ' . delim . ' =QuoteDelim("\' . delim . '")' endfor " Exit from inside the matching pair: - " inoremap ) =ClosePair(')') - for delim in s:right_delims + for delim in b:delimitMate_right_delims exec 'inoremap ' . delim . ' =JumpOut("\' . delim . '")' endfor " Try to fix the use of apostrophes (de-activated by default): " inoremap n't n't - for map in s:apostrophes + for map in b:delimitMate_apostrophes exec "inoremap " . map . " " . map endfor @@ -370,46 +389,25 @@ endfunction "}}} function! s:VisualMaps() " {{{ " Wrap the selection with matching pairs, but do nothing if blockwise visual mode is active: - let s:i = 0 - while s:i < len(s:matchpairs) + let i = 0 + while i < len(b:delimitMate_matchpairs) " Map left delimiter: " vnoremap \( IsBlockVisual() ? MapMsg("Message") : "s(\\")\:call RestoreRegister()" - exec 'vnoremap ' . s:visual_leader . s:left_delims[s:i] . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . s:left_delims[s:i] . '\\"' . s:right_delims[s:i] . '\:call RestoreRegister()"' + exec 'vnoremap ' . b:delimitMate_visual_leader . b:delimitMate_left_delims[i] . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . b:delimitMate_left_delims[i] . '\\"' . b:delimitMate_right_delims[i] . '\:call RestoreRegister()"' " Map right delimiter: " vnoremap \) IsBlockVisual() ? MapMsg("Message") : "s(\\")\:call RestoreRegister()" - exec 'vnoremap ' . s:visual_leader . s:right_delims[s:i] . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . s:left_delims[s:i] . '\\"' . s:right_delims[s:i] . '\:call RestoreRegister()"' - let s:i += 1 + exec 'vnoremap ' . b:delimitMate_visual_leader . b:delimitMate_right_delims[i] . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . b:delimitMate_left_delims[i] . '\\"' . b:delimitMate_right_delims[i] . '\:call RestoreRegister()"' + let i += 1 endwhile " Wrap the selection with matching quotes, but do nothing if blockwise visual mode is active: - for quote in s:quotes + for quote in b:delimitMate_quotes " vnoremap \' IsBlockVisual() ? MapMsg("Message") : "s'\\"'\:call RestoreRegister()" - exec 'vnoremap ' . s:visual_leader . quote . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . escape(quote,'"') .'\\"' . escape(quote,'"') . '\:call RestoreRegister()"' + exec 'vnoremap ' . b:delimitMate_visual_leader . quote . ' IsBlockVisual() ? MapMsg("' . s:VMapMsg . '") : "s' . escape(quote,'"') .'\\"' . escape(quote,'"') . '\:call RestoreRegister()"' endfor endfunction "}}} -function! s:IsBlockVisual() " {{{ - if visualmode() == "" - return 1 - endif - " Store unnamed register values for later use in s:RestoreRegister(). - let s:save_reg = getreg('"') - let s:save_reg_mode = getregtype('"') - - if len(getline('.')) == 0 - " This for proper wrap of empty lines. - let @" = "\n" - endif - return 0 -endfunction " }}} - -function! s:RestoreRegister() " {{{ - " Restore unnamed register values store in s:IsBlockVisual(). - call setreg('"', s:save_reg, s:save_reg_mode) - echo "" -endfunction " }}} - function! s:ExpandReturn() "{{{ if DelimitMate_WithinEmptyPair() " Expand: @@ -428,9 +426,9 @@ function! s:ExpandSpace() "{{{ " Don't return "\" endif -endfunction "}}}1 +endfunction "}}} -function! s:ExtraMappings() "{{{1 +function! s:ExtraMappings() "{{{ " If pair is empty, delete both delimiters: inoremap DelimitMate_WithinEmptyPair() ? "\\\" : "\" @@ -438,65 +436,69 @@ function! s:ExtraMappings() "{{{1 inoremap DelimitMate_WithinEmptyPair() ? "\" : "\" " Expand return if inside an empty pair: - if s:expand_cr != 0 + if b:delimitMate_expand_cr != 0 inoremap =ExpandReturn() endif " Expand space if inside an empty pair: - if s:expand_space != 0 + if b:delimitMate_expand_space != 0 inoremap =ExpandSpace() endif " Jump out ot any empty pair: - if s:tab2exit + if b:delimitMate_tab2exit inoremap DelimitMate_ShouldJump() ? "\" : "\" endif -endfunction "}}}1 +endfunction "}}} +"}}} -function! s:TestMappings() "{{{1 - if s:autoclose +" Tools: {{{ +function! s:TestMappings() "{{{ + if b:delimitMate_autoclose exec "normal i* AUTOCLOSE:\" - for i in range(len(s:left_delims)) - exec "normal GGAOpen & close: " . s:left_delims[i]. "|" - exec "normal A\Delete: " . s:left_delims[i] . "\|" - exec "normal A\Exit: " . s:left_delims[i] . s:right_delims[i] . "|" - exec "normal A\Space: " . s:left_delims[i] . " |" - exec "normal GGA\Visual-L: v\v" . s:visual_leader . s:left_delims[i] - exec "normal A\Visual-R: v\v" . s:visual_leader . s:right_delims[i] - exec "normal A\Car return: " . s:left_delims[i] . "\|\GGA\\" + for i in range(len(b:delimitMate_left_delims)) + exec "normal GGAOpen & close: " . b:delimitMate_left_delims[i]. "|" + exec "normal A\Delete: " . b:delimitMate_left_delims[i] . "\|" + exec "normal A\Exit: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . "|" + exec "normal A\Space: " . b:delimitMate_left_delims[i] . " |" + exec "normal GGA\Visual-L: v\v" . b:delimitMate_visual_leader . b:delimitMate_left_delims[i] + exec "normal A\Visual-R: v\v" . b:delimitMate_visual_leader . b:delimitMate_right_delims[i] + exec "normal A\Car return: " . b:delimitMate_left_delims[i] . "\|\GGA\\" endfor - for i in range(len(s:quotes)) - exec "normal GGAOpen & close: " . s:quotes[i] . "|" - exec "normal A\Delete: " . s:quotes[i] . "\|" - exec "normal A\Exit: " . s:quotes[i] . s:quotes[i] . "|" - exec "normal A\Space: " . s:quotes[i] . " |" - exec "normal GGA\Visual: v\v" . s:visual_leader . s:quotes[i] - exec "normal A\Car return: " . s:quotes[i] . "\|\GGA\\" + for i in range(len(b:delimitMate_quotes)) + exec "normal GGAOpen & close: " . b:delimitMate_quotes[i] . "|" + exec "normal A\Delete: " + exec "normal A". b:delimitMate_quotes[i] + exec "normal a\|" + exec "normal A\Exit: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . "|" + exec "normal A\Space: " . b:delimitMate_quotes[i] . " |" + exec "normal GGA\Visual: v\v" . b:delimitMate_visual_leader . b:delimitMate_quotes[i] + exec "normal A\Car return: " . b:delimitMate_quotes[i] . "\|\GGA\\" endfor else exec "normal i* NO AUTOCLOSE:\" - for i in range(len(s:left_delims)) - exec "normal GGAOpen & close: " . s:left_delims[i] . s:right_delims[i] . "|" - exec "normal A\Delete: " . s:left_delims[i] . s:right_delims[i] . "\|" - exec "normal A\Exit: " . s:left_delims[i] . s:right_delims[i] . s:right_delims[i] . "|" - exec "normal A\Space: " . s:left_delims[i] . s:right_delims[i] . " |" - exec "normal GGA\Visual-L: v\v" . s:visual_leader . s:left_delims[i] - exec "normal A\Visual-R: v\v" . s:visual_leader . s:right_delims[i] - exec "normal A\Car return: " . s:left_delims[i] . s:right_delims[i] . "\|\GGA\\" + for i in range(len(b:delimitMate_left_delims)) + exec "normal GGAOpen & close: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . "|" + exec "normal A\Delete: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . "\|" + exec "normal A\Exit: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . b:delimitMate_right_delims[i] . "|" + exec "normal A\Space: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . " |" + exec "normal GGA\Visual-L: v\v" . b:delimitMate_visual_leader . b:delimitMate_left_delims[i] + exec "normal A\Visual-R: v\v" . b:delimitMate_visual_leader . b:delimitMate_right_delims[i] + exec "normal A\Car return: " . b:delimitMate_left_delims[i] . b:delimitMate_right_delims[i] . "\|\GGA\\" endfor - for i in range(len(s:quotes)) - exec "normal GGAOpen & close: " . s:quotes[i] . s:quotes[i] . "|" - exec "normal A\Delete: " . s:quotes[i] . s:quotes[i] . "\|" - exec "normal A\Exit: " . s:quotes[i] . s:quotes[i] . s:quotes[i] . "|" - exec "normal A\Space: " . s:quotes[i] . s:quotes[i] . " |" - exec "normal GGA\Visual: v\v" . s:visual_leader . s:quotes[i] - exec "normal A\Car return: " . s:quotes[i] . s:quotes[i] . "\|\GGA\\" + for i in range(len(b:delimitMate_quotes)) + exec "normal GGAOpen & close: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . "|" + exec "normal A\Delete: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . "\|" + exec "normal A\Exit: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . "|" + exec "normal A\Space: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . " |" + exec "normal GGA\Visual: v\v" . b:delimitMate_visual_leader . b:delimitMate_quotes[i] + exec "normal A\Car return: " . b:delimitMate_quotes[i] . b:delimitMate_quotes[i] . "\|\GGA\\" endfor endif exec "normal \i" -endfunction "}}}1 +endfunction "}}} -function! s:SwitchAutoclose() "{{{1 +function! s:SwitchAutoclose() "{{{ if !exists("g:delimitMate_autoclose") let g:delimitMate_autoclose = 1 elseif g:delimitMate_autoclose == 1 @@ -505,69 +507,78 @@ function! s:SwitchAutoclose() "{{{1 let g:delimitMate_autoclose = 1 endif DelimitMateReload -endfunction "}}}1 +endfunction "}}} function! s:UnMap() " {{{ " No Autoclose Mappings: - for char in s:right_delims + s:quotes - if maparg(' '.char,"i") =~? 'SkipDelim' - exec 'iunmap ' . char + for char in b:delimitMate_right_delims + b:delimitMate_quotes + if maparg(char,"i") =~? 'SkipDelim' + exec 'silent! iunmap ' . char "echomsg 'iunmap ' . char endif endfor " Autoclose Mappings: - let s:i = 0 - while s:i < len(s:matchpairs) - if maparg(' '.s:left_delims[s:i],"i") =~? s:left_delims[s:i] . s:right_delims[s:i] . '' - exec 'iunmap ' . s:left_delims[s:i] - "echomsg 'iunmap ' . s:left_delims[s:i] + let i = 0 + let l = len(b:delimitMate_matchpairs) + while i < l + if maparg(b:delimitMate_left_delims[i],"i") =~? 'JumpIn' + exec 'silent! iunmap ' . b:delimitMate_left_delims[i] + "echomsg 'iunmap ' . b:delimitMate_left_delims[i] endif - let s:i += 1 + let i += 1 endwhile - for char in s:quotes + for char in b:delimitMate_quotes if maparg(char, "i") =~? 'QuoteDelim' - exec 'iunmap ' . char + exec 'silent! iunmap ' . char "echomsg 'iunmap ' . char endif endfor - for char in s:right_delims - if maparg(char, "i") =~? 'ClosePair' - exec 'iunmap ' . char + for char in b:delimitMate_right_delims + if maparg(char, "i") =~? 'JumpOut' + exec 'silent! iunmap ' . char "echomsg 'iunmap ' . char endif endfor - for map in s:apostrophes + for map in b:delimitMate_apostrophes exec "silent! iunmap " . map endfor " Visual Mappings: - for char in s:right_delims + s:left_delims + s:quotes - if maparg(s:visual_leader . char,"v") =~? 'IsBlock' - exec 'vunmap ' . s:visual_leader . char - "echomsg 'vunmap ' . s:visual_leader . char + for char in b:delimitMate_right_delims + b:delimitMate_left_delims + b:delimitMate_quotes + if maparg(b:delimitMate_visual_leader . char,"v") =~? 'IsBlock' + exec 'silent! vunmap ' . b:delimitMate_visual_leader . char + "echomsg 'vunmap ' . b:delimitMate_visual_leader . char endif endfor " Expansion Mappings: if maparg('', "i") =~? 'WithinEmptyPair' - iunmap - "echomsg "iunmap " + silent! iunmap + "echomsg "silent! iunmap " + endif + if maparg('', "i") =~? 'WithinEmptyPair' + silent! iunmap + "echomsg "silent! iunmap " endif if maparg('',"i") =~? 'ExpandReturn' - iunmap - "echomsg "iunmap " + silent! iunmap + "echomsg "silent! iunmap " endif if maparg('',"i") =~? 'ExpandSpace' - iunmap - "echomsg "iunmap " + silent! iunmap + "echomsg "silent! iunmap " endif + if maparg('', "i") =~? 'ShouldJump' + silent! iunmap + "echomsg "silent! iunmap " + endif +endfunction " }}} s:ExtraMappings() -endfunction " }}} - -function! s:TestMappingsDo() "{{{1 +function! s:TestMappingsDo() "{{{ + "DelimitMateReload if !exists("g:delimitMate_testing") - call s:DelimitMateDo() + "call s:DelimitMateDo() call s:TestMappings() else call s:SwitchAutoclose() @@ -576,18 +587,18 @@ function! s:TestMappingsDo() "{{{1 call s:SwitchAutoclose() call s:TestMappings() endif -endfunction "}}}1 +endfunction "}}} -function! s:DelimitMateDo() "{{{1 +function! s:DelimitMateDo() "{{{ if exists("g:delimitMate_excluded_ft") " Check if this file type is excluded: for ft in split(g:delimitMate_excluded_ft,',') if ft ==? &filetype - if !exists("s:quotes") + if !exists("b:delimitMate_quotes") return 1 endif "echomsg "excluded" - "call s:UnMap() + call s:UnMap() return 1 endif endfor @@ -600,9 +611,10 @@ function! s:DelimitMateDo() "{{{1 finally let &cpo = save_cpo endtry -endfunction "}}}1 +endfunction "}}} +"}}} -" Set some commands: {{{1 +" Commands: {{{ call s:DelimitMateDo() " Let me refresh without re-loading the buffer: @@ -619,6 +631,7 @@ autocmd FileType * call DelimitMateDo() autocmd BufNewFile,BufRead,BufEnter * if !exists("b:loaded_delimitMate") | call DelimitMateDo() | endif "function! s:GetSynRegion () | echo synIDattr(synIDtrans(synID(line('.'), col('.'), 1)), 'name') | endfunction +"}}} " GetLatestVimScripts: 2754 1 :AutoInstall: delimitMate.vim -" vim:foldmethod=marker:foldcolumn=2 +" vim:foldmethod=marker:foldcolumn=4