2 "name": "rust-analyzer",
3 "displayName": "rust-analyzer",
4 "description": "An alternative rust language server to the RLS",
8 "version": "0.4.0-dev",
10 "publisher": "matklad",
12 "url": "https://github.com/rust-analyzer/rust-analyzer.git",
15 "homepage": "https://rust-analyzer.github.io/",
16 "license": "MIT OR Apache-2.0",
21 "Programming Languages"
26 "enableProposedApi": true,
28 "vscode:prepublish": "tsc && rollup -c",
29 "package": "vsce package -o rust-analyzer.vsix",
31 "watch": "tsc --watch",
32 "lint": "tsfmt --verify && eslint -c .eslintrc.js --ext ts ./src ./tests",
33 "fix": " tsfmt -r && eslint -c .eslintrc.js --ext ts ./src ./tests --fix",
34 "pretest": "npm run build",
35 "test": "node ./out/tests/runTests.js"
38 "node-fetch": "^2.6.1",
39 "vscode-languageclient": "7.0.0"
42 "@rollup/plugin-commonjs": "^17.0.0",
43 "@rollup/plugin-node-resolve": "^11.0.0",
44 "@types/glob": "^7.1.3",
45 "@types/mocha": "^8.0.4",
46 "@types/node": "~12.12.6",
47 "@types/node-fetch": "^2.5.7",
48 "@types/vscode": "^1.52.0",
49 "@typescript-eslint/eslint-plugin": "^4.9.0",
50 "@typescript-eslint/parser": "^4.9.0",
56 "typescript": "^4.1.2",
57 "typescript-formatter": "^7.2.2",
59 "vscode-test": "^1.4.1"
63 "onCommand:rust-analyzer.analyzerStatus",
64 "onCommand:rust-analyzer.memoryUsage",
65 "onCommand:rust-analyzer.reloadWorkspace",
66 "workspaceContains:**/Cargo.toml"
68 "main": "./out/src/main",
91 "patternProperties": {
102 "command": "rust-analyzer.syntaxTree",
103 "title": "Show Syntax Tree",
104 "category": "Rust Analyzer"
107 "command": "rust-analyzer.viewHir",
109 "category": "Rust Analyzer"
112 "command": "rust-analyzer.expandMacro",
113 "title": "Expand macro recursively",
114 "category": "Rust Analyzer"
117 "command": "rust-analyzer.matchingBrace",
118 "title": "Find matching brace",
119 "category": "Rust Analyzer"
122 "command": "rust-analyzer.parentModule",
123 "title": "Locate parent module",
124 "category": "Rust Analyzer"
127 "command": "rust-analyzer.joinLines",
128 "title": "Join lines",
129 "category": "Rust Analyzer"
132 "command": "rust-analyzer.run",
134 "category": "Rust Analyzer"
137 "command": "rust-analyzer.debug",
139 "category": "Rust Analyzer"
142 "command": "rust-analyzer.newDebugConfig",
143 "title": "Generate launch configuration",
144 "category": "Rust Analyzer"
147 "command": "rust-analyzer.analyzerStatus",
149 "category": "Rust Analyzer"
152 "command": "rust-analyzer.memoryUsage",
153 "title": "Memory Usage (Clears Database)",
154 "category": "Rust Analyzer"
157 "command": "rust-analyzer.reloadWorkspace",
158 "title": "Reload workspace",
159 "category": "Rust Analyzer"
162 "command": "rust-analyzer.reload",
163 "title": "Restart server",
164 "category": "Rust Analyzer"
167 "command": "rust-analyzer.updateGithubToken",
168 "title": "Update Github API token",
169 "category": "Rust Analyzer"
172 "command": "rust-analyzer.onEnter",
173 "title": "Enhanced enter key",
174 "category": "Rust Analyzer"
177 "command": "rust-analyzer.ssr",
178 "title": "Structural Search Replace",
179 "category": "Rust Analyzer"
182 "command": "rust-analyzer.serverVersion",
183 "title": "Show RA Version",
184 "category": "Rust Analyzer"
187 "command": "rust-analyzer.toggleInlayHints",
188 "title": "Toggle inlay hints",
189 "category": "Rust Analyzer"
192 "command": "rust-analyzer.openDocs",
193 "title": "Open docs under cursor",
194 "category": "Rust Analyzer"
197 "command": "rust-analyzer.openCargoToml",
198 "title": "Open Cargo.toml",
199 "category": "Rust Analyzer"
204 "command": "rust-analyzer.parentModule",
205 "key": "ctrl+shift+u",
206 "when": "editorTextFocus && editorLangId == rust"
209 "command": "rust-analyzer.matchingBrace",
210 "key": "ctrl+shift+m",
211 "when": "editorTextFocus && editorLangId == rust"
214 "command": "rust-analyzer.joinLines",
215 "key": "ctrl+shift+j",
216 "when": "editorTextFocus && editorLangId == rust"
221 "title": "Rust Analyzer",
223 "rust-analyzer.cargoRunner": {
229 "description": "Custom cargo runner extension ID."
231 "rust-analyzer.runnableEnv": {
243 "description": "Runnable name mask"
247 "description": "Variables in form of { \"key\": \"value\"}"
254 "description": "Variables in form of { \"key\": \"value\"}"
258 "markdownDescription": "Environment variables passed to the runnable launched using `Test` or `Debug` lens or `rust-analyzer.run` command."
260 "rust-analyzer.inlayHints.enable": {
263 "description": "Whether to show inlay hints."
265 "rust-analyzer.updates.channel": {
272 "markdownEnumDescriptions": [
273 "`stable` updates are shipped weekly, they don't contain cutting-edge features from VSCode proposed APIs but have less bugs in general.",
274 "`nightly` updates are shipped daily (extension updates automatically by downloading artifacts directly from GitHub), they contain cutting-edge features and latest bug fixes. These releases help us get your feedback very quickly and speed up rust-analyzer development **drastically**."
276 "markdownDescription": "Choose `nightly` updates to get the latest features and bug fixes every day. While `stable` releases occur weekly and don't contain cutting-edge features from VSCode proposed APIs."
278 "rust-analyzer.updates.askBeforeDownload": {
281 "description": "Whether to ask for permission before downloading any files from the Internet."
283 "rust-analyzer.serverPath": {
289 "markdownDescription": "Path to rust-analyzer executable (points to bundled binary by default). If this is set, then `#rust-analyzer.updates.channel#` setting is not used"
291 "rust-analyzer.trace.server": {
299 "enumDescriptions": [
305 "description": "Trace requests to the rust-analyzer (this is usually overly verbose and not recommended for regular users)."
307 "rust-analyzer.trace.extension": {
308 "description": "Enable logging of VS Code extensions itself.",
312 "rust-analyzer.debug.engine": {
316 "vadimcn.vscode-lldb",
320 "description": "Preferred debug engine.",
321 "markdownEnumDescriptions": [
322 "First try to use [CodeLLDB](https://marketplace.visualstudio.com/items?itemName=vadimcn.vscode-lldb), if it's not installed try to use [MS C++ tools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools).",
323 "Use [CodeLLDB](https://marketplace.visualstudio.com/items?itemName=vadimcn.vscode-lldb)",
324 "Use [MS C++ tools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools)"
327 "rust-analyzer.debug.sourceFileMap": {
329 "description": "Optional source file mappings passed to the debug engine.",
331 "/rustc/<id>": "${env:USERPROFILE}/.rustup/toolchains/<toolchain-id>/lib/rustlib/src/rust"
334 "rust-analyzer.debug.openDebugPane": {
335 "markdownDescription": "Whether to open up the `Debug Panel` on debugging start.",
339 "rust-analyzer.debug.engineSettings": {
342 "markdownDescription": "Optional settings passed to the debug engine. Example: `{ \"lldb\": { \"terminal\":\"external\"} }`"
344 "rust-analyzer.assist.importMergeBehaviour": {
345 "markdownDescription": "The strategy to use when inserting new imports or merging imports.",
353 "enumDescriptions": [
355 "Merge all layers of the import trees",
356 "Only merge the last layer of the import trees"
359 "rust-analyzer.assist.importPrefix": {
360 "markdownDescription": "The path structure for newly inserted paths to use.",
368 "enumDescriptions": [
369 "Insert import paths relative to the current module, using up to one `super` prefix if the parent module contains the requested item.",
370 "Prefix all import paths with `self` if they don't begin with `self`, `super`, `crate` or a crate name.",
371 "Force import paths to be absolute by always starting them with `crate` or the crate name they refer to."
374 "rust-analyzer.callInfo.full": {
375 "markdownDescription": "Show function name and docs in parameter hints.",
379 "rust-analyzer.cargo.autoreload": {
380 "markdownDescription": "Automatically refresh project info via `cargo metadata` on `Cargo.toml` changes.",
384 "rust-analyzer.cargo.allFeatures": {
385 "markdownDescription": "Activate all available features.",
389 "rust-analyzer.cargo.features": {
390 "markdownDescription": "List of features to activate.",
397 "rust-analyzer.cargo.loadOutDirsFromCheck": {
398 "markdownDescription": "Run `cargo check` on startup to get the correct value for package OUT_DIRs.",
402 "rust-analyzer.cargo.noDefaultFeatures": {
403 "markdownDescription": "Do not activate the `default` feature.",
407 "rust-analyzer.cargo.target": {
408 "markdownDescription": "Compilation target (target triple).",
415 "rust-analyzer.cargo.noSysroot": {
416 "markdownDescription": "Internal config for debugging, disables loading of sysroot crates.",
420 "rust-analyzer.checkOnSave.enable": {
421 "markdownDescription": "Run specified `cargo check` command for diagnostics on save.",
425 "rust-analyzer.checkOnSave.allFeatures": {
426 "markdownDescription": "Check with all features (will be passed as `--all-features`). Defaults to `#rust-analyzer.cargo.allFeatures#`.",
433 "rust-analyzer.checkOnSave.allTargets": {
434 "markdownDescription": "Check all targets and tests (will be passed as `--all-targets`).",
438 "rust-analyzer.checkOnSave.command": {
439 "markdownDescription": "Cargo command to use for `cargo check`.",
443 "rust-analyzer.checkOnSave.noDefaultFeatures": {
444 "markdownDescription": "Do not activate the `default` feature.",
451 "rust-analyzer.checkOnSave.target": {
452 "markdownDescription": "Check for a specific target. Defaults to `#rust-analyzer.cargo.target#`.",
459 "rust-analyzer.checkOnSave.extraArgs": {
460 "markdownDescription": "Extra arguments for `cargo check`.",
467 "rust-analyzer.checkOnSave.features": {
468 "markdownDescription": "List of features to activate. Defaults to `#rust-analyzer.cargo.features#`.",
478 "rust-analyzer.checkOnSave.overrideCommand": {
479 "markdownDescription": "Advanced option, fully override the command rust-analyzer uses for checking. The command should include `--message-format=json` or similar option.",
489 "rust-analyzer.completion.addCallArgumentSnippets": {
490 "markdownDescription": "Whether to add argument snippets when completing functions.",
494 "rust-analyzer.completion.addCallParenthesis": {
495 "markdownDescription": "Whether to add parenthesis when completing functions.",
499 "rust-analyzer.completion.postfix.enable": {
500 "markdownDescription": "Whether to show postfix snippets like `dbg`, `if`, `not`, etc.",
504 "rust-analyzer.completion.autoimport.enable": {
505 "markdownDescription": "Toggles the additional completions that automatically add imports when completed. Note that your client must specify the `additionalTextEdits` LSP client capability to truly have this feature enabled.",
509 "rust-analyzer.diagnostics.enable": {
510 "markdownDescription": "Whether to show native rust-analyzer diagnostics.",
514 "rust-analyzer.diagnostics.enableExperimental": {
515 "markdownDescription": "Whether to show experimental rust-analyzer diagnostics that might have more false positives than usual.",
519 "rust-analyzer.diagnostics.disabled": {
520 "markdownDescription": "List of rust-analyzer diagnostics to disable.",
528 "rust-analyzer.diagnostics.warningsAsHint": {
529 "markdownDescription": "List of warnings that should be displayed with info severity.\\n\\nThe warnings will be indicated by a blue squiggly underline in code and a blue icon in the `Problems Panel`.",
536 "rust-analyzer.diagnostics.warningsAsInfo": {
537 "markdownDescription": "List of warnings that should be displayed with hint severity.\\n\\nThe warnings will be indicated by faded text or three dots in code and will not show up in the `Problems Panel`.",
544 "rust-analyzer.files.watcher": {
545 "markdownDescription": "Controls file watching implementation.",
549 "rust-analyzer.hoverActions.debug": {
550 "markdownDescription": "Whether to show `Debug` action. Only applies when `#rust-analyzer.hoverActions.enable#` is set.",
554 "rust-analyzer.hoverActions.enable": {
555 "markdownDescription": "Whether to show HoverActions in Rust files.",
559 "rust-analyzer.hoverActions.gotoTypeDef": {
560 "markdownDescription": "Whether to show `Go to Type Definition` action. Only applies when `#rust-analyzer.hoverActions.enable#` is set.",
564 "rust-analyzer.hoverActions.implementations": {
565 "markdownDescription": "Whether to show `Implementations` action. Only applies when `#rust-analyzer.hoverActions.enable#` is set.",
569 "rust-analyzer.hoverActions.run": {
570 "markdownDescription": "Whether to show `Run` action. Only applies when `#rust-analyzer.hoverActions.enable#` is set.",
574 "rust-analyzer.hoverActions.linksInHover": {
575 "markdownDescription": "Use markdown syntax for links in hover.",
579 "rust-analyzer.inlayHints.chainingHints": {
580 "markdownDescription": "Whether to show inlay type hints for method chains.",
584 "rust-analyzer.inlayHints.maxLength": {
585 "markdownDescription": "Maximum length for inlay hints. Default is unlimited.",
593 "rust-analyzer.inlayHints.parameterHints": {
594 "markdownDescription": "Whether to show function parameter name inlay hints at the call site.",
598 "rust-analyzer.inlayHints.typeHints": {
599 "markdownDescription": "Whether to show inlay type hints for variables.",
603 "rust-analyzer.lens.debug": {
604 "markdownDescription": "Whether to show `Debug` lens. Only applies when `#rust-analyzer.lens.enable#` is set.",
608 "rust-analyzer.lens.enable": {
609 "markdownDescription": "Whether to show CodeLens in Rust files.",
613 "rust-analyzer.lens.implementations": {
614 "markdownDescription": "Whether to show `Implementations` lens. Only applies when `#rust-analyzer.lens.enable#` is set.",
618 "rust-analyzer.lens.run": {
619 "markdownDescription": "Whether to show `Run` lens. Only applies when `#rust-analyzer.lens.enable#` is set.",
623 "rust-analyzer.lens.methodReferences": {
624 "markdownDescription": "Whether to show `Method References` lens. Only applies when `#rust-analyzer.lens.enable#` is set.",
628 "rust-analyzer.linkedProjects": {
629 "markdownDescription": "Disable project auto-discovery in favor of explicitly specified set of projects.\\n\\nElements must be paths pointing to `Cargo.toml`, `rust-project.json`, or JSON objects in `rust-project.json` format.",
639 "rust-analyzer.lruCapacity": {
640 "markdownDescription": "Number of syntax trees rust-analyzer keeps in memory. Defaults to 128.",
648 "rust-analyzer.notifications.cargoTomlNotFound": {
649 "markdownDescription": "Whether to show `can't find Cargo.toml` error message.",
653 "rust-analyzer.procMacro.enable": {
654 "markdownDescription": "Enable Proc macro support, `#rust-analyzer.cargo.loadOutDirsFromCheck#` must be enabled.",
658 "rust-analyzer.runnables.overrideCargo": {
659 "markdownDescription": "Command to be executed instead of 'cargo' for runnables.",
666 "rust-analyzer.runnables.cargoExtraArgs": {
667 "markdownDescription": "Additional arguments to be passed to cargo for runnables such as tests or binaries.\\nFor example, it may be `--release`.",
674 "rust-analyzer.rustcSource": {
675 "markdownDescription": "Path to the rust compiler sources, for usage in rustc_private projects.",
682 "rust-analyzer.rustfmt.extraArgs": {
683 "markdownDescription": "Additional arguments to `rustfmt`.",
690 "rust-analyzer.rustfmt.overrideCommand": {
691 "markdownDescription": "Advanced option, fully override the command rust-analyzer uses for formatting.",
708 "regexp": "^(warning|warn|error)(?:\\[(.*?)\\])?: (.*)$",
714 "regexp": "^[\\s->=]*(.*?):(\\d*):(\\d*)\\s*$",
722 "name": "rustc-json",
725 "regexp": "^.*\"message\":{\"message\":\"([^\"]*).*?\"file_name\":\"([^\"]+).*?\"line_start\":(\\d+).*?\"line_end\":(\\d+).*?\"column_start\":(\\d+).*?\"column_end\":(\\d+).*}$",
738 "id": "ra_syntax_tree",
752 "configuration": "language-configuration.json"
757 "language": "ra_syntax_tree",
758 "scopeName": "source.ra_syntax_tree",
759 "path": "ra_syntax_tree.tmGrammar.json"
774 "name": "rustc-json",
781 "pattern": "$rustc-json"
784 "name": "rustc-watch",
792 "beginsPattern": "^\\[Running\\b",
793 "endsPattern": "^\\[Finished running\\b"
800 "id": "rust_analyzer.inlayHints.foreground",
801 "description": "Foreground color of inlay hints (is overriden by more specific rust_analyzer.inlayHints.foreground.* configurations)",
805 "highContrast": "#BEBEBE"
809 "id": "rust_analyzer.inlayHints.background",
810 "description": "Background color of inlay hints (is overriden by more specific rust_analyzer.inlayHints.background.* configurations)",
813 "light": "#11223300",
814 "highContrast": "#11223300"
818 "id": "rust_analyzer.inlayHints.foreground.typeHints",
819 "description": "Foreground color of inlay type hints for variables (overrides rust_analyzer.inlayHints.foreground)",
821 "dark": "rust_analyzer.inlayHints.foreground",
822 "light": "rust_analyzer.inlayHints.foreground",
823 "highContrast": "rust_analyzer.inlayHints.foreground"
827 "id": "rust_analyzer.inlayHints.foreground.chainingHints",
828 "description": "Foreground color of inlay type hints for method chains (overrides rust_analyzer.inlayHints.foreground)",
830 "dark": "rust_analyzer.inlayHints.foreground",
831 "light": "rust_analyzer.inlayHints.foreground",
832 "highContrast": "rust_analyzer.inlayHints.foreground"
836 "id": "rust_analyzer.inlayHints.foreground.parameterHints",
837 "description": "Foreground color of function parameter name inlay hints at the call site (overrides rust_analyzer.inlayHints.foreground)",
839 "dark": "rust_analyzer.inlayHints.foreground",
840 "light": "rust_analyzer.inlayHints.foreground",
841 "highContrast": "rust_analyzer.inlayHints.foreground"
845 "id": "rust_analyzer.inlayHints.background.typeHints",
846 "description": "Background color of inlay type hints for variables (overrides rust_analyzer.inlayHints.background)",
848 "dark": "rust_analyzer.inlayHints.background",
849 "light": "rust_analyzer.inlayHints.background",
850 "highContrast": "rust_analyzer.inlayHints.background"
854 "id": "rust_analyzer.inlayHints.background.chainingHints",
855 "description": "Background color of inlay type hints for method chains (overrides rust_analyzer.inlayHints.background)",
857 "dark": "rust_analyzer.inlayHints.background",
858 "light": "rust_analyzer.inlayHints.background",
859 "highContrast": "rust_analyzer.inlayHints.background"
863 "id": "rust_analyzer.inlayHints.background.parameterHints",
864 "description": "Background color of function parameter name inlay hints at the call site (overrides rust_analyzer.inlayHints.background)",
866 "dark": "rust_analyzer.inlayHints.background",
867 "light": "rust_analyzer.inlayHints.background",
868 "highContrast": "rust_analyzer.inlayHints.background"
872 "id": "rust_analyzer.syntaxTreeBorder",
873 "description": "Color of the border displayed in the Rust source code for the selected syntax node (see \"Show Syntax Tree\" command)",
877 "highContrast": "#b700ff"
881 "semanticTokenTypes": [
884 "description": "Style for attributes"
888 "description": "Style for boolean literals",
889 "superType": "keyword"
893 "description": "Style for builtin types",
898 "description": "Style for lifetimes"
902 "description": "Style for the self keyword",
903 "superType": "keyword"
907 "description": "Style for type aliases",
912 "description": "Style for C-style untagged unions",
916 "id": "unresolvedReference",
917 "description": "Style for names which can not be resolved due to compilation errors"
920 "id": "formatSpecifier",
921 "description": "Style for {} placeholders in format strings"
924 "semanticTokenModifiers": [
927 "description": "Style for elements within attributes"
931 "description": "Style for compile-time constants"
935 "description": "Style for control flow keywords"
939 "description": "Style for mutable bindings"
943 "description": "Style for unsafe operations"
947 "description": "Style for non-Copy lvalues consumed by method/function call"
951 "description": "Style for variables/parameters that can be used in call expressions"
954 "semanticTokenScopes": [
959 "meta.attribute.rust"
961 "function.attribute": [
962 "entity.name.function.attribute.rust"
965 "constant.language.boolean.rust"
968 "support.type.primitive.rust"
971 "storage.modifier.lifetime.rust"
974 "entity.name.type.typeAlias.rust"
977 "entity.name.type.union.rust"
980 "entity.name.type.struct.rust"
985 "keyword.controlFlow": [
986 "keyword.control.rust"
988 "variable.constant": [
989 "variable.other.constant.rust"
992 "punctuation.section.embedded.rust"
1003 "command": "rust-analyzer.syntaxTree",
1004 "when": "inRustProject"
1007 "command": "rust-analyzer.viewHir",
1008 "when": "inRustProject"
1011 "command": "rust-analyzer.expandMacro",
1012 "when": "inRustProject"
1015 "command": "rust-analyzer.matchingBrace",
1016 "when": "inRustProject"
1019 "command": "rust-analyzer.parentModule",
1020 "when": "inRustProject"
1023 "command": "rust-analyzer.joinLines",
1024 "when": "inRustProject"
1027 "command": "rust-analyzer.run",
1028 "when": "inRustProject"
1031 "command": "rust-analyzer.debug",
1032 "when": "inRustProject"
1035 "command": "rust-analyzer.newDebugConfig",
1036 "when": "inRustProject"
1039 "command": "rust-analyzer.analyzerStatus",
1040 "when": "inRustProject"
1043 "command": "rust-analyzer.memoryUsage",
1044 "when": "inRustProject"
1047 "command": "rust-analyzer.reloadWorkspace",
1048 "when": "inRustProject"
1051 "command": "rust-analyzer.reload",
1052 "when": "inRustProject"
1055 "command": "rust-analyzer.updateGithubToken",
1056 "when": "inRustProject"
1059 "command": "rust-analyzer.onEnter",
1060 "when": "inRustProject"
1063 "command": "rust-analyzer.ssr",
1064 "when": "inRustProject"
1067 "command": "rust-analyzer.serverVersion",
1068 "when": "inRustProject"
1071 "command": "rust-analyzer.toggleInlayHints",
1072 "when": "inRustProject"
1075 "command": "rust-analyzer.openDocs",
1076 "when": "inRustProject"
1079 "command": "rust-analyzer.openCargoToml",
1080 "when": "inRustProject"