-
Notifications
You must be signed in to change notification settings - Fork 30.1k
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
Add support for additional global config files (in addition to settings.json) #17634
Comments
@archshift I'm curious what settings differ across your Mac and Linux configs? Another potential solution is to have /cc @sandy081 @joaomoreno |
@Tyriar it's not so much about OSs and more about computers. Let's say I have a laptop and a desktop (both Windows, for instance), and the two computers have different screen sizes/resolutions. I might want to set This also applies to extensions. If I'm using the Rust extension, which has options like |
In our case, this would be on the workspace level: we'd commit BTW this is a common issue with IDEs. We commonly commit something like |
@Tyriar The requested feature is also useful for maintaining separate override configs for home vs. work, or for each client. For example, different default tab size and linter settings. Hard-coding it to only split based on platform would be too restrictive. |
@mikelward Sounds as if workspace settings might be of better use to you. |
This suggestion would be useful to us even in the workspace settings alone. Some settings could be shared (commited) and some could be personal or system specific. I have workspaces on multiple platforms and sometimes need to tweak local settings per workspace, e.g. terminal settings, EOL settings, run code settings, file exclude settings, git settings, etc. |
Hope this feature will be imported, including |
@philipmat Here's my breakdown: Doing it using workspace settings would mean I'd need to copy my settings for every one of hundreds of projects. And I wouldn't be allowed to check in vscode-specific configs into my projects, so I'd have to re-create them every time I made a new checkout. Sure I could script it, but supporting a "local" include file makes way more sense IMHO. |
Hi, are there any updates on this? thanks! |
@mikelward Thanks for giving the breakdown. Trying to understand why you did not want to keep tabSize... settings in global settings? Are you syncing global settings between your personal and company machine? If you are using any external tool/extension for syncing, I think the easier and better solution could be that if the tool can provide an option to sync only a list of settings you would like? |
To all those who are requesting for local workspace settings, here is the issue #40233 that tracks it. This issue does not cover it. |
@sandy081 I personally would like to sync most of my settings with nix home-manager. So I won't even be able to just modify the font size for a moment because the config file is read-only. Thus, I would need a "global global" config files (which is managed by nix), a "global" config file (for this machine, that can override the "global global" settings") and then, further down the road I have my project-specific settings. |
In my case, it is Dropbox that is syncing my settings files from one machine to the next. Dropbox is of course not aware of VSCode settings, it's just syncing the files. I then point a symlink to that Dropbox file and thus when I updated a VSCode setting on one machine, I don't have to remember to update it on another machine (I have 4 development machines not counting terminal servers). So in my case, it really isn't possible for the external syncing tool to do this separation of settings. For my use case, it is generally path settings that differ from one machine to the next. For instance, the paths I use when on Windows are of course drastically different than the paths I use on Linux. They can also be different between two different Windows machines if say there is a path to my user folder and the user is different on those two machines. As it is now, the only way I can handle this situation is to have a full complete settings file for each of my machines that only differ with the paths used. Which means for every setting change I make, I have to also make it in every machine specific settings file. This of course is not ideal and very problematic. So much so that on my Linux machine I just deal with having a few broken extensions rather than trying to keep multiple files up to date. On my Windows machine I can get around some of this by just having more symlinks (i.e. C:/Users/WorkUser -> C:/Users/HomeUser). However, that only works on some of the paths and others I just deal with it not working. |
Hey there! Just 👍 voice that "workspace settings" is not the same as "multiple global (non-workspace-specific) settings files." One mention came up of 'making the syncing tool' understand the settings file, and explicitly decide which settings to sync and which not to: well, for most of us I daresay, Git is the syncing tool. And I really strongly doubt Git is going to land explicit support for VScode settings-files. :P At the moment, if you don't want all settings synced into your dotfiles repository, you're a bit SOL. I, for instance, have to use interactive-stage tooling, and simply leave parts of the changes uncommitted (theme, which I change often and never have any desire to sync; font-size and such, some machine-specific PATHs ...), and just deal with the fact that since I started to use VScode, my dotfiles directory is never going to be in a clean state anymore. 0= Anyway! Just, again, 👍 for this as an actual feature; it is not something that's easily work-around-able! |
I like to have this feature as well as I keep my settings.json in git and in the open |
I find this feature useful to me for keeping a local configuration. A potential issue is how do we merge them? Consider this in {
"foo": [1, 2],
"editor.includeConfig": "settings.local.json"
} and following in {
"foo": [4, 5]
} Do we expect |
You can ignore these settings from sync. Are you expecting more? |
See my previous comment: #17634 (comment) see my usage here: https://github.com/casz/dotfiles/blob/master/vscode/settings.json |
Ok. |
@sandy081 As I understand it, this issue is about supporting machine- or environment-specific configurations. If this is part of the sync feature, then great, otherwise I think this issue is still relevant. (It seems like this might be covered by #89627 and/or #88625 but I'm not sure whether they will actually be part of the sync feature on not.) |
We already support ignoring settings to sync. You can select a setting and ignore it from sync and this setting will not be synced. Lets say if you ignore #89627 is different and more advanced and #88625 is for platform specific extensions. |
Oh great, that certainly sounds sufficient for my use case! Do you have an issue describing that feature? e.g. what the syntax is? I couldn't find it. |
Yes. I'm syncing all my configurations in a shared dotfile git environment. |
@ithinkihaveacat We are planning to preview it for next 1.44.0-insiders release and you can find this in the release notes then. @phryneas I see your reason of using separate files when you are using external sync feature like dotfiles repo. Given that we support this in OOB sync feature, and I am not sure how many users engaged in this issue might have this issue I would close this issue and create a fresh issue for those who still want this? |
@sandy081 I would recommend leaving this issue open until the OOB sync feature is released, at which time everyone on this thread can examine whether it works for them. |
Sure. We are planning to launch settings sync preview from 1.44 insiders which is planned to release on next Monday. Will update you once it is released. Would be happy to get the feedback. |
All, As you know from our latest release that Settings Sync feature is previewed in insiders. So, please try out the feature using our insiders and provide us with the feedback - https://code.visualstudio.com/insiders/ |
I am a bit overwhelmed by the huge power of Settings Sync. After a quick overview I am impressed but also a bit sad thinking that a more basic solution might not be implemented. I tend to sync all my configuration and dotfiles across 4 computers: 1 Linux, 1 Mac and 2 windows. Windows is the main problem because I cannot symlink config files into my unique repository, so something as basic as load, extend or just stack settings from a folder (like vim runtimepath) would help a lot. Also when working on multiple project/teams, a good old app folder config that one can diff and version control is really nice. Even environments where an external internet connection is not possible for legal/certification reasons. Requiring a Microsoft Account (or a GitHub one as the extension needs) seems a bit overkill. I am sure it will cover most of my pain points, but please consider implementing too the more basic solution that does not depend so much on capital/human investment. It easier to trust on solutions with low maintenance demands. |
I hope this use case won't be overlooked as it is not covered by Settings Sync. It's very unfortunate that you cannot share |
Our team also needs the ability to share per folder settings, but with the ability to override them locally. e.g. when all team members except one agree with some settings. Currently we haven't optimal solution when everyone is happy and productive. |
/duplicate From the description of the issue - it seems to be similar to #5595. Hence marking it as a dup. |
Right, got it. |
+1 to this as well, except for a slightly different use case, when using something like https://github.com/antfu/vscode-file-nesting-config the settings file become very big to parse and it slows down the whole thing even u try to just open the settings editor. another example would be something like https://github.com/shanalikhan/code-settings-sync in case u have settings for multiple machines/hosts u use ex.
there are amillion other extension that can quickly bloat the settings file & separating the config between multiple files will surely make things easier to organise & quicker for the editor. btw this is already possible with theme files ex. |
Hi, |
It seems this is a duplicate of following features we already have or working on
Hence closing this as duplicate of all these features. |
It would be very helpful for somebody attempting to sync config files between multiple machines if VSCode supported some system for having multiple config files included at a time.
Benefits:
Imagine a config folder structure like this on a developer's mac:
And then like this on a developer's linux desktop:
Using symlinks, then, a developer would be able to have specialized configuration files for each computer, while keeping the vast majority of options synced between both.
Implementation:
I can think of two simple ways to implement this with as little friction as possible.
editor.includeConfig
option in the mainsettings.json
This might be a JSON array, with support for various different config files. It could also just be a single field.
Whether or not the option should be recursive is up to the VSCode team.
settings[.foo].json
and includes those.Conflicts:
If going with option (1) above, conflicting config entries should take precedence the later they appear in the
includeConfig
array.If going with option (2), the main
settings.json
file should take precendence.The text was updated successfully, but these errors were encountered: