diff --git a/after/plugin/table-mode.vim b/after/plugin/table-mode.vim
index ff0dad1..5cc1735 100644
--- a/after/plugin/table-mode.vim
+++ b/after/plugin/table-mode.vim
@@ -4,7 +4,7 @@
" Author: Dhruva Sagar
" License: MIT (http://www.opensource.org/licenses/MIT)
" Website: http://github.com/dhruvasagar/vim-table-mode
-" Version: 2.2.2
+" Version: 2.3.0
" Note: This plugin was heavily inspired by the 'CucumberTables.vim'
" (https://gist.github.com/tpope/287147) plugin by Tim Pope and
" uses a small amount of code from it.
@@ -56,7 +56,6 @@ call s:SetGlobalOptDefault('table_mode_delimiter', ',')
call s:SetGlobalOptDefault('table_mode_tableize_map', 'tt')
call s:SetGlobalOptDefault('table_mode_tableize_op_map', 'T')
call s:SetGlobalOptDefault('table_mode_align', 'l1')
-call s:SetGlobalOptDefault('table_mode_no_border_padding', '0')
call s:SetGlobalOptDefault('table_mode_realign_map', 'tr')
call s:SetGlobalOptDefault('table_mode_motion_prefix', 't')
"}}}1
@@ -91,7 +90,7 @@ execute "xnoremap " . g:table_mode_tableize_map . " :Tableize"
execute "nnoremap " . g:table_mode_tableize_map . " :Tableize"
execute "xnoremap " . g:table_mode_tableize_op_map . " :call tablemode#TableizeByDelimiter()"
-execute "nnoremap " . g:table_mode_realign_map . " :call tablemode#TableRealign()"
+execute "nnoremap " . g:table_mode_realign_map . " :call tablemode#TableRealign('.')"
execute "nnoremap " . g:table_mode_motion_prefix . " :call TableMotion()"
"}}}1
diff --git a/autoload/tablemode.vim b/autoload/tablemode.vim
index e9b57c7..2f0d5c5 100644
--- a/autoload/tablemode.vim
+++ b/autoload/tablemode.vim
@@ -4,7 +4,7 @@
" Author: Dhruva Sagar
" License: MIT (http://www.opensource.org/licenses/MIT)
" Website: http://github.com/dhruvasagar/vim-table-mode
-" Version: 2.2.2
+" Version: 2.3.0
" Note: This plugin was heavily inspired by the 'CucumberTables.vim'
" (https://gist.github.com/tpope/287147) plugin by Tim Pope and
" uses a small amount of code from it.
@@ -35,11 +35,6 @@ function! s:Strlen(text)
endfunction
" }}}2
-function! s:CountSeparator(line, separator) "{{{2
- return s:Strlen(substitute(getline(a:line), '[^' . a:separator . ']', '', 'g'))
-endfunction
-" }}}2
-
function! s:GetCommentStart() "{{{2
let cstring = &commentstring
if s:Strlen(cstring) > 0
@@ -98,57 +93,53 @@ function! s:SetActive(bool) "{{{2
endfunction
" }}}2
-function! s:UpdateLineBorder(line) "{{{2
- let cline = a:line
- let hf = s:StartExpr() . g:table_mode_corner . '[' . g:table_mode_corner . ' ' .
- \ g:table_mode_fillchar . ']*' . g:table_mode_corner . '\?\s*$'
- let curr_line_count = s:CountSeparator(cline, g:table_mode_separator)
-
- if getline(cline-1) =~# hf
- let prev_line_count = s:CountSeparator(cline-1, g:table_mode_corner)
- if curr_line_count > prev_line_count
- silent! execute 'normal! kA' . repeat(g:table_mode_corner, curr_line_count - prev_line_count) . "\j"
- endif
+function! s:GenerateBorder(line) "{{{2
+ let line = 0
+ if type(a:line) == type('')
+ let line = line(a:line)
else
- let cstartexpr = s:StartCommentExpr()
- if s:Strlen(cstartexpr) > 0 && getline(cline) =~# cstartexpr
- let indent = matchstr(getline(cline), s:StartCommentExpr())
- call append(cline-1, indent . repeat(g:table_mode_corner, curr_line_count))
- else
- call append(cline-1, repeat(g:table_mode_corner, curr_line_count))
- endif
- let cline = a:line + 1 " because of the append, the current line moved down
+ let line = a:line
endif
- if getline(cline+1) =~# hf
- let next_line_count = s:CountSeparator(cline+1, g:table_mode_corner)
- if curr_line_count > next_line_count
- silent! execute 'normal! jA' . repeat(g:table_mode_corner, curr_line_count - next_line_count) . "\k"
- end
+ let border = substitute(getline(line)[stridx(getline(line), g:table_mode_separator):-1], g:table_mode_separator, g:table_mode_corner, 'g')
+ let border = substitute(border, '[^' . g:table_mode_corner . ']', g:table_mode_fillchar, 'g')
+
+ let cstartexpr = s:StartCommentExpr()
+ if s:Strlen(cstartexpr) > 0 && getline(line) =~# cstartexpr
+ let indent = matchstr(getline(line), s:StartCommentExpr())
+ return indent . border
+ elseif getline(line) =~# s:StartExpr()
+ let indent = matchstr(getline(line), s:StartExpr())
+ return indent . border
else
- let cstartexpr = s:StartCommentExpr()
- if s:Strlen(cstartexpr) > 0 && getline(cline) =~# cstartexpr
- let indent = matchstr(getline(cline), s:StartCommentExpr())
- call append(cline, indent . repeat(g:table_mode_corner, curr_line_count))
- else
- call append(cline, repeat(g:table_mode_corner, curr_line_count))
- endif
+ return border
endif
endfunction
" }}}2
-function! s:FillTableBorder() "{{{2
- let [ current_col, current_line ] = [ col('.'), line('.') ]
- if g:table_mode_no_border_padding
- silent! execute '%s/' . g:table_mode_corner . '\zs\([' .
- \ g:table_mode_fillchar . ' ]*\)\ze' . g:table_mode_corner .
- \ '/\=repeat("' . g:table_mode_fillchar . '", s:Strlen(submatch(0)))/g'
+function! s:UpdateLineBorder(line) "{{{2
+ let cline = a:line
+ let hf = s:StartExpr() . g:table_mode_corner . '[' . g:table_mode_corner .
+ \ g:table_mode_fillchar . ']*' . g:table_mode_corner . '\?\s*$'
+
+ let border = s:GenerateBorder(cline)
+
+ let [prev_line, next_line] = [getline(cline-1), getline(cline+1)]
+ if next_line =~# hf
+ if next_line !=# border
+ call setline(cline+1, border)
+ endif
else
- silent! execute '%s/' . g:table_mode_corner . ' \zs\([' .
- \ g:table_mode_fillchar . ' ]*\)\ze ' . g:table_mode_corner .
- \ '/\=repeat("' . g:table_mode_fillchar . '", s:Strlen(submatch(0)))/g'
+ call append(cline, border)
+ endif
+
+ if prev_line =~# hf
+ if prev_line !=# border
+ call setline(cline-1, border)
+ endif
+ else
+ call append(cline-1, border)
endif
- call cursor(current_line, current_col)
endfunction
" }}}2
@@ -171,7 +162,6 @@ function! s:Tableizeline(line, ...) "{{{2
if a:0 && type(a:1) == type('') && !empty(a:1) | let delim = a:1[1:-1] | endif
call s:ConvertDelimiterToSeparator(a:line, delim)
if g:table_mode_border | call s:UpdateLineBorder(a:line) | endif
- call tablemode#TableRealign()
endfunction
" }}}2
@@ -193,8 +183,7 @@ function! tablemode#TableizeInsertMode() "{{{2
if s:IsTableModeActive() && getline('.') =~# (s:StartExpr() . g:table_mode_separator)
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.*'))
- if g:table_mode_border | call s:UpdateLineBorder(line('.')) | endif
- call tablemode#TableRealign()
+ call tablemode#TableRealign('.')
normal! 0
call search(repeat('[^' . g:table_mode_separator . ']*' . g:table_mode_separator, column) . '\s\{-\}' . repeat('.', position), 'ce', line('.'))
endif
@@ -234,7 +223,8 @@ function! tablemode#TableizeRange(...) range "{{{2
undojoin
let lnum = lnum + shift
endwhile
- if g:table_mode_border | call s:FillTableBorder() | endif
+
+ if g:table_mode_border | call tablemode#TableRealign(lnum - shift) | endif
endfunction
" }}}2
@@ -248,10 +238,47 @@ function! tablemode#TableizeByDelimiter() "{{{2
endfunction
" }}}2
-function! tablemode#TableRealign() "{{{2
- if g:table_mode_no_border_padding && g:table_mode_align !=# 'c0' | let g:table_mode_align = 'c0' | endif
- execute 'Tabularize/[' . g:table_mode_separator . g:table_mode_corner . ']/' . g:table_mode_align
- if g:table_mode_border | call s:FillTableBorder() | endif
+function! tablemode#TableRealign(line) "{{{2
+ let line = 0
+ if type(a:line) == type('')
+ let line = line(a:line)
+ else
+ let line = a:line
+ endif
+
+ let rowCount = 1
+ if g:table_mode_border | let rowCount = 2 | endif
+
+ let [lnums, lines] = [[], []]
+ let tline = line
+ while tline > 0
+ if tablemode#IsATableRow(tline)
+ call insert(lnums, tline)
+ call insert(lines, getline(tline))
+ else
+ break
+ endif
+ let tline = tline - rowCount
+ endwhile
+
+ let tline = line + rowCount
+ while tline <= line('$')
+ if tablemode#IsATableRow(tline)
+ call add(lnums, tline)
+ call add(lines, getline(tline))
+ else
+ break
+ endif
+ let tline = tline + rowCount
+ endwhile
+
+ call tabular#TabularizeStrings(lines, g:table_mode_separator)
+
+ for lnum in lnums
+ let index = index(lnums, lnum)
+ call setline(lnum, lines[index])
+ call s:UpdateLineBorder(lnum)
+ endfor
endfunction
" }}}2
@@ -262,7 +289,7 @@ endfunction
function! tablemode#RowCount(line) "{{{2
let line = 0
- if type(line) == type('')
+ if type(a:line) == type('')
let line = line(a:line)
else
let line = a:line
@@ -322,7 +349,7 @@ endfunction
function! tablemode#ColumnCount(line) "{{{2
let line = 0
- if type(line) == type('')
+ if type(a:line) == type('')
let line = line(a:line)
else
let line = a:line
diff --git a/doc/table-mode.txt b/doc/table-mode.txt
index 80a6618..24f8df4 100644
--- a/doc/table-mode.txt
+++ b/doc/table-mode.txt
@@ -1,7 +1,7 @@
-*table-mode.txt* Table Mode for easy table formatting. v2.2.2
+*table-mode.txt* Table Mode for easy table formatting. v2.3.0
===============================================================================
Table Mode, THE AWESOME AUTOMATIC TABLE CREATOR & FORMATTER
- VERSION 2.2.2
+ VERSION 2.3.0
Author: Dhruva Sagar
License: MIT
@@ -44,6 +44,12 @@ The table mode is disabled by default and you can enter table mode using
|table-mode-toggle-map| or you can also enable it permanently using
|g:table-mode-always-active| if you wish.
+Table Mode allows for creation of tables within comments, it looks at the
+'commentstring' setting to identify whether the current line is commented.
+
+Table Mode enables conversion of delimited text into tables. Again like table
+creation, this is also applicable within comments.
+
===============================================================================
OPTIONS *table-mode-options*
@@ -180,6 +186,9 @@ MAPPINGS *table-mode-mappings*
*table-mode-mappings-realign*
tr Realigns table columns
+
+ *table-mode-mappings-motions*
+t[hjkl] Move to previous | below | above | right cell in the table.
===============================================================================
COMMANDS *table-mode-commands*