-
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
Profiles feature request: Ability to apply user settings across all profiles #176813
Comments
I came here to report the same issue, although from the direction I come from I feel it would make more sense to solve it by just applying the profile settings.json on top of the user settings. So when switching to a profile it would combine the default settings with the user settings, as usual, and then just smack the profile/settings.json on top, before actually committing the settings-object to vscode. In case a profile wants to revert a user setting to the default value I suppose the property could just be set to The reason I came here was |
/duplicate |
Thanks for creating this issue! We figured it's covering the same as another one we already have. Thus, we closed this one as a duplicate. You can search for similar existing issues. See also our issue reporting guidelines. Happy Coding! |
@sandy081 - That issue doesn't mention the challenges with getting/setting values from multiple files. It seems that item (written pre-Profiles) assumes that we're importing/grafting a file's contents on top of the main one. Would that presume that Profiles keep working how they do today, and the user would manually curate their own personal settings file(s)? Or would that proposal have a context for layering what we now call "Profiles" on top of each other? And is the scope of that issue expected to expand to include settings UI support as well? For ref: |
@aaronsteers Thanks for the input and also for the proposal. Initially I felt that your requirement is similar to extending from default profile. It seems you have two basic requirements
There is already feature request for 2nd. I will track this as a feature request for 1st. Since profiles feature is a very new one, we are trying to collect feedback before adding more features. This issue, 157492 and 15909 are most asked and very much related to each other. We want to digest all requirements around this and come up with a good solution. Thanks. |
@sandy081 That's the problem I've encountered with today. It's awful to install a generally-used extension to all my profiles.
The Profiles feature is what I'm eagerly desiring for a long period. I think the improvement of this feature would make it easy to config a new develop environment. I sincerely hope it'll be better in the future release. Thanks again. |
This is what we do internally when you install same extension in multiple profiles. |
@sandy081 With this feature installed, when I customize my settings through the plain text settings.json, I still need to go to the Settings UI page and click the button? |
@Eitheages
Not needed, underneath there will be a new setting ( |
Agreed that profile inheritance gives much more flexibility and it is a powerful feature that needs considerable effor to design and implement with good UX. I would not prefer to make this one solution of all features. Its best if some small features can be supported independently and this is one of them. @brettcannon There is no hierarchy supported here. A setting to application settings list will be applied to all profiles and cannot be overridden at profile level. |
So I can't set a default indentation level for e.g. Python files, but then override that in a profile that is specific to a workspace/repo? |
Thats correct |
I'm not sure how a settings block that applies to all profiles actually helps. Profile inheritance seems like it'd be much more useful and solve several outstanding issues. It also seems relatively straightforward to design, especially since there are extensions in the marketplace that have already solved the problem in an elegant, usable way. Can you help shed some light on why the path that you've outlined is better? |
These two are different requirements. Inheritance is much a bigger feature than this. Why would I like to inherit if I want just one setting to be applied across all profiles? |
IMO, it's extremely rare for one setting to be the same across all profiles. Inheritance solves both cases though. |
I think previous posters have demonstrated that it's not a rare or unusual use-case to share settings between profiles. Not just shared plugins, but settings that configure the workspace, like Some plugins just make more sense if they're 'global' by default, e.g. Project Manager, or themes. The statusbar-commands plugin differentiates between global/user settings and profile settings. It applies settings under |
Why should every plugin implement that differentiation when there's a relatively straightforward way of having VS Code itself handle it? Profile inheritance solves both use cases: config applied across all profiles and config that is only set in one profile (that is either not set in the base profile or is overriding the base profile). |
As mentioned also in: #15909 (comment)
The release of Profiles feature is exciting but I can't figure out how/if I can use this for "mode switching" in my own dev experience.
I am having a hard time making these work for the named application here (from the docs):
I'm
starting tohoping to use Profiles to keep my IDE more lean and focused - for instance one profile for Python development, one for Terraform development, and one for Data Analysis. But what I'm finding is that the isolation between profiles is a bit too strong in cases. Perfect example is my use of Code Spell Checker - I have built a usage pattern of always adding exceptions/additions to the default spell check dictionary to my user settings - these follow me everywhere. But now, if I correctly understand the behavior of Profiles feature, these settings won't follow me to other profiles.Now with profiles, I think I'm going to end up repeating the same changes, and having to deal with drift across these profiles when there are some settings I just want to have permanent.
I don't know if we're going to get updates to Profiles feature that will allow some settings to follow us across profiles. The example above for the spell check dictionary, but also applies for extension settings like, ChatGPT, Live Share, etc. I think the common theme here is that certain settings and extensions are personal and some are modal.
Proposal
Application of two profiles
I think this basically requires two layers of profiles to be active at the same time:
personal
profile: the "base" default/global/personal profilemodal
profile: the "applied" profile like "Python", "Terraform", etc. - which are focused on what kind of work I'm trying to get done in the moment.Handling global settings
Basically, there are certain plugins I'd like to treat as "global" or "personal" and those would ideally have these behaviors:
Handling extension-managed writes when 2 profiles exist
I believe this algorithm is sensible:
{my-ext}.{my-setting}
, first check if a same-named setting exists in the personal profile. If yes, update it there.{my-ext}
extension has any existing config in the modal profile, set the new setting there, adjacent to existing settings. (We presume the setting is modal until the user has moved it to their global profile.){my-ext}
extension has any existing config in the personal profile, set the new setting there, adjacent to existing settings.These, I think, are sensible default behaviors - specifically because:
Handling settings resolution ("read" behavior)
When reading settings, personal profile always has precedent. Modal profile has lower precedent.
Impact on "imported" profiles, or profiles gotten from other users
This behavior nicely keeps a user's own settings as overrides when importing community-created profiles.
E.g. If I import a "Python" profile from my community, I don't lose my custom Live Share settings upon import.
Rendering in VS Code Settings UI
This would have a 3-level interface. Instead of "User" meaning "Profile" in the screenshot below, there would be separate tabs for
User | Profile | Workspace
:Since "User" has already come to mean "profile", the word "Personal" might work better:
Personal | Profile | Workspace
might be even more clear.Better yet: naming the profile in the tab makes it super obvious what profile is applied and where setting values will be stored:
Personal | 'Python' Profile | Workspace
. This is nice because the answer to "which should I use" becomes much more intuitive.Education
Probably, this is most simply communicated to users by distinguishing between "User Settings" or "Personal Settings" and "Profile Settings".
The algorithms for how settings are read and written can be more described concisely as:
Is there an option to do something like this today? It is being considered for future development?
I checked the Profiles docs and could not find any mention of handling for profile overlays.
The text was updated successfully, but these errors were encountered: