This is a Vim plugin that provides Rust file detection, syntax highlighting, formatting,
Syntastic integration, and more. It requires Vim 8 or higher for full functionality.
Some things may not work on earlier versions.
Installation
For activating the full functionality, this plugin requires either the plugin
manager or the .vimrc to have the following:
syntax enable
filetype plugin indent on
Most plugin managers don’t do this automatically, so these statements are
usually added by users in their vimrcright after the plugin manager load
section.
The installation of Tagbar along with Universal Ctags is recommended
for a good Tagbar experience. For other kinds of setups, rust.vim tries to
configure Tagbar to some degree.
Note: This feature requires webapi-vim to be installed.
The :RustPlay command will send the current selection, or if
nothing is selected the current buffer, to the Rust playpen.
If you set g:rust_clip_command RustPlay will copy the url to the clipboard.
Mac:
let g:rust_clip_command = 'pbcopy'
Linux:
let g:rust_clip_command = 'xclip -selection clipboard'
Running a test under cursor
In a Cargo project, the :RustTest command will run the test that is under the cursor.
This is useful when your project is big and running all of the tests takes a long time.
Help
Further help can be found in the documentation with :Helptags then :help rust.
Detailed help can be found in the documentation with :help rust.
Helptags (:help helptags) need to be generated for this plugin
in order to navigate the help. Most plugin managers will do this
automatically, but check their documentation if that is not the case.
License
Like Rust, rust.vim is primarily distributed under the terms of both the MIT
license and the Apache License (Version 2.0). See LICENSE-APACHE and
LICENSE-MIT for details.
rust.vim
Description
This is a Vim plugin that provides Rust file detection, syntax highlighting, formatting, Syntastic integration, and more. It requires Vim 8 or higher for full functionality. Some things may not work on earlier versions.
Installation
For activating the full functionality, this plugin requires either the plugin manager or the
.vimrcto have the following:Most plugin managers don’t do this automatically, so these statements are usually added by users in their
vimrcright after the plugin manager load section.Vim8 packages
Vundle
Pathogen
vim-plug
dein.vim
NeoBundle
Features
Error checking with Syntastic
rust.vimautomatically registerscargoas a syntax checker with Syntastic, if nothing else is specified. See:help rust-syntasticfor more details.Source browsing with Tagbar
The installation of Tagbar along with Universal Ctags is recommended for a good Tagbar experience. For other kinds of setups,
rust.vimtries to configure Tagbar to some degree.Formatting with rustfmt
The
:RustFmtcommand will format your code with rustfmt if installed.rustfmtcan be installed viarustup component add rustfmt.Placing
let g:rustfmt_autosave = 1in your~/.vimrcwill enable automatic running of:RustFmtwhen you save a buffer.Do
:help :RustFmtfor further formatting help and customization options.Playpen integration
Note: This feature requires webapi-vim to be installed.
The
:RustPlaycommand will send the current selection, or if nothing is selected the current buffer, to the Rust playpen.If you set g:rust_clip_command RustPlay will copy the url to the clipboard.
Mac:
Linux:
Running a test under cursor
In a Cargo project, the
:RustTestcommand will run the test that is under the cursor. This is useful when your project is big and running all of the tests takes a long time.Help
Further help can be found in the documentation with
:Helptagsthen:help rust.Detailed help can be found in the documentation with
:help rust. Helptags (:help helptags) need to be generated for this plugin in order to navigate the help. Most plugin managers will do this automatically, but check their documentation if that is not the case.License
Like Rust, rust.vim is primarily distributed under the terms of both the MIT license and the Apache License (Version 2.0). See LICENSE-APACHE and LICENSE-MIT for details.