1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
|
" https://github.com/mipmip/vim-scimark/blob/master/plugin/scimark.vim
"
function! InitVariable(var, value)
if !exists(a:var)
exec 'let ' . a:var . ' = ' . "'" . a:value . "'"
return 1
endif
return 0
endfunction
call InitVariable("g:scimCommand", "sc-im")
function! OpenInScim()
let lineundercursor=getline('.')
let curlinenumber = line('.')
if lineundercursor=~?'|.*|$'
while lineundercursor=~?'|.*|$'
let curlinenumber = curlinenumber -1
let lineundercursor=getline(curlinenumber)
endwhile
let lineundercursor=getline(curlinenumber+1)
let g:scimarkTableTopLine = curlinenumber+1
let fileLines = []
while lineundercursor=~?'|.*|$'
let curlinenumber = curlinenumber + 1
let lineundercursor = getline(curlinenumber)
call add(fileLines, lineundercursor)
endwhile
let g:scimarkTempFile = tempname() . '.md'
let g:scimarkOpenerBuffer = bufnr("%")
let g:scimarkOpenerFile = expand("%")
let g:scimarkTableBottonLine = curlinenumber-1
let g:scimarkOpenerWindow = winnr()
if writefile(fileLines, g:scimarkTempFile)
echomsg 'write error'
else
if has('nvim')
exe 'split(:sp)'
call termopen(g:scimCommand . ' ' . g:scimarkTempFile, { 'on_exit': 'g:ReadFromScimNeoVim', 'on_stdout': 'NeoVimStartInsert'})
else
call term_start(g:scimCommand . ' ' . g:scimarkTempFile, { 'exit_cb': function('g:ReadFromScimVim')})
endif
endif
endif
endfunction
function! g:ReadFromScimVim(job,exit_code)
call g:ReadFromScim()
endfunction
function! g:NeoVimStartInsert(job,data,event)
exe 'startinsert'
endfunction
function! g:ReadFromScimNeoVim(job,data,event)
call g:ReadFromScim()
endfunction
function! g:ReadFromScim()
exe g:scimarkOpenerWindow . "wincmd w | wincmd c"
exe 'buffer! '. g:scimarkOpenerBuffer
exe g:scimarkTableTopLine.','.g:scimarkTableBottonLine.'d'
call cursor(g:scimarkTableTopLine-1,0)
exe 'r '.g:scimarkTempFile
endfunction
command! OpenInScim :call OpenInScim()
nmap <leader>sc :OpenInScim<CR>
|