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 "enabledApiProposals": [],
28 "vscode:prepublish": "npm run build-base -- --minify",
29 "package": "vsce package -o rust-analyzer.vsix",
30 "build-base": "esbuild ./src/main.ts --bundle --outfile=out/main.js --external:vscode --format=cjs --platform=node --target=node14",
31 "build": "npm run build-base -- --sourcemap",
32 "watch": "npm run build-base -- --sourcemap --watch",
33 "lint": "tsfmt --verify && eslint -c .eslintrc.js --ext ts ./src ./tests",
34 "fix": " tsfmt -r && eslint -c .eslintrc.js --ext ts ./src ./tests --fix",
35 "pretest": "tsc && npm run build",
36 "test": "node ./out/tests/runTests.js"
39 "vscode-languageclient": "8.0.0-next.12",
41 "d3-graphviz": "^4.0.0"
44 "@types/node": "~14.17.5",
45 "@types/vscode": "~1.65.0",
46 "@typescript-eslint/eslint-plugin": "^5.10.0",
47 "@typescript-eslint/parser": "^5.10.0",
48 "@vscode/test-electron": "^2.1.1",
49 "esbuild": "^0.14.12",
52 "typescript": "^4.5.5",
53 "typescript-formatter": "^7.2.2",
58 "onCommand:rust-analyzer.analyzerStatus",
59 "onCommand:rust-analyzer.memoryUsage",
60 "onCommand:rust-analyzer.reloadWorkspace",
61 "workspaceContains:*/Cargo.toml",
62 "workspaceContains:*/rust-project.json"
87 "patternProperties": {
98 "command": "rust-analyzer.syntaxTree",
99 "title": "Show Syntax Tree",
100 "category": "Rust Analyzer"
103 "command": "rust-analyzer.viewHir",
105 "category": "Rust Analyzer"
108 "command": "rust-analyzer.viewItemTree",
109 "title": "Debug ItemTree",
110 "category": "Rust Analyzer"
113 "command": "rust-analyzer.viewCrateGraph",
114 "title": "View Crate Graph",
115 "category": "Rust Analyzer"
118 "command": "rust-analyzer.viewFullCrateGraph",
119 "title": "View Crate Graph (Full)",
120 "category": "Rust Analyzer"
123 "command": "rust-analyzer.expandMacro",
124 "title": "Expand macro recursively",
125 "category": "Rust Analyzer"
128 "command": "rust-analyzer.matchingBrace",
129 "title": "Find matching brace",
130 "category": "Rust Analyzer"
133 "command": "rust-analyzer.parentModule",
134 "title": "Locate parent module",
135 "category": "Rust Analyzer"
138 "command": "rust-analyzer.joinLines",
139 "title": "Join lines",
140 "category": "Rust Analyzer"
143 "command": "rust-analyzer.run",
145 "category": "Rust Analyzer"
148 "command": "rust-analyzer.copyRunCommandLine",
149 "title": "Copy Run Command Line",
150 "category": "Rust Analyzer"
153 "command": "rust-analyzer.debug",
155 "category": "Rust Analyzer"
158 "command": "rust-analyzer.newDebugConfig",
159 "title": "Generate launch configuration",
160 "category": "Rust Analyzer"
163 "command": "rust-analyzer.analyzerStatus",
165 "category": "Rust Analyzer"
168 "command": "rust-analyzer.memoryUsage",
169 "title": "Memory Usage (Clears Database)",
170 "category": "Rust Analyzer"
173 "command": "rust-analyzer.shuffleCrateGraph",
174 "title": "Shuffle Crate Graph",
175 "category": "Rust Analyzer"
178 "command": "rust-analyzer.reloadWorkspace",
179 "title": "Reload workspace",
180 "category": "Rust Analyzer"
183 "command": "rust-analyzer.reload",
184 "title": "Restart server",
185 "category": "Rust Analyzer"
188 "command": "rust-analyzer.updateGithubToken",
189 "title": "Update Github API token",
190 "category": "Rust Analyzer"
193 "command": "rust-analyzer.onEnter",
194 "title": "Enhanced enter key",
195 "category": "Rust Analyzer"
198 "command": "rust-analyzer.ssr",
199 "title": "Structural Search Replace",
200 "category": "Rust Analyzer"
203 "command": "rust-analyzer.serverVersion",
204 "title": "Show RA Version",
205 "category": "Rust Analyzer"
208 "command": "rust-analyzer.toggleInlayHints",
209 "title": "Toggle inlay hints",
210 "category": "Rust Analyzer"
213 "command": "rust-analyzer.openDocs",
214 "title": "Open docs under cursor",
215 "category": "Rust Analyzer"
218 "command": "rust-analyzer.openCargoToml",
219 "title": "Open Cargo.toml",
220 "category": "Rust Analyzer"
223 "command": "rust-analyzer.peekTests",
224 "title": "Peek related tests",
225 "category": "Rust Analyzer"
228 "command": "rust-analyzer.moveItemUp",
229 "title": "Move item up",
230 "category": "Rust Analyzer"
233 "command": "rust-analyzer.moveItemDown",
234 "title": "Move item down",
235 "category": "Rust Analyzer"
240 "command": "rust-analyzer.parentModule",
241 "key": "ctrl+shift+u",
242 "when": "editorTextFocus && editorLangId == rust"
245 "command": "rust-analyzer.matchingBrace",
246 "key": "ctrl+shift+m",
247 "when": "editorTextFocus && editorLangId == rust"
250 "command": "rust-analyzer.joinLines",
251 "key": "ctrl+shift+j",
252 "when": "editorTextFocus && editorLangId == rust"
257 "title": "Rust Analyzer",
259 "rust-analyzer.cargoRunner": {
265 "description": "Custom cargo runner extension ID."
267 "rust-analyzer.runnableEnv": {
279 "description": "Runnable name mask"
283 "description": "Variables in form of { \"key\": \"value\"}"
290 "description": "Variables in form of { \"key\": \"value\"}"
294 "markdownDescription": "Environment variables passed to the runnable launched using `Test` or `Debug` lens or `rust-analyzer.run` command."
296 "rust-analyzer.inlayHints.enable": {
299 "description": "Whether to show inlay hints."
301 "rust-analyzer.server.path": {
306 "scope": "machine-overridable",
308 "markdownDescription": "Path to rust-analyzer executable (points to bundled binary by default)."
310 "rust-analyzer.server.extraEnv": {
316 "markdownDescription": "Extra environment variables that will be passed to the rust-analyzer executable. Useful for passing e.g. `RA_LOG` for debugging."
318 "rust-analyzer.trace.server": {
326 "enumDescriptions": [
332 "description": "Trace requests to the rust-analyzer (this is usually overly verbose and not recommended for regular users)."
334 "rust-analyzer.trace.extension": {
335 "description": "Enable logging of VS Code extensions itself.",
339 "rust-analyzer.debug.engine": {
343 "vadimcn.vscode-lldb",
347 "description": "Preferred debug engine.",
348 "markdownEnumDescriptions": [
349 "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).",
350 "Use [CodeLLDB](https://marketplace.visualstudio.com/items?itemName=vadimcn.vscode-lldb)",
351 "Use [MS C++ tools](https://marketplace.visualstudio.com/items?itemName=ms-vscode.cpptools)"
354 "rust-analyzer.debug.sourceFileMap": {
360 "description": "Optional source file mappings passed to the debug engine.",
362 "/rustc/<id>": "${env:USERPROFILE}/.rustup/toolchains/<toolchain-id>/lib/rustlib/src/rust"
365 "rust-analyzer.debug.openDebugPane": {
366 "markdownDescription": "Whether to open up the `Debug Panel` on debugging start.",
370 "rust-analyzer.debug.engineSettings": {
373 "markdownDescription": "Optional settings passed to the debug engine. Example: `{ \"lldb\": { \"terminal\":\"external\"} }`"
375 "$generated-start": {},
376 "rust-analyzer.assist.exprFillDefault": {
377 "markdownDescription": "Placeholder for missing expressions in assists.",
384 "enumDescriptions": [
385 "Fill missing expressions with the `todo` macro",
386 "Fill missing expressions with reasonable defaults, `new` or `default` constructors."
389 "rust-analyzer.assist.importGranularity": {
390 "markdownDescription": "How imports should be grouped into use statements.",
399 "enumDescriptions": [
400 "Do not change the granularity of any imports and preserve the original structure written by the developer.",
401 "Merge imports from the same crate into a single use statement. Conversely, imports from different crates are split into separate statements.",
402 "Merge imports from the same module into a single use statement. Conversely, imports from different modules are split into separate statements.",
403 "Flatten imports so that each has its own use statement."
406 "rust-analyzer.assist.importEnforceGranularity": {
407 "markdownDescription": "Whether to enforce the import granularity setting for all files. If set to false rust-analyzer will try to keep import styles consistent per file.",
411 "rust-analyzer.assist.importPrefix": {
412 "markdownDescription": "The path structure for newly inserted paths to use.",
420 "enumDescriptions": [
421 "Insert import paths relative to the current module, using up to one `super` prefix if the parent module contains the requested item.",
422 "Insert import paths relative to the current module, using up to one `super` prefix if the parent module contains the requested item. Prefixes `self` in front of the path if it starts with a module.",
423 "Force import paths to be absolute by always starting them with `crate` or the extern crate name they come from."
426 "rust-analyzer.assist.importGroup": {
427 "markdownDescription": "Group inserted imports by the [following order](https://rust-analyzer.github.io/manual.html#auto-import). Groups are separated by newlines.",
431 "rust-analyzer.assist.allowMergingIntoGlobImports": {
432 "markdownDescription": "Whether to allow import insertion to merge new imports into single path glob imports like `use std::fmt::*;`.",
436 "rust-analyzer.cache.warmup": {
437 "markdownDescription": "Warm up caches on project load.",
441 "rust-analyzer.callInfo.full": {
442 "markdownDescription": "Show function name and docs in parameter hints.",
446 "rust-analyzer.cargo.autoreload": {
447 "markdownDescription": "Automatically refresh project info via `cargo metadata` on\n`Cargo.toml` changes.",
451 "rust-analyzer.cargo.allFeatures": {
452 "markdownDescription": "Activate all available features (`--all-features`).",
456 "rust-analyzer.cargo.unsetTest": {
457 "markdownDescription": "Unsets `#[cfg(test)]` for the specified crates.",
466 "rust-analyzer.cargo.features": {
467 "markdownDescription": "List of features to activate.",
474 "rust-analyzer.cargo.runBuildScripts": {
475 "markdownDescription": "Run build scripts (`build.rs`) for more precise code analysis.",
479 "rust-analyzer.cargo.useRustcWrapperForBuildScripts": {
480 "markdownDescription": "Use `RUSTC_WRAPPER=rust-analyzer` when running build scripts to\navoid compiling unnecessary things.",
484 "rust-analyzer.cargo.noDefaultFeatures": {
485 "markdownDescription": "Do not activate the `default` feature.",
489 "rust-analyzer.cargo.target": {
490 "markdownDescription": "Compilation target (target triple).",
497 "rust-analyzer.cargo.noSysroot": {
498 "markdownDescription": "Internal config for debugging, disables loading of sysroot crates.",
502 "rust-analyzer.checkOnSave.enable": {
503 "markdownDescription": "Run specified `cargo check` command for diagnostics on save.",
507 "rust-analyzer.checkOnSave.allFeatures": {
508 "markdownDescription": "Check with all features (`--all-features`).\nDefaults to `#rust-analyzer.cargo.allFeatures#`.",
515 "rust-analyzer.checkOnSave.allTargets": {
516 "markdownDescription": "Check all targets and tests (`--all-targets`).",
520 "rust-analyzer.checkOnSave.command": {
521 "markdownDescription": "Cargo command to use for `cargo check`.",
525 "rust-analyzer.checkOnSave.noDefaultFeatures": {
526 "markdownDescription": "Do not activate the `default` feature.",
533 "rust-analyzer.checkOnSave.target": {
534 "markdownDescription": "Check for a specific target. Defaults to\n`#rust-analyzer.cargo.target#`.",
541 "rust-analyzer.checkOnSave.extraArgs": {
542 "markdownDescription": "Extra arguments for `cargo check`.",
549 "rust-analyzer.checkOnSave.features": {
550 "markdownDescription": "List of features to activate. Defaults to\n`#rust-analyzer.cargo.features#`.",
560 "rust-analyzer.checkOnSave.overrideCommand": {
561 "markdownDescription": "Advanced option, fully override the command rust-analyzer uses for\nchecking. The command should include `--message-format=json` or\nsimilar option.",
571 "rust-analyzer.completion.addCallArgumentSnippets": {
572 "markdownDescription": "Whether to add argument snippets when completing functions.\nOnly applies when `#rust-analyzer.completion.addCallParenthesis#` is set.",
576 "rust-analyzer.completion.addCallParenthesis": {
577 "markdownDescription": "Whether to add parenthesis when completing functions.",
581 "rust-analyzer.completion.snippets": {
582 "markdownDescription": "Custom completion snippets.",
586 "body": "Arc::new(${receiver})",
587 "requires": "std::sync::Arc",
588 "description": "Put the expression into an `Arc`",
593 "body": "Rc::new(${receiver})",
594 "requires": "std::rc::Rc",
595 "description": "Put the expression into an `Rc`",
600 "body": "Box::pin(${receiver})",
601 "requires": "std::boxed::Box",
602 "description": "Put the expression into a pinned `Box`",
607 "body": "Ok(${receiver})",
608 "description": "Wrap the expression in a `Result::Ok`",
613 "body": "Err(${receiver})",
614 "description": "Wrap the expression in a `Result::Err`",
619 "body": "Some(${receiver})",
620 "description": "Wrap the expression in an `Option::Some`",
626 "rust-analyzer.completion.postfix.enable": {
627 "markdownDescription": "Whether to show postfix snippets like `dbg`, `if`, `not`, etc.",
631 "rust-analyzer.completion.autoimport.enable": {
632 "markdownDescription": "Toggles the additional completions that automatically add imports when completed.\nNote that your client must specify the `additionalTextEdits` LSP client capability to truly have this feature enabled.",
636 "rust-analyzer.completion.autoself.enable": {
637 "markdownDescription": "Toggles the additional completions that automatically show method calls and field accesses\nwith `self` prefixed to them when inside a method.",
641 "rust-analyzer.completion.privateEditable.enable": {
642 "markdownDescription": "Enables completions of private items and fields that are defined in the current workspace even if they are not visible at the current position.",
646 "rust-analyzer.diagnostics.enable": {
647 "markdownDescription": "Whether to show native rust-analyzer diagnostics.",
651 "rust-analyzer.diagnostics.enableExperimental": {
652 "markdownDescription": "Whether to show experimental rust-analyzer diagnostics that might\nhave more false positives than usual.",
656 "rust-analyzer.diagnostics.disabled": {
657 "markdownDescription": "List of rust-analyzer diagnostics to disable.",
665 "rust-analyzer.diagnostics.remapPrefix": {
666 "markdownDescription": "Map of prefixes to be substituted when parsing diagnostic file paths.\nThis should be the reverse mapping of what is passed to `rustc` as `--remap-path-prefix`.",
670 "rust-analyzer.diagnostics.warningsAsHint": {
671 "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\nand will not show up in the `Problems Panel`.",
678 "rust-analyzer.diagnostics.warningsAsInfo": {
679 "markdownDescription": "List of warnings that should be displayed with info severity.\n\nThe warnings will be indicated by a blue squiggly underline in code\nand a blue icon in the `Problems Panel`.",
686 "rust-analyzer.experimental.procAttrMacros": {
687 "markdownDescription": "Expand attribute macros.",
691 "rust-analyzer.files.watcher": {
692 "markdownDescription": "Controls file watching implementation.",
696 "rust-analyzer.files.excludeDirs": {
697 "markdownDescription": "These directories will be ignored by rust-analyzer. They are\nrelative to the workspace root, and globs are not supported. You may\nalso need to add the folders to Code's `files.watcherExclude`.",
704 "rust-analyzer.highlightRelated.references": {
705 "markdownDescription": "Enables highlighting of related references while hovering your mouse above any identifier.",
709 "rust-analyzer.highlightRelated.exitPoints": {
710 "markdownDescription": "Enables highlighting of all exit points while hovering your mouse above any `return`, `?`, or return type arrow (`->`).",
714 "rust-analyzer.highlightRelated.breakPoints": {
715 "markdownDescription": "Enables highlighting of related references while hovering your mouse `break`, `loop`, `while`, or `for` keywords.",
719 "rust-analyzer.highlightRelated.yieldPoints": {
720 "markdownDescription": "Enables highlighting of all break points for a loop or block context while hovering your mouse above any `async` or `await` keywords.",
724 "rust-analyzer.highlighting.strings": {
725 "markdownDescription": "Use semantic tokens for strings.\n\nIn some editors (e.g. vscode) semantic tokens override other highlighting grammars.\nBy disabling semantic tokens for strings, other grammars can be used to highlight\ntheir contents.",
729 "rust-analyzer.hover.documentation": {
730 "markdownDescription": "Whether to show documentation on hover.",
734 "rust-analyzer.hover.linksInHover": {
735 "markdownDescription": "Use markdown syntax for links in hover.",
739 "rust-analyzer.hoverActions.debug": {
740 "markdownDescription": "Whether to show `Debug` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
744 "rust-analyzer.hoverActions.enable": {
745 "markdownDescription": "Whether to show HoverActions in Rust files.",
749 "rust-analyzer.hoverActions.gotoTypeDef": {
750 "markdownDescription": "Whether to show `Go to Type Definition` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
754 "rust-analyzer.hoverActions.implementations": {
755 "markdownDescription": "Whether to show `Implementations` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
759 "rust-analyzer.hoverActions.references": {
760 "markdownDescription": "Whether to show `References` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
764 "rust-analyzer.hoverActions.run": {
765 "markdownDescription": "Whether to show `Run` action. Only applies when\n`#rust-analyzer.hoverActions.enable#` is set.",
769 "rust-analyzer.inlayHints.renderColons": {
770 "markdownDescription": "Whether to render trailing colons for parameter hints, and trailing colons for parameter hints.",
774 "rust-analyzer.inlayHints.maxLength": {
775 "markdownDescription": "Maximum length for inlay hints. Set to null to have an unlimited length.",
783 "rust-analyzer.inlayHints.parameterHints": {
784 "markdownDescription": "Whether to show function parameter name inlay hints at the call\nsite.",
788 "rust-analyzer.inlayHints.typeHints": {
789 "markdownDescription": "Whether to show inlay type hints for variables.",
793 "rust-analyzer.inlayHints.chainingHints": {
794 "markdownDescription": "Whether to show inlay type hints for method chains.",
798 "rust-analyzer.inlayHints.closureReturnTypeHints": {
799 "markdownDescription": "Whether to show inlay type hints for return types of closures with blocks.",
803 "rust-analyzer.inlayHints.reborrowHints": {
804 "markdownDescription": "Whether to show inlay type hints for compiler inserted reborrows.",
808 "rust-analyzer.inlayHints.lifetimeElisionHints": {
809 "markdownDescription": "Whether to show inlay type hints for elided lifetimes in function signatures.",
817 "enumDescriptions": [
818 "Always show lifetime elision hints.",
819 "Never show lifetime elision hints.",
820 "Only show lifetime elision hints if a return type is involved."
823 "rust-analyzer.inlayHints.lifetimeElisionHints.useParameterNames": {
824 "markdownDescription": "Whether to prefer using parameter names as the name for elided lifetime hints if possible.",
828 "rust-analyzer.inlayHints.hideNamedConstructorHints": {
829 "markdownDescription": "Whether to hide inlay hints for constructors.",
833 "rust-analyzer.joinLines.joinElseIf": {
834 "markdownDescription": "Join lines inserts else between consecutive ifs.",
838 "rust-analyzer.joinLines.removeTrailingComma": {
839 "markdownDescription": "Join lines removes trailing commas.",
843 "rust-analyzer.joinLines.unwrapTrivialBlock": {
844 "markdownDescription": "Join lines unwraps trivial blocks.",
848 "rust-analyzer.joinLines.joinAssignments": {
849 "markdownDescription": "Join lines merges consecutive declaration and initialization of an assignment.",
853 "rust-analyzer.lens.debug": {
854 "markdownDescription": "Whether to show `Debug` lens. Only applies when\n`#rust-analyzer.lens.enable#` is set.",
858 "rust-analyzer.lens.enable": {
859 "markdownDescription": "Whether to show CodeLens in Rust files.",
863 "rust-analyzer.lens.implementations": {
864 "markdownDescription": "Whether to show `Implementations` lens. Only applies when\n`#rust-analyzer.lens.enable#` is set.",
868 "rust-analyzer.lens.run": {
869 "markdownDescription": "Whether to show `Run` lens. Only applies when\n`#rust-analyzer.lens.enable#` is set.",
873 "rust-analyzer.lens.methodReferences": {
874 "markdownDescription": "Whether to show `Method References` lens. Only applies when\n`#rust-analyzer.lens.enable#` is set.",
878 "rust-analyzer.lens.references": {
879 "markdownDescription": "Whether to show `References` lens for Struct, Enum, Union and Trait.\nOnly applies when `#rust-analyzer.lens.enable#` is set.",
883 "rust-analyzer.lens.enumVariantReferences": {
884 "markdownDescription": "Whether to show `References` lens for Enum Variants.\nOnly applies when `#rust-analyzer.lens.enable#` is set.",
888 "rust-analyzer.lens.forceCustomCommands": {
889 "markdownDescription": "Internal config: use custom client-side commands even when the\nclient doesn't set the corresponding capability.",
893 "rust-analyzer.linkedProjects": {
894 "markdownDescription": "Disable project auto-discovery in favor of explicitly specified set\nof projects.\n\nElements must be paths pointing to `Cargo.toml`,\n`rust-project.json`, or JSON objects in `rust-project.json` format.",
904 "rust-analyzer.lruCapacity": {
905 "markdownDescription": "Number of syntax trees rust-analyzer keeps in memory. Defaults to 128.",
913 "rust-analyzer.notifications.cargoTomlNotFound": {
914 "markdownDescription": "Whether to show `can't find Cargo.toml` error message.",
918 "rust-analyzer.primeCaches.numThreads": {
919 "markdownDescription": "How many worker threads to to handle priming caches. The default `0` means to pick automatically.",
925 "rust-analyzer.procMacro.enable": {
926 "markdownDescription": "Enable support for procedural macros, implies `#rust-analyzer.cargo.runBuildScripts#`.",
930 "rust-analyzer.procMacro.server": {
931 "markdownDescription": "Internal config, path to proc-macro server executable (typically,\nthis is rust-analyzer itself, but we override this in tests).",
938 "rust-analyzer.procMacro.ignored": {
939 "markdownDescription": "These proc-macros will be ignored when trying to expand them.\n\nThis config takes a map of crate names with the exported proc-macro names to ignore as values.",
943 "rust-analyzer.runnables.overrideCargo": {
944 "markdownDescription": "Command to be executed instead of 'cargo' for runnables.",
951 "rust-analyzer.runnables.cargoExtraArgs": {
952 "markdownDescription": "Additional arguments to be passed to cargo for runnables such as\ntests or binaries. For example, it may be `--release`.",
959 "rust-analyzer.rustcSource": {
960 "markdownDescription": "Path to the Cargo.toml of the rust compiler workspace, for usage in rustc_private\nprojects, or \"discover\" to try to automatically find it if the `rustc-dev` component\nis installed.\n\nAny project which uses rust-analyzer with the rustcPrivate\ncrates must set `[package.metadata.rust-analyzer] rustc_private=true` to use it.\n\nThis option does not take effect until rust-analyzer is restarted.",
967 "rust-analyzer.rustfmt.extraArgs": {
968 "markdownDescription": "Additional arguments to `rustfmt`.",
975 "rust-analyzer.rustfmt.overrideCommand": {
976 "markdownDescription": "Advanced option, fully override the command rust-analyzer uses for\nformatting.",
986 "rust-analyzer.rustfmt.enableRangeFormatting": {
987 "markdownDescription": "Enables the use of rustfmt's unstable range formatting command for the\n`textDocument/rangeFormatting` request. The rustfmt option is unstable and only\navailable on a nightly build.",
991 "rust-analyzer.workspace.symbol.search.scope": {
992 "markdownDescription": "Workspace symbol search scope.",
993 "default": "workspace",
997 "workspace_and_dependencies"
999 "enumDescriptions": [
1000 "Search in current workspace only",
1001 "Search in current workspace and dependencies"
1004 "rust-analyzer.workspace.symbol.search.kind": {
1005 "markdownDescription": "Workspace symbol search kind.",
1006 "default": "only_types",
1012 "enumDescriptions": [
1013 "Search for types only",
1014 "Search for all symbols kinds"
1017 "$generated-end": {}
1020 "problemPatterns": [
1025 "regexp": "^(warning|warn|error)(?:\\[(.*?)\\])?: (.*)$",
1031 "regexp": "^[\\s->=]*(.*?):(\\d*):(\\d*)\\s*$",
1039 "name": "rustc-json",
1042 "regexp": "^.*\"message\":{\"message\":\"([^\"]*).*?\"file_name\":\"([^\"]+).*?\"line_start\":(\\d+).*?\"line_end\":(\\d+).*?\"column_start\":(\\d+).*?\"column_end\":(\\d+).*}$",
1055 "id": "ra_syntax_tree",
1069 "configuration": "language-configuration.json"
1074 "language": "ra_syntax_tree",
1075 "scopeName": "source.ra_syntax_tree",
1076 "path": "ra_syntax_tree.tmGrammar.json"
1079 "problemMatchers": [
1091 "name": "rustc-json",
1098 "pattern": "$rustc-json"
1101 "name": "rustc-watch",
1109 "beginsPattern": "^\\[Running\\b",
1110 "endsPattern": "^\\[Finished running\\b"
1117 "id": "rust_analyzer.syntaxTreeBorder",
1118 "description": "Color of the border displayed in the Rust source code for the selected syntax node (see \"Show Syntax Tree\" command)",
1122 "highContrast": "#b700ff"
1126 "semanticTokenTypes": [
1129 "description": "Style for < or >",
1130 "superType": "punctuation"
1134 "description": "Style for arithmetic operators",
1135 "superType": "operator"
1139 "description": "Style for attributes"
1142 "id": "attributeBracket",
1143 "description": "Style for attribute invocation brackets, that is the `#[` and `]` tokens",
1144 "superType": "punctuation"
1148 "description": "Style for bitwise operators",
1149 "superType": "operator"
1153 "description": "Style for boolean literals",
1154 "superType": "keyword"
1158 "description": "Style for { or }",
1159 "superType": "punctuation"
1163 "description": "Style for [ or ]",
1164 "superType": "punctuation"
1167 "id": "builtinAttribute",
1168 "description": "Style for builtin attributes",
1169 "superType": "attribute"
1172 "id": "builtinType",
1173 "description": "Style for builtin types",
1178 "description": "Style for character literals",
1183 "description": "Style for :",
1184 "superType": "punctuation"
1188 "description": "Style for ,",
1189 "superType": "punctuation"
1193 "description": "Style for comparison operators",
1194 "superType": "operator"
1197 "id": "constParameter",
1198 "description": "Style for const generics"
1202 "description": "Style for derives",
1203 "superType": "attribute"
1207 "description": "Style for .",
1208 "superType": "punctuation"
1211 "id": "escapeSequence",
1212 "description": "Style for char escapes in strings"
1215 "id": "formatSpecifier",
1216 "description": "Style for {} placeholders in format strings"
1220 "description": "Style for labels"
1224 "description": "Style for lifetimes"
1228 "description": "Style for logic operators",
1229 "superType": "operator"
1233 "description": "Style for the ! token of macro calls",
1234 "superType": "punctuation"
1238 "description": "Style for operators",
1239 "superType": "punctuation"
1242 "id": "parenthesis",
1243 "description": "Style for ( or )",
1244 "superType": "punctuation"
1247 "id": "punctuation",
1248 "description": "Style for generic punctuation"
1251 "id": "selfKeyword",
1252 "description": "Style for the self keyword",
1253 "superType": "keyword"
1256 "id": "selfTypeKeyword",
1257 "description": "Style for the self type keyword",
1258 "superType": "keyword"
1262 "description": "Style for ;",
1263 "superType": "punctuation"
1267 "description": "Style for type aliases",
1272 "description": "Style for C-style untagged unions",
1276 "id": "unresolvedReference",
1277 "description": "Style for names which can not be resolved due to compilation errors"
1280 "semanticTokenModifiers": [
1283 "description": "Style for async functions and the `async` and `await` keywords"
1287 "description": "Style for elements within attributes"
1291 "description": "Style for locals whose types implements one of the `Fn*` traits"
1295 "description": "Style for compile-time constants"
1299 "description": "Style for locals that are being consumed when use in a function call"
1302 "id": "controlFlow",
1303 "description": "Style for control-flow related tokens, this includes the `?` operator"
1307 "description": "Style for names resolving to a crate root"
1311 "description": "Style for doc-string injected highlighting like rust source blocks in documentation"
1314 "id": "intraDocLink",
1315 "description": "Style for intra doc links in doc-strings"
1319 "description": "Style for items that are defined outside of the current crate"
1323 "description": "Style for mutable locals and statics as well as functions taking `&mut self`"
1327 "description": "Style tems that are from the current crate and are `pub`"
1331 "description": "Style for locals behind a reference and functions taking `self` by reference"
1335 "description": "Style for associated trait items"
1339 "description": "Style for unsafe operations, like unsafe function calls, as well as the `unsafe` token"
1342 "semanticTokenScopes": [
1347 "meta.attribute.rust"
1350 "constant.language.boolean.rust"
1353 "support.type.primitive.rust"
1356 "constant.other.caps.rust"
1359 "entity.name.type.enum.rust"
1361 "formatSpecifier": [
1362 "punctuation.section.embedded.rust"
1365 "entity.name.function.rust"
1368 "entity.name.type.trait.rust"
1371 "keyword.other.rust"
1373 "keyword.controlFlow": [
1374 "keyword.control.rust"
1377 "storage.modifier.lifetime.rust"
1380 "entity.name.function.macro.rust"
1383 "entity.name.function.rust"
1386 "entity.name.type.struct.rust"
1389 "entity.name.type.declaration.rust"
1392 "entity.name.type.union.rust"
1395 "variable.other.rust"
1397 "variable.constant": [
1398 "variable.other.constant.rust"
1409 "command": "rust-analyzer.syntaxTree",
1410 "when": "inRustProject"
1413 "command": "rust-analyzer.viewHir",
1414 "when": "inRustProject"
1417 "command": "rust-analyzer.expandMacro",
1418 "when": "inRustProject"
1421 "command": "rust-analyzer.matchingBrace",
1422 "when": "inRustProject"
1425 "command": "rust-analyzer.parentModule",
1426 "when": "inRustProject"
1429 "command": "rust-analyzer.joinLines",
1430 "when": "inRustProject"
1433 "command": "rust-analyzer.run",
1434 "when": "inRustProject"
1437 "command": "rust-analyzer.debug",
1438 "when": "inRustProject"
1441 "command": "rust-analyzer.newDebugConfig",
1442 "when": "inRustProject"
1445 "command": "rust-analyzer.analyzerStatus",
1446 "when": "inRustProject"
1449 "command": "rust-analyzer.memoryUsage",
1450 "when": "inRustProject"
1453 "command": "rust-analyzer.reloadWorkspace",
1454 "when": "inRustProject"
1457 "command": "rust-analyzer.reload",
1458 "when": "inRustProject"
1461 "command": "rust-analyzer.updateGithubToken",
1462 "when": "inRustProject"
1465 "command": "rust-analyzer.onEnter",
1466 "when": "inRustProject"
1469 "command": "rust-analyzer.ssr",
1470 "when": "inRustProject"
1473 "command": "rust-analyzer.serverVersion",
1474 "when": "inRustProject"
1477 "command": "rust-analyzer.toggleInlayHints",
1478 "when": "inRustProject"
1481 "command": "rust-analyzer.openDocs",
1482 "when": "inRustProject"
1485 "command": "rust-analyzer.openCargoToml",
1486 "when": "inRustProject"
1491 "command": "rust-analyzer.peekTests",
1492 "when": "inRustProject",
1493 "group": "navigation@1000"