-
Notifications
You must be signed in to change notification settings - Fork 29.9k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Ability to enable extensions only on specific workspaces #15611
Comments
it would be a great pleasure if it is configurable from {
"extensions.enabled": ["ms-vscode.csharp", ...enabled],
"extensions.disabled": [/*whatever extensions wanted to be*/...disabled],
} |
This is very convenient. |
After starting to use the TSLint language plugin with the TypeScript language service in VSCode, I need to ensure that the whole team disables the TSLint extension. We already use the file ".vscode/extensions.json" to promote recommend extensions for the workspace to the team. It make sense to also support disabling plugins through this file, right? |
I have exactly the same requirement. The disable issue you mentioned is tracked by #18386 |
I'd like to add my obvious notion from the duplicate I did: It should store the extensions which are selectively enabled to workspace settings file like also @zrrtcs suggested, but VSCode could also then suggest for user to install the extensions if such workspace is opened with extension list. Btw selectively disabling is a different beast, I think storing that to version control is less common. Storing enabled plugins however maybe even required for other people to open the workspace. |
Hello,
Everything could be marked eager by default to emulate current behavior and those who want a thinner profile can opt in to making more of their extensions lazy. The status bar could have an "EXT Hints" entry whenever a lazy extension would otherwise have been activated in the editor. Thank you. Good day. |
The biggest offender here is my collection of 5+ linters that are only individually useful alone on specific workspaces. Preferably I could have my personal settings disable them by default, and them enable them on a workspace level, e.g. User Settings {
"extensions.disabled": ["ms-vscode.jscs", "dbaeumer.vscode-eslint"]
} Workspace Settings {
"extensions.enabled": ["dbaeumer.vscode-eslint"]
} Then my linters are correctly enabled workspace to workspace. |
Fully agree. For me it's forcecode and typescript/angular |
I love @mherodev's option. But, I also suggest enhancing the API so that we can build extensions to do this for us? |
Can we prioritize this? VSCode is getting dog slow because of all the different types of projects |
Could not get to this in October milestone. Moving to November. |
I dont understand. Is this feature already done? |
No.. Moved to next milestone. |
This would be very important for enabling formatters like Prettier only on the right workspace folders, relevant discussion: prettier/prettier-vscode#252 |
This #37464 should be very similar to this issue |
This feature will be available in tomorrow's insiders. Please try out and give the feedback. You can now enable an extension for a workspace using following action. This action is enabled on disabled extensions. An extension can be
|
Great stuff will do tomorrow. |
Most awesome! Will try it out. This feature will help in many ways. |
@sandy081 This is absolutely great! Is there anyway to control which extensions are enabled/disabled via your workspace settings folder (.vscode)? |
@jrylan Enabled/Disabled extensions are not stored in workspace settings. Instead it is stored in local storage cache. You can manage them from the extensions view. |
Marking as verified. I used this the last couple of day when coding PowerShell with the PS extension. Liked the support! |
#2882 recently added the ability to disable extensions either globally or on specific workspaces. With these new options, it is now possible to have extensions enabled on all except some selected workspaces.
However, it currently does not seem to be possible to enable extensions on specific workspaces while disabling them on all others, effectively the inverse of what is currently implemented.
I am currently running some extensions that incorrectly activate on workspaces they should not, and there is no way around it apart from toggling the enabled/disabled state every time I open a workspace1. This is a rather tedious process. Getting the extension author to leave a marker file also pollutes the workspace, and some extension authors may not be willing to do so.
1 Disabling them on each workspace manually isn't a great solution, when I often use "Open with Code" on previously-unvisited directories. This particular offending extension ends up creating a hidden settings folder, leaving them scattered around unrelated directories.
The text was updated successfully, but these errors were encountered: