Compare commits

...

6 Commits

Author SHA1 Message Date
Dhruva Sagar
60ab92cd35 Updated doc & README.md 2013-03-21 13:37:30 +05:30
Dhruva Sagar
503271fca5 Fixed #4 2013-03-21 13:35:16 +05:30
Dhruva Sagar
b789e2c86f Fixed #3 2013-03-21 12:41:02 +05:30
Dhruva Sagar
7b89b6b50d Insert mode mapping is for current buffer only #2 2013-03-21 12:16:27 +05:30
Dhruva Sagar
28dc1626ab Merge branch 'master' of github.com:dhruvasagar/vim-table-mode 2013-03-21 08:47:53 +05:30
Dhruva Sagar
da871cac51 Releasing v2.1.1
- Moved some code around for better readability.
- Added new option g:table_mode_align for allowing the user to set the
  format option for aligning the text, this is passed directly to
  Tabular.
- Updated vim doc.
- Updated README.md
2013-03-21 08:44:26 +05:30
4 changed files with 51 additions and 43 deletions

View File

@@ -4,6 +4,9 @@ An awesome automatic table creator & formatter allowing one to create neat
tables as you type. tables as you type.
## Change Log ## Change Log
### Version 2.1.2 :
* Bug Fixes #2, #3 & #4
### Version 2.1.1 : ### Version 2.1.1 :
* Added option g:table_mode_align to allow setting Tabular format option for * Added option g:table_mode_align to allow setting Tabular format option for
more control on how Tabular aligns text. more control on how Tabular aligns text.

View File

