Skip to content
James Eapen edited this page Jun 19, 2022 · 50 revisions

By default, Nvim-R will run R in a built-in terminal emulator, but you can change this behavior (see R_external_term).

Key bindings

Note: The <LocalLeader> is '\' by default.

Note: It is recommended the use of different keys for <Leader> and <LocalLeader> to avoid clashes between filetype plugins and general plugins key binds. See |filetype-plugins|, |maplocalleader| and Nvim-R-localleader.

To use the plugin, open a .R, .Rnw, .Rd, .Rmd or .Rrst file with Vim and type <LocalLeader>rf. Then, you will be able to use the plugin key bindings to send commands to R.

This plugin has many key bindings, which correspond with menu entries. In the list below, the backslash represents the <LocalLeader>. Not all menu items and key bindings are enabled in all filetypes supported by the plugin (r, rnoweb, rhelp, rrst, rmd).

Start/Close

Action Default shortcut
Start R (default) \rf
Start R (custom) \rc
Close R (no save) \rq
Stop (interrupt) R :RStop

Send

Action Default shortcut
File \aa
File (echo) \ae
File (open .Rout) \ao
Block (cur) \bb
Block (cur, echo) \be
Block (cur, down) \bd
Block (cur, echo and down) \ba
Chunk (cur) \cc
Chunk (cur, echo) \ce
Chunk (cur, down) \cd
Chunk (cur, echo and down) \ca
Chunk (from first to here) \ch
Function (cur) \ff
Function (cur, echo) \fe
Function (cur and down) \fd
Function (cur, echo and down) \fa
Selection \ss
Selection (echo) \se
Selection (and down) \sd
Selection (echo and down) \sa
Selection (evaluate and insert output in new tab) \so
Send motion region \m{motion}
Paragraph \pp
Paragraph (echo) \pe
Paragraph (and down) \pd
Paragraph (echo and down) \pa
Line \l
Line (and down) \d
Line (and new one) \q
Left part of line (cur) \r<Left>
Right part of line (cur) \r<Right>
Line (evaluate and insert the output a comment) \o
All lines above the current one \su

Command

Action Default shortcut
List space \rl
Clear console \rr
Remove objects and clear console \rm
Print (cur) \rp
Names (cur) \rn
Structure (cur) \rt
View data.frame (cur) in new tab \rv
View data.frame (cur) in horizontal split \vs
View data.frame (cur) in vertical split \vv
View head(data.frame) (cur) in horizontal split \vh
Run dput(cur) and show output in new tab \td
Arguments (cur) \ra
Example (cur) \re
Help (cur) \rh
Summary (cur) \rs
Plot (cur) \rg
Plot and summary (cur) \rb
Set working directory (cur file path) \rd
Sweave (cur file) \sw
Sweave and PDF (cur file) \sp
Sweave, BibTeX and PDF (cur file) (Linux/Unix) \sb
Knit (cur file) \kn
Knit, BibTeX and PDF (cur file) (Linux/Unix) \kb
Knit and PDF (cur file) \kp
Knit and Beamer PDF (cur file) \kl
Knit and HTML (cur file, verbose) \kh
Knit and ODT (cur file) \ko
Knit and Word Document (cur file) \kw
Markdown render (cur file) \kr
Spin (cur file) (only .R) \ks
Markdown render (cur file) (all in YAML) \ka
Quarto render (cur file) \qr
Quarto preview (cur file) \qp
Quarto stop preview (all files) \qs
Open attachment of reference (Rmd, Rnoweb) \oa
Open PDF (cur file) \op
Search forward (SyncTeX) \gp
Go to LaTeX (SyncTeX) \gt
Debug (function) \bg
Undebug (function) \ud
Build tags file (cur dir) :RBuildTags

Edit

Action Default shortcut
Insert <- _
Complete object name CTRL-X CTRL-O
Indent (line) ==
Indent (selected lines) =
Indent (whole buffer) gg=G
Toggle comment (line, sel) \xx
Comment (line, sel) \xc
Uncomment (line, sel) \xu
Add/Align right comment (line, sel) \;
Go (next R chunk) \gn
Go (previous R chunk) \gN

