147 lines
6.0 KiB
Markdown
147 lines
6.0 KiB
Markdown
# vimtex
|
|
|
|
vimtex is a [Vim](http://www.vim.org/) plugin that provides support for writing
|
|
LaTeX documents. It is based on
|
|
[LaTeX-Box](https://github.com/LaTeX-Box-Team/LaTeX-Box) and it shares a
|
|
similar goal: to provide a simple and lightweight LaTeX plugin. It has been
|
|
rewritten from scratch to provide a more modern and modular code base. See
|
|
[here](#alternatives) for some more comments on the difference between vimtex
|
|
and other LaTeX plugins for Vim.
|
|
|
|
[![Build Status](https://travis-ci.org/lervag/vimtex.svg?branch=master)](https://travis-ci.org/lervag/vimtex)
|
|
[![Donate](https://img.shields.io/badge/Donate-PayPal-green.svg)](https://www.paypal.com/cgi-bin/webscr?cmd=_s-xclick&hosted_button_id=5N4MFVXN7U8NW)
|
|
|
|
## Installation
|
|
|
|
If you use [vim-plug](https://github.com/junegunn/vim-plug), then add the
|
|
following line to your `vimrc` file:
|
|
|
|
```vim
|
|
Plug 'lervag/vimtex'
|
|
```
|
|
|
|
Or use some other plugin manager:
|
|
- [vundle](https://github.com/gmarik/vundle)
|
|
- [neobundle](https://github.com/Shougo/neobundle.vim)
|
|
- [pathogen](https://github.com/tpope/vim-pathogen)
|
|
|
|
## Quick Start
|
|
|
|
The following is a simple guide for how to use vimtex. It only displays the
|
|
most basic features. Users are _strongly_ encouraged to read or at least skim
|
|
through the documentation to learn about the different features and
|
|
possibilities provided by vimtex (see
|
|
[here](https://github.com/lervag/vimtex/blob/master/doc/vimtex.txt) or `:h
|
|
vimtex`).
|
|
|
|
1. Edit a document: `vim document.tex`
|
|
2. Start compiling the document with `\ll`
|
|
3. Open pdf viewer and/or do forward searching with `\lv`
|
|
4. Stop the running compilation with `\ll` (or `\lk`)
|
|
5. To parse the log file for errors and warnings, press `\le`
|
|
6. To clean auxiliary files, press `\lc` (or `\lC` to also clean the output
|
|
file)
|
|
|
|
## Features
|
|
|
|
Below is a list of features offered by vimtex. The features are accessible as
|
|
both commands and mappings. The mappings generally start with
|
|
`<localleader>l`, but if desired one can disable default mappings to define
|
|
custom mappings. All features are enabled by default, but each feature may be
|
|
disabled if desired.
|
|
|
|
- Document compilation with
|
|
[latexmk](http://users.phys.psu.edu/~collins/software/latexmk-jcc/)
|
|
- Compilation of selected part of document
|
|
- Support for several PDF viewers with forward search
|
|
- [MuPDF](http://www.mupdf.com/)
|
|
- [Zathura](https://pwmt.org/projects/zathura/)
|
|
- [Okular](https://okular.kde.org/)
|
|
- [qpdfview](https://launchpad.net/qpdfview)
|
|
- [SumatraPDF](http://www.sumatrapdfreader.org/free-pdf-reader.html)
|
|
- Other viewers are supported through a general interface
|
|
- Completion of citations, labels, and file names for figures
|
|
- Document navigation through
|
|
- table of content
|
|
- table of labels
|
|
- Word count (through `texcount`)
|
|
- Motions
|
|
- Move between sections with `[[`, `[]`, `][`, `]]`
|
|
- Move between matching delimiters with `%`
|
|
- Text objects
|
|
- `ic ac` Commands
|
|
- `id ad` Delimiters
|
|
- `ie ae` LaTeX environments
|
|
- `i$ a$` Inline math structures
|
|
- Other mappings
|
|
- Delete the surrounding command or environment with `dsc`/`dse`/`ds$`
|
|
- Change the surrounding command or environment with `csc`/`cse`/`cs$`
|
|
- Toggle starred environment with `tse`
|
|
- Toggle between e.g. `()` and `\left(\right)` with `tsd`
|
|
- Close the current environment/delimiter in insert mode with `]]`
|
|
- Insert new command with `<F7>`
|
|
- Convenient insert mode mappings for faster typing of e.g. maths
|
|
- Improved folding (`:h 'foldexpr'`)
|
|
- Improved indentation (`:h 'indentexpr'`)
|
|
- Improved syntax highlighting
|
|
- Highlight matching delimiters
|
|
- Support for `biblatex`/`natbib` package
|
|
- Support for `cleveref` package
|
|
- Support for `listings` package
|
|
- Support for `minted` package
|
|
- Support for `dot2tex` with nested syntax highlighting
|
|
- Support for multi-file project packages
|
|
- [import](http://ctan.uib.no/macros/latex/contrib/import/import.pdf)
|
|
- [subfiles](http://ctan.uib.no/macros/latex/contrib/subfiles/subfiles.pdf)
|
|
|
|
See the documentation for a thorough introduction to vimtex (e.g. `:h vimtex`).
|
|
|
|
## Alternatives
|
|
|
|
The following are some alternative LaTeX plugins for Vim:
|
|
|
|
- [LaTeX-Box](https://github.com/LaTeX-Box-Team/LaTeX-Box)
|
|
|
|
vimtex currently has most of the features of LaTeX-Box, as well as
|
|
some additional ones. See [here](#features) for a relatively complete list
|
|
of features.
|
|
|
|
One particular feature that LaTeX-Box has but vimtex misses, is the ability
|
|
to do single-shot compilation _with callback_. This functionality was
|
|
removed because it adds a lot of complexity for relatively little gain
|
|
(IMHO).
|
|
|
|
Note: LaTeX-Box is included with
|
|
[vim-polyglot](https://github.com/sheerun/vim-polyglot). Some users are not
|
|
quite aware of this and end up trying vimtex with LaTeX-Box enabled. This
|
|
will not work --- please disable LaTeX-Box first!
|
|
|
|
- [LaTeX-Suite](http://vim-latex.sourceforge.net)
|
|
|
|
The main difference between vimtex and LaTeX-Suite (aka vim-latex) is
|
|
probably that vimtex does not try to implement a full fledged IDE for LaTeX
|
|
inside Vim. E.g.:
|
|
|
|
- vimtex does not provide a full snippet feature, because this is better
|
|
handled by [UltiSnips](https://github.com/SirVer/ultisnips) or
|
|
[neosnippet](https://github.com/Shougo/neosnippet.vim) or similar snippet
|
|
engines.
|
|
- vimtex builds upon Vim principles: It provides text objects for
|
|
environments, inline math, it provides motions for sections and
|
|
paragraphs
|
|
- vimtex uses `latexmk` for compilation with a callback feature to get
|
|
instant feedback on compilation errors
|
|
- vimtex is very modular: if you don't like a feature, you can turn it off.
|
|
|
|
- [AutomaticTexPlugin](http://atp-vim.sourceforge.net)
|
|
- [vim-latex-live-preview](https://github.com/xuhdev/vim-latex-live-preview)
|
|
|
|
For more alternatives and more information and discussions regarding LaTeX
|
|
plugins for Vim, see:
|
|
|
|
- [What are the differences between LaTeX
|
|
plugins](http://vi.stackexchange.com/questions/2047/what-are-the-differences-between-latex-plugins)
|
|
- [List of LaTeX editors (not only
|
|
Vim)](https://tex.stackexchange.com/questions/339/latex-editors-ides)
|
|
|