Table of Contents
- The Visual Studio Code Roadmap 2020
The Visual Studio Code Roadmap 2020
As 2019 is coming to an end, now is the time to look towards the future. We typically look out 12-18 months and we establish topics we want to work on. We don't start with our roadmap on a blank sheet. We develop it based on our last roadmap, the findings we made over the course of the last year, and of course what we heard from you in issues, in face-to-face discussions, stack overflow, and twitter.
When we execute on our roadmap, we keep learning and our assessment of some of the topics listed changes. As a result, we may add or drop topics as we go. In 12 months from now, we then come together to develop the next roadmap.
We describe some initiatives as "investigations" or "explorations" which means our goal in the next few months is to better understand the problem and potential solutions before scheduling actual feature work. Once an investigation is done, we will update our plan, either deferring the initiative or committing to it.
As always, we listen to your feedback and adapt our plans if needed.
Legend of annotations:
Mark | Description |
---|---|
bullet | work not started |
check mark | work completed |
🏃 | on-going work |
💪 | stretch goal |
🔴 | missing link |
Themes
Our roadmap covers the broadly the following themes:
- Become the best editor for anyone who relies on accessibility features
- Improve performance, scalability, and security of VS Code and its extensions
- Tackle some of the most wanted and most emotional user features
- Polishing and a constant trickle of design refreshments
- Incrementally improve already existing features
- Responsibly enable extensions that have broader extensibility requirements
- Tackle a couple of big rocks that push the boundaries of what VS Code can do
Fundamentals
- 🏃 Make VS Code an outstandingly accessible developer tool. We'll engage and work with our community to get input and guidance, and we need you to keep us honest.
- Improve support for RTL languages.
- 🏃 Keep start-up times within a predictable and suitable range for users across all platforms and improve the overall performance for large workspace:
- Load less code on start-up and investigate improving the workbench restoration time by expanding on the rapid render approach.
- Continuously monitor the size of the VS Code download to ensure it downloads in seconds no matter where you are.
- Improve VS Code performance in large workspaces
- 🏃 Investigate 'working sets' of files and folders in the file explorer
- Provide guidance to users how to configure VS Code
- Improve Open File / Quick Pick performance
- 🏃 Make VS Code more secure by running renderer processes without access to
node
APIs.
Workbench
- Workbench layout
- Support for detachable workbench parts is our most upvoted feature request which due to architectural issues is challenging to implement. We will explore how we can work around this limitation. This investigation will focus on detaching terminals (2nd most upvoted feature request) and editors.
- Allows to move views between the panel and sidebar.
- Support a more flexible workbench layout such as allow sidebars on the left and the right. For example, you could have your outline on the right and the file explorer on the left.
- Investigate how to safely provide richer customizability in the workbench
- Support custom editors.
- Investigate custom views based on
WebViews
.
- Support to configure workbench font and font size
- Broaden support to customize the UI, e.g. menu bar, context menus.
Settings
- Support synchronizing settings and extensions across VS Code installations on different machines.
- 🏃 In the settings editor, provide high-fidelity support for additional settings types, such as colors.
- Provide a dedicated theme customization editor.
- Support to synchronize settings between the insider and stable versions of VS Code
Search
- Show search results not only in the side bar or a panel, but also in an editor. This allows users to work with multiple search results and to see additional context for each match.
UX
- Continue to incrementally improve presentation and behavior across the board. Examples include:
- 🏃 Harmonize hovers, completion items, completion item details
- 🏃 Welcome page
- Use tabs instead of the terminal dropdown
- 🏃 Revisit/review the first run experience for VS Code as well as newly installed extensions. For example, we want to reduce the number of notifications that are shown.
- 🏃 Touch and mobile support for VS Code in the browser
- Investigate how users can express what they want to use VS Code for after they installed it. For example, a user wants to develop a website with a Go backend, VS Code should provide light-weight guidance to get all the right extensions and configure them appropriately.
Editor
- 🏃 Notebooks (for example Jupyter) have become a popular means in data science and education and are making their way into every corner of development. We'll explore how VS Code and the Monaco Editor can provide a rich notebook experience (deep language services, light-weight/simple debugging).
- Investigate isolating the editor from misbehaving grammars
- Investigate support for semantic coloring
- Investigate how to simplify the maintenance of textmate grammars
- Expand 'inline' experiences
- Inset editing
- Inline errors
- 🏃 Richer minimap
- 🏃 Inline values (on by default, see debugging)
- Smarter indent support (e.g. for Python)
- Prevent tooltips from getting into your way when editing
- Support word-wrap in the diff editor
Languages
- Enable programming language extensions to provide support for call hierarchies.
- Enable programming language extensions to provide support for type hierarchies.
- Improve support for workspace-level edits (an semantic unit comprised of name, location, and content manipulations across multiple files)
- 🏃 Enable language extensions to participate in workspace edits such as rename or move.
- Enable an one-step undo of complex workspace edits.
- Investigate how a user can preview workspace edits (e.g. preview the changes of a rename refactoring).
- Incrementally improve support for nested languages. This will be code changes on our side as well as samples and documentations.
TypeScript
We will continue to collaborate deeply with the TypeScript team to deliver the richest code editing, navigation, and understanding experiences for both TypeScript and JavaScript. see also the TypeScript roadmap. One focus item will be to show the errors and warnings for the entire project(s) in your workspace.
HTML/CSS
- Provide a live preview.
SCM
- 🏃 Investigate synergies between the core git support and GitLens
- Provide an overall improved GitHub integration, e.g. we'll make it easier to hover over issue URL in your code or associate a GitHub issue with your commit.
- Provide full merge support (3-way)
- Investigate support for showing a local history of a file and folder and combine that with the git history
- Provide a contributable timeline view
- Investigate combining local history with other events such as successful test runs or refactorings
Debug
- 🏃 Leverage language services to improve debug experience. For example, improve hovering and inline values by leveraging the knowledge about the programming language so that the
Inline Values
feature can be enabled by default - Provide improved 'full stack' debugging, i.e. combined
node
(server) andchrome
(client) debugging.
Testing
- 🏃 Investigate how VS Code can improve the testing support. Several extensions are already providing testing support, explore what APIs/UIs could be added to improve these testing extensions and the test running experience.
Install
- Investigate migrating to the MSIX installer on Windows.
Terminal
- Investigate how to persist integrated terminal sessions across window reloads and, for remote scenarios, application restarts.
- Investigate how to support problem matchers to run in any internal terminals
Extensions
-
Extension Acquisition
- Revisit how users find and install extensions including a simple text-based approach
- Make it easier for users to pick and choose which functionality they want from extensions packs.
- Improve the recommendation system, e.g., allow users to ask for recommendations based on their prior use of VS Code.
- Add support to only activate signed extensions (see Extension Authoring).
-
Extension Management
- Make the consumption of extensions more secure and improve the process for how we handle malicious extensions.
- Show runtime information for an extension (activation state, performance, error logs)
-
Extension Authoring
- 🏃 Provide clear guidance to extension authors for how to structure their functionality so that their users can get as little or as much functionality as they want. For example, ensure text editor lovers can get Python language support without too much overhead.
- 🏃 Provide an integrated 'Welcome' experience for extensions.
- 🏃 Investigate how to effectively inform users about new features provided by an extension update.
- 🏃 Investigate into play grounds like the VS Code playground (
Help>Interactive Playground
) for extensions. - Provide extensions more control over the sequence and grouping of their settings in the settings editor, e.g., support to group commonly used settings.
- Give extensions more realtime insights into how user configured them, e.g. the user hides the custom tree view your extension contributes from the explorer.
-
Extension Publishing
- ✋ Work with the marketplace to allow platform specific flavors of extensions.
- ✋ Support publishing of signed extensions.
- ✋ Add support for verified publishers.
- ✋ Investigate providing a GitHub action for publishing to the marketplace.
Contributions to VS Code Extensions
Our teams contributes to a number of extensions that are available in the market place.
Our main focus will be on the following extensions:
- 🏃 VS Code Remote
- 🏃 GitHub Pull Request extension and related extensions
- 🏃 Azure Account extension
- 🏃 Vue extension
- 🏃 GitLens extension
We will continue to maintain the following extensions:
We will investigate into improving the performance of popular extensions that not performing as well as users expect
Contributions to Underlying Components and Technologies
VS Code is made possible through a wide range of technologies. Below are examples of technologies in which we are particularly active.
Language Server Protocol
- 🏃 Continue to refine and improve the Language Server Protocol with support from the community.
- 🏃 Continue to refine and improve the Language Server Index Format with support from the community.
Debug Adaptor Protocol
- 🏃 Continue to refine and improve the Debug Adapter Protocol with support from the community.
- 🏃 Expose more UI for DAP features that are currently not surfaced in the VS Code debugging UI. This includes moving the loaded scripts UI into the core.
xterm.js
- 🏃 Provide ongoing improvements to
xterm.js
for performance, stability, and maintainability
Engineering
- Migrate from
tslint
toeslint
. Tslint will be deprecated. - Improve the built-in issue reporter, e.g., support to paste/attach images.
- Implement tooling that allows us to detect issues in which emotions fly high.
- 🏃 Improve our "smoke" tests and revisit the current approach on how we implement them.
- Investigate automating how we sanity check all our binaries right before we release.
- 🏃 Investigate moving our GitHub bots to GitHub actions.
- 🏃 Improve our GitHub issue bots, examples:
- reject invalid incoming issues automatically
- 🏃 make it easier to move issue to extension repositories
- 🏃 automate training of our classification bot
Explorations
- Explore support to synchronize more state when opening the same folder in different VS Code installs such as untitled files, open files, focussed editor.
- Explore how to better provide support for low-end devices.
- 🏃 Explore how to support new user in learning VS Code (interactive exploration mode, videos)
- Explore how to make it easier to show, tell, and share your VS Code customizations.
- 🏃 Explore how to support trying out VS Code for a particular language or technology stack without any local installation. For example, 'Debug Java code in less than 1 minute'.
Documentation
- 🏃 Refresh all of our dated overview videos.
- Provide translated documentation for major user groups such as Mandarin, Korean, Spanish, Portuguese, French. Noe: the list of languages might change.
Community Support
- 🏃 We'll continue our work on our GitHub bots that enable members of our community give us a hand triaging and resolving issues.
Summary
These are examples of some of the work we will be focusing on in the next 12-18 months. We continuously tune the plan based on feedback and we will provide more detail in each of our monthly iteration plans. We will develop our next roadmap in around 12 months from now. Please follow along and let us know what you think!
Project Management
- Roadmap
- Iteration Plans
- Development Process
- Issue Tracking
- Build Champion
- Release Process
- Running the Endgame
- Related Projects
Contributing
- How to Contribute
- Submitting Bugs and Suggestions
- Feedback Channels
- Source Code Organization
- Coding Guidelines
- Testing
- Dealing with Test Flakiness
- Contributor License Agreement
- Extension API Guidelines
- Accessibility Guidelines
Documentation