Object Browser

Action Default shortcut
Open/Close \ro
Expand (all lists) \r=
Collapse (all lists) \r-
Toggle (cur) Enter

Help

Action Default shortcut
Help (plugin)
Help (R) :Rhelp

Please see Nvim-R-key-bindings to learn how to customize the key bindings without editing the plugin directly.

The plugin commands that send code to R Console are the most commonly used. If the code to be sent to R has a single line it is sent directly to the R Console. If it has more than one line (a selection of lines, a block of lines between two marks, a paragraph etc) the lines are written to a file and the plugin sends R the command to source the file.

To send the line currently under the cursor to the R Console you should type <LocalLeader>d. If you want to see what lines are being sourced when sending a selection of lines, you can use either <LocalLeader>se or <LocalLeader>sa instead of <LocalLeader>ss. The <LocalLeader>m{motion} command sends the lines from the motion command that follows <LocalLeader>m, e.g. <LocalLeader>m} (from the current line to the end of paragraph) or <LocalLeader>m3j (the next 3 lines including the current line).

You can also use the command :RSend to type and, then, send a line of code to R. If you use this command frequently, you may consider creating a map for it in your vimrc. For example:

nmap <LocalLeader>: :RSend

Observe that there is an empty space after :RSend, so you do not have to type it.

The command <LocalLeader>o runs in the background the R command print(line), where line is the line under the cursor, and adds the output as commented lines to the source code.

Rnoweb, RMarkdown, Quarto or RreStructuredText document), and you use one of the commands that send a single line of code to R, then the plugin will send to R the command to knit the child document.

After the commands that send, sweave or knit the current buffer, Vim will save the current buffer if it has any pending changes before performing the tasks. After <LocalLeader>ao, Vim will run R CMD BATCH --no-restore --no-save on the current file and show the resulting .Rout file in a new tab. Please see R_routnotab if you prefer that the file is open in a new split window. Note: The command <LocalLeader>ao, silently writes the current buffer to its file if it was modified and deletes the .Rout file if it exists.

R syntax uses <- to assign values to variables which is inconvenient to type. In insert mode, typing a single underscore, _, will write <-, unless you are typing inside a string. The replacement will always happen if syntax highlighting is off (see :syn-on and :syn-off). If necessary, it is possible to insert an actual underscore into your file by typing a second underscore. This behavior is similar to the EMACS ESS mode some users may be familiar with and is enabled by default. You have to change the value of R_assign to disable underscore replacement.

When you press <LocalLeader>rh, the plugin shows the help for the function under the cursor. The plugin also checks the class of the first object passed as argument to the function to try to figure out whether the function is a generic one and whether it is more appropriate to show a specific method. The same procedure is followed with <LocalLeader>rp, that is, while printing an object. For example, if you run the code below and, then, press <LocalLeader>rh and <LocalLeader>rp over the two occurrences of summary, the plugin will show different help documents and print different function methods in each case:

y <- rnorm(100)
x <- rnorm(100)
m <- lm(y ~ x)
summary(x)
summary(m)

Nvim-R will not check the class of the first object if the = operator is present. For example, in the two cases below you would get the generic help for summary:

summary(object = x)
summary(object = m)

To get help on an R topic, you can also type in Vim (Normal mode):

:Rhelp topic

The command may be abbreviated to :Rh and you can either press <Tab> to trigger the autocompletion of R objects names or hit CTRL-D to list the possible completions (see |cmdline-completion| for details on the various ways of getting command-line completion). The list of objects used for completion is the same available for omni completion (see R_start_libs). You may close the R documentation buffer by simply pressing q.

The command <LocalLeader>td will run dput() with the object under cursor as argument and insert the output in a new tab. The command <LocalLeader>rv will also run dput() with the object under cursor as argument and show the output in a new tab, while <LocalLeader>vs will show it in a horizontal split, and <LocalLeader>vv will show it in a vertical split.

