Move Analyzer VS Code Extension
The Move Analyzer extension for Visual Studio Code provides language support features for the Move programming language. It enables syntax highlighting, code completion, and advanced features like definition linking and type checking.
Install
You can install the Move extension from the Visual Studio Code Marketplace:
- Open VS Code.
- Open the Extensions view (⇧ + ⌘ + X on macOS, Ctrl + Shift + X on Windows/Linux).
- Search for
mysten.move
. - Click Install on the Move extension by Mysten Labs.
Alternative install methods include:
-
Use Ctrl + P or ⌘ + P and type
ext install mysten.move
. -
Use the command line:
$ code --install-extension mysten.move
The following extensions are included in the Move extension install:
Install move-analyzer
The Move extension attempts to install the appropriate move-analyzer
binary for your platform. If this doesn't work, or you prefer to install it manually, build it with Cargo:
$ cargo install --git https://github.com/MystenLabs/sui.git sui-move-lsp
By default, the Move extension expects to find the move-analyzer
binary in ~/.sui/bin
. You can either copy the binary to this location, or configure the extension to use a different path.
Features
The Move extension supports most Language Server Protocol features, as well as basic commands for building, testing, and tracing Move code.
Build, test, and trace
The Move extension installs command palette commands for building, testing, and tracing Move code.
These commands find the Move.toml
file for the open Move source file and open a terminal to run the appropriate sui move
command.
To generate a trace, you must have a trace-capable sui
binary. See Debugger for more information.
Syntax highlighting
The Move Syntax extension provides syntax highlighting.
Hover information
Hovering over identifiers shows type information, struct fields and attributes, and docstrings (if any) for the identifier. This works for all Move symbols including macros.
-
Hover over structs to see structure and definition.
-
Hover over functions for details and definition.
-
Hover over macros for their functionality.
Code completion
The Move extension autocompletes upon a dot operator, displaying the available methods and fields for the type.
The Move extension also autocompletes after a ::
operator.
Finally, the Move extension provides "inlay hints," where the plugin automatically inserts the correct type after a variable declaration, unpack, function parameters, and other places.
Navigation
The Move extension supports go-to-definition
navigation for all Move symbols including types, functions, and macros, as long as the type was present when move-analyzer
last built the file.
The extension also supports find-references
for functions, macros, constants, and types.