@@ -4,7 +4,7 @@
" Author: Dhruva Sagar <http://dhruvasagar.com/> " Author: Dhruva Sagar <http://dhruvasagar.com/>
" License: MIT (http://www.opensource.org/licenses/MIT) " License: MIT (http://www.opensource.org/licenses/MIT)
" Website: http://github.com/dhruvasagar/vim-table-mode " Website: http://github.com/dhruvasagar/vim-table-mode
" Version: 2.1.1 " Version: 2.1.2
" Note: This plugin was heavily inspired by the 'CucumberTables.vim' " Note: This plugin was heavily inspired by the 'CucumberTables.vim'
" (https://gist.github.com/tpope/287147) plugin by Tim Pope and " (https://gist.github.com/tpope/287147) plugin by Tim Pope and
" uses a small amount of code from it. " uses a small amount of code from it.
@@ -45,7 +45,7 @@ call s:SetGlobalOptDefault('table_mode_border', 1)
call s:SetGlobalOptDefault('table_mode_corner', '+') call s:SetGlobalOptDefault('table_mode_corner', '+')
call s:SetGlobalOptDefault('table_mode_separator', '|') call s:SetGlobalOptDefault('table_mode_separator', '|')
call s:SetGlobalOptDefault('table_mode_fillchar', '-') call s:SetGlobalOptDefault('table_mode_fillchar', '-')
call s:SetGlobalOptDefault('table_mode_toggle_map', '<Leader>tm') call s:SetGlobalOptDefault('table_mode_toggle_map', '<LocalLeader>tm')
call s:SetGlobalOptDefault('table_mode_always_active', 0) call s:SetGlobalOptDefault('table_mode_always_active', 0)
call s:SetGlobalOptDefault('table_mode_delimiter', ',') call s:SetGlobalOptDefault('table_mode_delimiter', ',')
call s:SetGlobalOptDefault('table_mode_tableize_map', '<Leader>T') call s:SetGlobalOptDefault('table_mode_tableize_map', '<Leader>T')
@@ -59,12 +59,20 @@ if !g:table_mode_always_active
command! -nargs=0 TableModeToggle call tablemode#TableModeToggle() command! -nargs=0 TableModeToggle call tablemode#TableModeToggle()
command! -nargs=0 TableModeEnable call tablemode#TableModeEnable() command! -nargs=0 TableModeEnable call tablemode#TableModeEnable()
command! -nargs=0 TableModeDisable call tablemode#TableModeDisable() command! -nargs=0 TableModeDisable call tablemode#TableModeDisable()
else
let table_mode_separator_map = g:table_mode_separator
" '|' is a special character, we need to map <Bar> instead
if g:table_mode_separator ==# '|' | let table_mode_separator_map = '<Bar>' | endif
execute "inoremap <silent> " . table_mode_separator_map . ' ' .
\ table_mode_separator_map . "<Esc>:call tablemode#TableizeInsertMode()<CR>a"
unlet table_mode_separator_map
endif endif
command! -nargs=0 -range Tableize <line1>,<line2>call tablemode#TableizeRange() command! -nargs=0 -range Tableize <line1>,<line2>call tablemode#TableizeRange()
exec "xnoremap <silent> " . g:table_mode_tableize_map . " :Tableize<CR>" execute "xnoremap <silent> " . g:table_mode_tableize_map . " :Tableize<CR>"
exec "nnoremap <silent> " . g:table_mode_tableize_map . " :Tableize<CR>" execute "nnoremap <silent> " . g:table_mode_tableize_map . " :Tableize<CR>"
"}}}1 "}}}1
" ModeLine {{{ " ModeLine {{{
" vim:fdm=marker " vim:fdl=0 fdm=marker

View File

@@ -4,7 +4,7 @@
" Author: Dhruva Sagar <http://dhruvasagar.com/> " Author: Dhruva Sagar <http://dhruvasagar.com/>
" License: MIT (http://www.opensource.org/licenses/MIT) " License: MIT (http://www.opensource.org/licenses/MIT)
" Website: http://github.com/dhruvasagar/vim-table-mode " Website: http://github.com/dhruvasagar/vim-table-mode
" Version: 2.1.1 " Version: 2.1.2
" Note: This plugin was heavily inspired by the 'CucumberTables.vim' " Note: This plugin was heavily inspired by the 'CucumberTables.vim'
" (https://gist.github.com/tpope/287147) plugin by Tim Pope and " (https://gist.github.com/tpope/287147) plugin by Tim Pope and
" uses a small amount of code from it. " uses a small amount of code from it.
@@ -40,12 +40,6 @@ function! s:CountSeparator(line, separator) "{{{2
endfunction endfunction
" }}}2 " }}}2
function! s:ConvertDelimiterToSeparator(line) "{{{2
execute 'silent! ' . a:line . 's/^\s*\zs\ze.\|' . g:table_mode_delimiter .
\ '\|$/' . g:table_mode_separator . '/g'
endfunction
" }}}2
function! s:IsTableModeActive() "{{{2 function! s:IsTableModeActive() "{{{2
if g:table_mode_always_active | return 1 | endif if g:table_mode_always_active | return 1 | endif
@@ -54,21 +48,16 @@ function! s:IsTableModeActive() "{{{2
endfunction endfunction
" }}}2 " }}}2
function! s:TableModeSeparatorMap() "{{{2
if g:table_mode_separator ==# '|'
return '<Bar>'
else
return g:table_mode_separator
endif
endfunction
" }}}2
function! s:ToggleMapping() "{{{2 function! s:ToggleMapping() "{{{2
if exists('b:table_mode_active') && b:table_mode_active if exists('b:table_mode_active') && b:table_mode_active
execute "inoremap <silent> " . s:TableModeSeparatorMap() . ' ' . call s:SetBufferOptDefault('table_mode_separator_map', g:table_mode_separator)
\ s:TableModeSeparatorMap() . "<Esc>:call <SID>Tableize()<CR>a" " '|' is a special character, we need to map <Bar> instead
if g:table_mode_separator ==# '|' | let b:table_mode_separator_map = '<Bar>' | endif
execute "inoremap <silent> <buffer> " . b:table_mode_separator_map . ' ' .
\ b:table_mode_separator_map . "<Esc>:call tablemode#TableizeInsertMode()<CR>a"
else else
execute "iunmap <silent> " . s:TableModeSeparatorMap() execute "iunmap <silent> <buffer> " . b:table_mode_separator_map
endif endif
endfunction endfunction
" }}}2 " }}}2
@@ -92,7 +81,7 @@ function! s:UpdateLineBorder(line) "{{{2
endif endif
else else
call append(cline-1, repeat(g:table_mode_corner, curr_line_count)) call append(cline-1, repeat(g:table_mode_corner, curr_line_count))
let cline = a:line + 1 let cline = a:line + 1 " because of the append, the current line moved down
endif endif
if getline(cline+1) =~# hf if getline(cline+1) =~# hf
@@ -116,7 +105,24 @@ function! s:FillTableBorder() "{{{2
endfunction endfunction
" }}}2 " }}}2
function! s:Tableize() "{{{2 function! s:ConvertDelimiterToSeparator(line) "{{{2
execute 'silent! ' . a:line . 's/^\s*\zs\ze.\|' . g:table_mode_delimiter .
\ '\|$/' . g:table_mode_separator . '/g'
endfunction
" }}}2
function! s:Tableizeline(line) "{{{2
call s:ConvertDelimiterToSeparator(a:line)
if g:table_mode_border | call s:UpdateLineBorder(a:line) | endif
execute 'Tabularize/[' . g:table_mode_separator . g:table_mode_corner . ']/' . g:table_mode_align
endfunction
" }}}2
" }}}1
" Public API {{{1
function! tablemode#TableizeInsertMode() "{{{2
if s:IsTableModeActive() && getline('.') =~# ('^\s*' . g:table_mode_separator) if s:IsTableModeActive() && getline('.') =~# ('^\s*' . g:table_mode_separator)
let column = s:Strlen(substitute(getline('.')[0:col('.')], '[^' . g:table_mode_separator . ']', '', 'g')) let column = s:Strlen(substitute(getline('.')[0:col('.')], '[^' . g:table_mode_separator . ']', '', 'g'))
let position = s:Strlen(matchstr(getline('.')[0:col('.')], '.*' . g:table_mode_separator . '\s*\zs.*')) let position = s:Strlen(matchstr(getline('.')[0:col('.')], '.*' . g:table_mode_separator . '\s*\zs.*'))
@@ -129,17 +135,6 @@ function! s:Tableize() "{{{2
endfunction endfunction
" }}}2 " }}}2
function! s:Tableizeline(line) "{{{2
call s:ConvertDelimiterToSeparator(a:line)
call s:UpdateLineBorder(a:line)
execute 'Tabularize/[' . g:table_mode_separator . g:table_mode_corner . ']/' . g:table_mode_align
endfunction
" }}}2
" }}}1
" Public API {{{1
function! tablemode#TableModeEnable() "{{{2 function! tablemode#TableModeEnable() "{{{2
call s:SetActive(1) call s:SetActive(1)
endfunction endfunction
@@ -161,17 +156,19 @@ endfunction
" }}}2 " }}}2
function! tablemode#TableizeRange() range "{{{2 function! tablemode#TableizeRange() range "{{{2
let shift = 1
if g:table_mode_border | let shift = shift + 1 | endif
call s:Tableizeline(a:firstline) call s:Tableizeline(a:firstline)
undojoin undojoin
" The first one causes 2 extra lines for top & bottom border while the " The first one causes 2 extra lines for top & bottom border while the
" following lines cause only 1 for the bottom border. " following lines cause only 1 for the bottom border.
let lnum = a:firstline+3 let lnum = a:firstline + shift + (g:table_mode_border > 0)
while lnum <= (a:firstline + (a:lastline - a:firstline+1)*2) while lnum < (a:firstline + (a:lastline - a:firstline + 1)*shift)
call s:Tableizeline(lnum) call s:Tableizeline(lnum)
undojoin undojoin
let lnum = lnum + 2 let lnum = lnum + shift
endwhile endwhile
call s:FillTableBorder() if g:table_mode_border | call s:FillTableBorder() | endif
endfunction endfunction
" }}}2 " }}}2

View File

@@ -1,7 +1,7 @@
*table-mode.txt* Table Mode for easy table formatting. v2.1 *table-mode.txt* Table Mode for easy table formatting. v2.1.2
=============================================================================== ===============================================================================
Table Mode, THE AWESOME AUTOMATIC TABLE CREATOR & FORMATTER Table Mode, THE AWESOME AUTOMATIC TABLE CREATOR & FORMATTER
VERSION 2.1 VERSION 2.1.2
Author: Dhruva Sagar <http://dhruvasagar.com/> Author: Dhruva Sagar <http://dhruvasagar.com/>
License: MIT <http://opensource.org/licenses/MIT/> License: MIT <http://opensource.org/licenses/MIT/>