However, if the object under the cursor is a data.frame or a matrix, instead of displaying the output of dput(), the commands will save the data.frame or matrix in a text file with values separated by tab characters and display this file. The command <LocalLeader>vh will show the head() of the data.frame or matrix in a horizontal split that opens above the current window. This behavior can be customized with new mappings (see Nvim-R-df-view-mappings and Nvim-R-df-view), and you can configure Nvim-R to call an external application to display the data.frame or matrix. All files involved in these operations are created in Nvim-R's temporary directory and deleted when R quits.

When completing object names (CTRL-X CTRL-O) you have to press CTRL-N to go forward in the list and CTRL-P to go backward (see |popupmenu-completion|). For rnoweb, rmd and rrst file types, CTRL-X CTRL-O can also be used to complete knitr chunk options if the cursor is inside the chunk header.

If R is not running the completion will be based on information from the packages listed by R_start_libs (provided that the libraries were loaded at least once during a session of Nvim-R usage). Otherwise, the pop up menu for completion of function arguments will include an additional line with the name of the library where the function is (if the function name can be found in more than one library) and the function method (if what is being shown are the arguments of a method and not of the function itself). For both library() and require(), when completing the first argument, the popup list shows the names of installed packages, but only if R is running.

You can source all .R files in a directory with the Normal mode command :RSourceDir, which accepts an optional argument (the directory to be sourced).

Rinsert

The command :Rinsert <cmd> inserts one or more lines with the output of the R command sent to R. By using this command we can avoid the need of copying and pasting the output R from its console to Vim. For example, to insert the output of dput(levels(var)), where var is a factor vector, we could do in Vim:

:Rinsert dput(levels(var))

The output inserted by :Rinsert is limited to 5012 characters.

Rformat

The command :Rformat calls the function style_text() (if the package styler is installed) or the function tidy_source() (if the package formatR is installed) to format either the entire buffer or the selected lines. The command only works if R is running. If style_text() is used the value of 'shiftwidth' is passed as indent_by, and if tidy_source() is used, the value of the width.cutoff argument is set to the buffer's 'textwidth' if it is not outside the range 20-180.

See R help on tidy_source for details on how to control the function behavior.

Editing Rnoweb files

In Rnoweb files (.Rnw), when the cursor is over the @ character, which finishes an R chunk, the sending of all commands to R is suspended and the shortcut to send the current line makes the cursor to jump to the next chunk. While editing Rnoweb files, the following commands are available in Normal mode:

Go to the next chunk of R code:

[count]<LocalLeader>gn

Go to the previous chunk of R code:

[count]<LocalLeader>gN

You can also press <LocalLeader>gt to go the corresponding line in the generated .tex file (if SyncTeX is enabled).

The commands <LocalLeader>cc, ce, cd and ca send the current chunk of R code to R Console. The command <LocalLeader>ch sends the R code from the first chunk up to the current line.

The commands <LocalLeader>kn builds the .tex file from the Rnoweb one using the knitr package and <LocalLeader>kp compiles the pdf; for Sweave, the commands are, respectively <LocalLeader>sw and <LocalLeader>sp. You can jump from the Rnoweb file to the PDF (forward search) with the command <LocalLeader>gp. The command to jump from a specific location in the PDF to the corresponding line in the Rnoweb (backward search) is specific to each pdf viewer:

  • Zathura: <C-LeftMouse>

  • Evince: <C-LeftMouse>

  • Okular: <S-LeftMouse>

  • Skim: <S-Cmd-Click>

  • Sumatra: <Double-click>

In any case, the pdf viewer must be started by the Nvim-R plugin. See Nvim-R-SyncTeX for details.

Omni completion and syntax highlighting

The plugin adds some features to the default syntax highlight of R code. One such feature is the highlight of R functions. However, functions are highlighted only if their libraries are loaded by R (but see R_start_libs).

Note: If you have too many loaded packages Vim may be unable to load the list of functions for syntax highlight.

