https://github.com/vim-pandoc/vim-rmarkdown
Rmarkdown support for vim
https://github.com/vim-pandoc/vim-rmarkdown
Last synced: 3 months ago
JSON representation
Rmarkdown support for vim
- Host: GitHub
- URL: https://github.com/vim-pandoc/vim-rmarkdown
- Owner: vim-pandoc
- Created: 2014-07-12T17:06:23.000Z (over 10 years ago)
- Default Branch: master
- Last Pushed: 2023-02-06T03:41:22.000Z (about 2 years ago)
- Last Synced: 2024-06-18T00:38:46.322Z (8 months ago)
- Language: Vim script
- Size: 26.4 KB
- Stars: 98
- Watchers: 6
- Forks: 26
- Open Issues: 25
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
- jimsghstars - vim-pandoc/vim-rmarkdown - Rmarkdown support for vim (Vim Script)
README
vim-rmarkdown
=============[RMarkdown](http://rmarkdown.rstudio.com/) support for vim.
## Setup
vim-rmarkdown requires
* the [vim-pandoc](https://github.com/vim-pandoc/vim-pandoc) and
[vim-pandoc-syntax](https://github.com/vim-pandoc/vim-pandoc-syntax) vim plugins.* the [rmarkdown standalone package](https://github.com/rstudio/rmarkdown)
vim-rmarkdown's repo uses the typical bundle layout, so it's very simple to
install using some plugin manager such as [pathogen](https://github.com/tpope/vim-pathogen), [Vundle](https://github.com/VundleVim/Vundle.vim) or [NeoBundle](https://github.com/Shougo/neobundle.vim). For
example, using Vundle you should addPlugin 'vim-pandoc/vim-rmarkdown'
to your .vimrc, source it, and execute `:PluginInstall`.
## Screenshot
data:image/s3,"s3://crabby-images/2c933/2c9339d5c6f63bd4635a320519ca2ac06aa260e5" alt="screenshot"
## Usage
Files with the .Rmd extension are automatically detected as RMarkdown files.
vim-rmarkdown loads vim-pandoc and pandoc's markdown syntax, and adds some
extra functionality specific to rmarkdown.### Syntax
vim-rmarkdown extends pandoc's markdown syntax so
```{r qplot, fig.width=4, message=FALSE}
library(ggplot2)
summary(cars)
qplot(speed, dist, data=cars) +
geom_smooth()
```is recognized as an R code chunk, and
inline unformatted text like `r 1 + 2`
as inline R.
R syntax is used within such fenced codeblocks and inline spans.
### Command
To render the file using rmarkdown, the user can execute the `|:RMarkdown|`
command. Its syntax is`:RMarkdown[!] [OUTPUT_TYPE] [- RENDER_ARGS[ -]] [OUTPUT_TYPE_ARGS]`
OUTPUT_TYPE is one of "pdf", "word", "html", "md", "beamer", "ioslides",
"revealjs", "all", or a combination thereof (e.g., "pdf+html"). Command
completion is provided for defining this variable.RENDER_ARGS are arguments passed to rmarkdown::render(...), and
OUTPUT_TYPE_ARGS are passed to output objects such as rmarkdown::pdf_document(...)
and rmarkdown::word_document(...). (Refer to RMarkdown's documentation).
Note RENDER_ARGS MUST be surrounded by '- ' and ' -'.The bang (!) version opens the created file on successful execution. If the
execution fails, a message will be shown and a buffer will open with Rscript's
output (can be dismissed by pressing q in normal mode).:RMarkdown builds a R expression that executes rmarkdown. For example, if the
current file is "input.Rmd",:RMarkdown pdf
executes
Rscript -e 'library(rmarkdown);render("input.Rmd", "pdf_document")'
If OUTPUT_TYPE is ommited, RMarkdown produces an html document.
Some more examples:
:RMarkdown pdf latex_engine="xelatex", toc=TRUE
->
Rscript -e 'library(rmarkdown);render("input.Rmd", pdf_document(latex_engine="xelatex", toc=TRUE):RMarkdown html - quiet=FALSE - toc=FALSE
->
Rscript -e 'library(rmarkdown);render("input.Rmd", html_document(toc=TRUE), quiet=FALSE):RMarkdown word - quiet=FALSE
->
Rscript -e 'library(rmarkdown);render("input.Rmd", "word_document", quiet=FALSE)Note `|:RMarkdown|` doesn't parse the arguments itself, so the user must type them
exactly as they should be used in R (for example, commas should separate
arguments). For example,:RMarkdown latex_engine="lualatex" bibliography="input.bib"
will cause rmarkdown to fail.
## NrrwRgn
If the NrrwRgn plugin is available, vim-rmarkdown will register an extra
command, |:RNrrw|, which "narrows" the current R chunk in a separate buffer.
This command is also mapped to "ccn" in normal mode.`" vim: set ft=help :`