summaryrefslogtreecommitdiff
path: root/.config/vim/ftplugin
diff options
context:
space:
mode:
Diffstat (limited to '.config/vim/ftplugin')
-rw-r--r--.config/vim/ftplugin/tex.vim73
1 files changed, 55 insertions, 18 deletions
diff --git a/.config/vim/ftplugin/tex.vim b/.config/vim/ftplugin/tex.vim
index 33c0116..c283e69 100644
--- a/.config/vim/ftplugin/tex.vim
+++ b/.config/vim/ftplugin/tex.vim
@@ -1,26 +1,63 @@
-imap FTT \texttt{}<Esc>i
-imap FBF \textbf{}<Esc>i
-imap FIT \textit{}<Esc>i
-imap MTT \mathtt{}<Esc>i
-imap MBF \mathbf{}<Esc>i
-imap MIT \mathit{}<Esc>i
+function! GetMainDoc()
+ let l:maindoc = search('\\begin{document}', "cnw")
+ if l:maindoc > 0
+ return '%'
+ else
+ " Find the main document file
+ " Must be in the same folder of the current file
+ let l:maindocs = split(system("grep -lE '\\\\begin{document}' " . expand('%:h') . "/*.tex"), '\n')
+ if len(l:maindocs) > 0
+ " Use the first document containing `begin{document}`
+ return l:maindocs[0]
+ else
+ return ""
+ endif
+ endif
+endfunction
-imap MCC \mathcal{}<++><Esc>T{i
+function! CompileMainDoc()
+ let l:latexcmd ='autocmd BufWritePost <buffer> !
+ \ latexrun --latex-args="-synctex=1 -interaction=nonstopmode" '
-inoremap <C-j> <Esc>/<++><CR>cf>
-noremap <C-j> /<++><CR>cf>
+ execute(l:latexcmd . GetMainDoc())
+endfunction
-vnoremap `IT <ESC>`>a}<ESC>`<i\textit{<ESC>
-vnoremap `BF <ESC>`>a}<ESC>`<i\textbf{<ESC>
-vnoremap `TT <ESC>`>a}<ESC>`<i\texttt{<ESC>
-vnoremap `MI <ESC>`>a}<ESC>`<i\mathit{<ESC>
-vnoremap `MB <ESC>`>a}<ESC>`<i\mathbf{<ESC>
-vnoremap `MT <ESC>`>a}<ESC>`<i\mathtt{<ESC>
+function! Synctex()
+ " remove 'silent' for debugging
+ let l:doc = GetMainDoc()
+ execute "silent !mv -u latex.out/" . substitute(l:doc, '\.tex', '') . ".synctex.gz ."
+ execute "silent !zathura --synctex-forward " . line('.') . ":" . col('.') . ":" . bufname('%') . " " . expand('%:t:r') . ".pdf"
+ redraw!
+endfunction
+
+imap <buffer> FTT \texttt{}<Esc>i
+imap <buffer> FBF \textbf{}<Esc>i
+imap <buffer> FIT \textit{}<Esc>i
+imap <buffer> FSC \textsc{}<Esc>i
+imap <buffer> MTT \mathtt{}<Esc>i
+imap <buffer> MBF \mathbf{}<Esc>i
+imap <buffer> MIT \mathit{}<Esc>i
+imap <buffer> MSC \mathsc{}<Esc>i
+
+imap <buffer> MCC \mathcal{}<++><Esc>T{i
+
+inoremap <buffer> <C-j> <Esc>/<++><CR>cf>
+noremap <buffer> <C-j> /<++><CR>cf>
+
+vnoremap <buffer> `it <ESC>`>a}<ESC>`<i\textit{<ESC>
+vnoremap <buffer> `bf <ESC>`>a}<ESC>`<i\textbf{<ESC>
+vnoremap <buffer> `tt <ESC>`>a}<ESC>`<i\texttt{<ESC>
+vnoremap <buffer> `mi <ESC>`>a}<ESC>`<i\mathit{<ESC>
+vnoremap <buffer> `mb <ESC>`>a}<ESC>`<i\mathbf{<ESC>
+vnoremap <buffer> `mt <ESC>`>a}<ESC>`<i\mathtt{<ESC>
" put \begin{} \end{} tags tags around the current word
-autocmd BufRead *.tex map <C-B> YpkI\begin{<ESC>A}<ESC>jI\end{<ESC>A}<esc>kA
-autocmd BufRead *.tex map! <C-B> <ESC>YpkI\begin{<ESC>A}<ESC>jI\end{<ESC>A}<esc>kA
-autocmd BufRead *.tex map <C-M> :call Synctex()<CR>
+vnoremap <C-B> YpkI\begin{<ESC>A}<ESC>jI\end{<ESC>A}<esc>kA
+nmap <C-M> :call Synctex()<CR>
+
+"setlocal spell spelllang=en_US
+
+call CompileMainDoc()
" autocmd BufRead *.tex imap /\ \land
" autocmd BufRead *.tex imap \/ \lor