mirror of
https://github.com/dhruvasagar/vim-table-mode.git
synced 2025-11-08 11:03:47 -05:00
Add support for inserting columns #130
Two mappings are introduced to enable usage of this feature like vim's pasting with p and P.
This commit is contained in:
@@ -40,6 +40,8 @@ function! s:ToggleMapping() "{{{2
|
||||
call s:Map('<Plug>(table-mode-realign)', g:table_mode_realign_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-delete-row)', g:table_mode_delete_row_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-delete-column)', g:table_mode_delete_column_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-insert-column-before)', g:table_mode_insert_column_before_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-insert-column-after)', g:table_mode_insert_column_after_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-add-formula)', g:table_mode_add_formula_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-eval-formula)', g:table_mode_eval_formula_map, 'n')
|
||||
call s:Map('<Plug>(table-mode-echo-cell)', g:table_mode_echo_cell_map, 'n')
|
||||
@@ -57,6 +59,8 @@ function! s:ToggleMapping() "{{{2
|
||||
call s:UnMap(g:table_mode_realign_map, 'n')
|
||||
call s:UnMap(g:table_mode_delete_row_map, 'n')
|
||||
call s:UnMap(g:table_mode_delete_column_map, 'n')
|
||||
call s:UnMap(g:table_mode_insert_column_before_map, 'n')
|
||||
call s:UnMap(g:table_mode_insert_column_after_map, 'n')
|
||||
call s:UnMap(g:table_mode_add_formula_map, 'n')
|
||||
call s:UnMap(g:table_mode_eval_formula_map, 'n')
|
||||
call s:UnMap(g:table_mode_echo_cell_map, 'n')
|
||||
|
||||
@@ -187,6 +187,57 @@ function! tablemode#spreadsheet#DeleteRow() "{{{2
|
||||
endif
|
||||
endfunction
|
||||
|
||||
function! tablemode#spreadsheet#InsertColumn(after) "{{{2
|
||||
if tablemode#table#IsRow('.')
|
||||
let quantity = v:count1
|
||||
|
||||
call tablemode#spreadsheet#MoveToFirstRowOrHeader()
|
||||
call tablemode#spreadsheet#MoveToStartOfCell()
|
||||
if a:after
|
||||
execute "normal! f".g:table_mode_separator
|
||||
endif
|
||||
execute "normal! h\<C-V>"
|
||||
call tablemode#spreadsheet#MoveToLastRow()
|
||||
normal! y
|
||||
|
||||
let corner = tablemode#utils#get_buffer_or_global_option('table_mode_corner')
|
||||
if a:after
|
||||
let cell_line = g:table_mode_separator.' '
|
||||
let header_line = corner.g:table_mode_fillchar.g:table_mode_fillchar
|
||||
else
|
||||
let cell_line = ' '.g:table_mode_separator
|
||||
let header_line = g:table_mode_fillchar.g:table_mode_fillchar.corner
|
||||
endif
|
||||
let cell_line = escape(cell_line, '\&')
|
||||
let header_line = escape(header_line, '\&')
|
||||
|
||||
" This transforms the character column before or after the column separator
|
||||
" into a new column with separator.
|
||||
" This requires, that
|
||||
" g:table_mode_separator != g:table_mode_fillchar
|
||||
" && g:table_mode_separator != g:table_mode_header_fillchar
|
||||
" && g:table_mode_separator != g:table_mode_align_char
|
||||
call setreg(
|
||||
\ '"',
|
||||
\ substitute(
|
||||
\ substitute(@", ' ', cell_line, 'g'),
|
||||
\ '\V\C'.escape(g:table_mode_fillchar, '\')
|
||||
\ .'\|'.escape(g:table_mode_header_fillchar, '\')
|
||||
\ .'\|'.escape(g:table_mode_align_char, '\'),
|
||||
\ header_line,
|
||||
\ 'g'),
|
||||
\ 'b')
|
||||
|
||||
if a:after
|
||||
execute "normal! ".quantity."p2l"
|
||||
else
|
||||
execute "normal! ".quantity."Pl"
|
||||
endif
|
||||
|
||||
call tablemode#table#Realign('.')
|
||||
endif
|
||||
endfunction
|
||||
|
||||
function! tablemode#spreadsheet#Sum(range, ...) abort "{{{2
|
||||
let args = copy(a:000)
|
||||
call insert(args, a:range)
|
||||
|
||||
Reference in New Issue
Block a user