Vim can automatically complete the names of R objects both as you type them and when CTRL-X CTRL-O is pressed in insert mode (to disable these features, see R_auto_omni and R_set_omnifunc; see also |omni-completion| for details). Omni completion shows in a pop up menu the name of the object, its class and its environment (most frequently, its package name). If the object is a function, the plugin also shows the function arguments in a attached float window.

If a data.frame is found, while building the list of objects, the columns in the data.frame are added to the list but they are shown in the menu only after you have inserted the '$' symbol after the data.frame name.

Only the names of objects in .GlobalEnv and in loaded libraries are completed. If R is not running, only objects of libraries listed in R_start_libs will have their names completed.

Vim uses one file to store the names of .GlobalEnv objects and a list of files for all other objects. The .GlobalEnv list is stored in the $NVIMR_TMPDIR directory and is deleted when you quit Vim. The other files are stored in the $NVIMR_COMPLDIR directory, are automatically updated and remain available until you manually delete them.

The Object Browser

You have to use <LocalLeader>ro to either open or close the Object Browser. The Object Browser has two views: .GlobalEnv and Libraries. If you press on the first line of the Object Browser it will toggle the view between the objects in .GlobalEnv and the currently loaded libraries.

In the .GlobalEnv view, if a data.frame column has the attribute "label", it will also be displayed. For instance, the code below would make the Object Browser display the variable labels of an imported SPSS dataset:

library(foreign)
d <- read.spss("/path/to/spss/dataset.sav", to.data.frame = TRUE)
vlabs <- attr(d, "variable.labels")
for(n in names(vlabs))
    attr(d[[n]], "label") <- vlabs[[n]]

In the Object Browser window, while in Normal mode, you can either press or double click (GVim only) over a data.frame or list to show/hide its elements (not if viewing the content of loaded libraries). If you are running R in an environment where the string UTF-8 is part of either LC_MESSAGES or LC_ALL variables, Unicode line drawing characters will be used to draw lines in the Object Browser. This is the case of most Linux distributions.

In the Libraries view, you can either double click or press on a library name to see its objects. In the Object Browser, the libraries have the color defined by the PreProc highlighting group. The other objects have their colors defined by the return value of some R functions. Each line in the table below shows a highlighting group and the corresponding type of R object:

Highlighting Group Object type
PreProc libraries
Include environment
Number numeric
String character
Special factor
Boolean logical
Type data.frame
StorageClass list
Structure s4
Function function
Statement control flow (for, while, break, etc)
Comment promise (lazy load object)

One limitation of the Object Browser is that objects made available by the command data() are only links to the actual objects (promises of lazily loading the object when needed) and their real classes are not recognized in the GlobalEnv view. The same problem happens when the knitr option cache.lazy=TRUE. However, if you press over the name of the object in the Object Browser, it will be actually loaded by the command (ran in the background):

obj <- obj

