Visual Studio Code Extension to navigate through the functions, variables, and classes using quick and easy key commands similar to functionality provided by IntelliJ IDEs and Resharper
Visual Studio Code Extension to navigate through the functions, variables, and classes using quick and easy keycommands similar to functionality provided by IntelliJ IDE’s (next/previous function) or Resharper (next/previous member)
This Extension provides two key commands to navigate up and down through the members in your file.
This extension provides the following commands that can be used in keyboard shortcuts:
Command | Description | Default Shortcut |
---|---|---|
gotoNextPreviousMember.previousMember |
Move To Previous Member | ctrl+up |
gotoNextPreviousMember.nextMember |
Move To Next Member | ctrl+down |
You can customize these commands in your keybindings.json
to target specific symbol types. For example:
{
"key": "ctrl+shift+up",
"command": "gotoNextPreviousMember.previousMember",
"args": ["function", "method"]
}
This extension provides the following settings that can be configured in your settings.json
:
gotoNextPreviousMember.symbolKinds
(default: []
- all symbols included)
{
"gotoNextPreviousMember.symbolKinds": ["function", "class", "method"]
}
Available symbol types:
| Symbol Kind |
| ———————- |
| “array” |
| “boolean” |
| “class” |
| “constant” |
| “constructor” |
| “enum” |
| “enummember” |
| “event” |
| “field” |
| “file” |
| “function” |
| “interface” |
| “key” |
| “method” |
| “module” |
| “namespace” |
| “null” |
| “number” |
| “object” |
| “operator” |
| “package” |
| “property” |
| “string” |
| “struct” |
| “typeparameter” |
| “variable” |
gotoNextPreviousMember.selectEntireSymbol
(default: false
)
{
"gotoNextPreviousMember.selectEntireSymbol": true
}
true
: The entire symbol will be selected when navigatingfalse
: Only the cursor will be moved to the start of the symbolgotoNextPreviousMember.symbolPosition
(default: "center"
)
"top"
: Position the symbol at the top of the viewport"center"
: Position the symbol in the center of the viewport"bottom"
: Position the symbol at the bottom of the viewport
{
"gotoNextPreviousMember.symbolPosition": "top"
}
For the outline to work, the language support plugins need to support symbol information.
For the outline to form a tree structure, the language support plugins need to report the entire definition range as part of symbol.
See VS Code issue #34968 and language server protocol issue #132 for a discussion.
Here is a list of languages known to work with Code Outline:
Language/Format | Extension |
---|---|
C | C/C++ |
C++ | C/C++, cquery |
Docker | Docker |
HTML | Comes with VS Code |
JavaScript | Comes with VS Code |
JSON | Comes with VS Code |
Markdown | Comes with VS Code |
ruby | Ruby Symbols |
Perl | Perl |
PHP | PHP Symbols |
Python | Python |
TypeScript | Comes with VS Code |
YAML | YAML Support by Red Hat |
Please report any missing extensions and I’ll update the list.
If you are experiencing no movement upon running the command:
I have observed an issue with the Visual Studio API to return symbols from vscode.executeDocumentSymbolProvider
. One way I have found to possibly fix the issue is to disable all extensions, restart Visual Studio and then enable all extensions and restart again.
Possible Related Issue:
https://github.com/OmniSharp/omnisharp-vscode/issues/2192
See CHANGELOG.md
mishkinf
A Visual Studio Extension that provides the ability to quickly navigate back and forth between recently made edits
Enjoy!
MIT
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.