Notes:

  • The Object Browser enables the automatic update of the data for the omni completion of .GlobalEnv objects, and this may slowdown R if its workspace has too many objects, data.frames with too many columns or lists with too many elements (see R_hi_fun_globenv.

  • Names of objects are stupidly truncated if they occupy more than 62 bytes. This means that Unicode sequences might be split and become invalid.

Commenting and uncommenting lines

You can toggle the state of a line as either commented or uncommented by typing <LocalLeader>xx. The string used to comment the line will be #, ## or ###, depending on the values of R_indent_commented and r_indent_ess_comments (see R_rcomment_string).

You can also add the string # to the beginning of a line by typing <LocalLeader>xc and remove it with <LocalLeader>xu. In this case, you can set the value of R_rcomment_string to control what string will be added to the beginning of the line. For example:

let R_rcomment_string = '# '

Finally, you can also add comments to the right of a line with the <LocalLeader>; shortcut. By default, the comment starts at the 40th column, which can be changed by setting the value of r_indent_comment_column, as below:

let r_indent_comment_column = 20

If the line is longer than 38 characters, the comment will start two columns after the last character in the line. If you are running <LocalLeader>; over a selection of lines, the comments will be aligned according to the longest line.

Note: While typing comments the leader comment string is automatically added to new lines when you reach 'textwidth' but not when you press <Enter>. Please, read the Vim help about 'formatoptions' and |fo-table|. For example, you can add the following line to your vimrc if you want the comment string being added after <Enter>:

autocmd FileType r setlocal formatoptions-=t formatoptions+=croql

If you are using a plugin to comment and uncomment lines of code and don't want the default single dash as the comment string, rather prefering two dashes as is usual in Emacs/ESS, put this in your |vimrc|:

function MyRmdCommentStr()
 if b:IsInRCode(0)
   setlocal commentstring=##\ %s
 elseif ((search('^---$', 'Wn') || search('^\.\.\.$', 'Wn')) && search('^---$', 'bnW'))
   setlocal commentstring=#\ %s
 else
   setlocal commentstring=<!--\ %s\ -->
 endif
endfunction
function MyRnwCommentStr()
 if b:IsInRCode(0)
   setlocal commentstring=##\ %s
 else
   setlocal commentstring=%\ %s
 endif
endfunction

function InitMyRmdCmtStr()
 augroup RmdCStr
   autocmd!
   autocmd CursorMoved <buffer> call MyRmdCommentStr()
 augroup END
endfunction

function InitMyRnwCmtStr()
 augroup RnwCStr
   autocmd!
   autocmd CursorMoved <buffer> call MyRnwCommentStr()
 augroup END
endfunction

autocmd FileType rmd call InitMyRmdCmtStr()
autocmd FileType rnoweb call InitMyRnwCmtStr()
autocmd FileType r set commentstring=##\ %s

JBuild a tags file to jump to function definitions

Vim can jump to functions defined in other files if you press CTRL-] over the name of a function, but it needs a tags file to be able to find the function definition (see |tags-and-searches|). The command :RBuildTags calls the R functions rtags() and etags2ctags to build the tags file for the R scripts in the current directory. Please read |Nvim-R-tagsfile| to learn how to create a tags file referencing source code located in other directories, including the entire R source code.

Debugging R functions (Unix only)

The Nvim-R-Plugin has limited debugging facilities available on Unix systems (not available on Windows). To debug a function with Nvim-R you have to do the following:

  1. Source the R script where the function is with the source() function of the base package.

  2. In the R Console, run either debug(funcname) or debugonce(funcname) where funcname is the name of the function (not quoted). Nvim-R will send this command to R Console if you press db in Normal mode with the cursor over the function name.

  3. Call the function.

See :Rh browser for available commands in debugging mode.

For example, if you have a file named my_function.R with the following contents:

add.one <- function(x){
    y <- x + 1
    print(y)
    return(invisible(NULL))
}

You could debug the add.one() function from another script such as:

source("path/to/my_function.R")
debug(add.one)
add.one(7)

If you do not want to start debugging the function from its first line, instead of calling debug(funcname) before calling the function, you should add the line browser() to the function at the line where the debugging session should start. Example:

add.one <- function(x){
   y <- x + 1
   browser()
   print(y)
   return(invisible(NULL))
}

If you want a conditional breakpoint, you should call the browser() command only if a condition is satisfied. Example:

add.one <- function(x){
    y <- x + 1
    if(x > 9)
 browser()
    print(y)
    return(invisible(NULL))
}

One limitation is that Nvim-R also does not help you setting breakpoints. You have to set them manually as explained above.

Another limitation of Nvim-R is that it might be unable to jump to the line in the source code that is being evaluated if either you have sent the function directly to the R Console or the function has been sent by the knitr package, without calling the function source(). In either case, Nvim-R will try to find the pattern funcname <- function( in the buffer being edited. If the pattern is found, the cursor will jump to its position.

The highlighting group used to highlight the line being debuged is the QuickFixLine (see hl-QuickFixLine). Its foreground and background colors are defined by your colorscheme, but you can change them in your vimrc (see cterm-colors and gui-colors). Example:

hi QuickFixLine ctermfg=231 ctermbg=23 guifg=white guibg=#005f5f