138

I've just been through the VS Code installation process twice. The initial install is quick and painless (as is the editor itself), but I have had to remember the list of extensions I installed and am installing new ones a great rate.

With Sublime Text, I'd just copy a settings file to another PC and could auto-install any workflow dependencies that way, but what is the approach with VS Code?

Can I just back up a JSON 'settings' file or similar so that I can easily re-create my working environment (complete with extensions)?

Astravagrant
  • 2,215
  • 3
  • 18
  • 21
  • Just like other cross-platform editors, simply copy the `.vscode` directory to the new user environment's home directory. – JW0914 Feb 07 '20 at 13:17
  • 1
    You may be able to use the new preview feature [Settings Sync](https://code.visualstudio.com/docs/editor/settings-sync) to accomplish what you are trying to do. It will let you use a GitHub account or Microsoft account to store your VS Code settings (including preferences, extensions, etc) across machines. – Joel Glovier Jun 04 '21 at 18:42

5 Answers5

95

I've submitted an answer for this on the main StackOverflow site - pasted below for context

I've need to do this myself a few times - especially when installing on another machine.

Depending on your platform VS Code looks for your extensions folder (.vscode/extensions) on one of the following paths:

  • Windows: %USERPROFILE%\.vscode\extensions
  • Mac: ~/.vscode/extensions
  • Linux: ~/.vscode/extensions

That should show you a list of the extensions

I've also had success using Visual Studio Code Settings Sync Extension to sync settings to GitHub gist

EDIT: In the lastest release of VSCode (May 2016) it is now possible to list the installed extension in the command line

code --list-extensions
Amit Yadav
  • 103
  • 3
MarkP
  • 1,066
  • 8
  • 5
46

So as treehead's edit or MarkP's answer showed you can now list all extensions installed so the way to install that list of extensions would be to:

code --list-extensions >> vs_code_extensions_list.txt

Transfer the newly created file to the machine that you want to install those extensions to. On that machine you would:

cat vs_code_extensions_list.txt | xargs -n 1 code --install-extension

Which will then go through each extension in that file and install the extension.

If you want a clean install (AKA remove all existing extensions on that machine) you could run this before you install the new extensions (otherwise you will remove those new extensions too). BE CAREFUL as this will remove all extensions in VS Code:

code --list-extensions | xargs -n 1 code --uninstall-extension
NickTheSick
  • 561
  • 4
  • 2
  • Tried, got this error message: "xargs : The term 'xargs' is not recognized as the name of a cmdlet, function, script file, or operable program." ? – Nicholas Petersen Jul 15 '19 at 18:44
  • 7
    @NicholasPetersen That's for Linux. On windows: `get-content c:\exportedlist.txt | % { code --install-extension $_ }` – Jason Clement Oct 18 '19 at 21:06
  • Here is how to uninstall only exts missing from the file: `code --list-extensions | diff - vs_code_extensions_list.txt | grep '^<' | sed 's/' | sed 's/>/code --install-extension' | eval`. – DUzun Mar 20 '21 at 23:12
38

Here's the location of the VSCode settings (see below + comments):

Windows %APPDATA%\Code\User\settings.json
macOS $HOME/Library/ApplicationSupport/Code/User/settings.json
Linux $HOME/.config/Code/User/settings.json

It appears to only be storing modified settings, which is really nice (so you don't clobber up or screw with future versions).

You may also want /snippets/, in the same folder as settings.json.

And, of course, you can run code --list-extensions, as the other answers already mention.


Edit: I just discovered a neat little trick! Hit Ctrl+Shift+P to open up the command palette, and then type/select Preferences: Open Settings (JSON). This will open up your settings.json file. Then, you can right click on the settings.json tab, and click Open Containing Folder. This will take you to the folder mentioned above!

Andrew
  • 552
  • 5
  • 9
15

The Settings Sync extension should do the trick, though the UX is so-so.

It syncs your settings to a GitHub Gist in JSON format. You’ll have to create a GitHub token. I suggest saving the token code in the token file name, as when you need to download your settings again later, it’s unlikely you’ll have the code handy (at least, that was my case).

Rory O'Kane
  • 758
  • 1
  • 7
  • 19
Brandon
  • 1,181
  • 2
  • 10
  • 13
  • If you know you will need your GitHub token for the Settings Sync extension, you can get it from the `token` key in the `syncLocalSettings.json` that is in your Code profile, in the same folder as `settings.json`. – Rory O'Kane Sep 12 '19 at 08:47
-1

I just install Google Backup and Sync apps and then add user folder C:\Users\<user>\.vscode into the list of folders to be backed up.

Google Backup and Sync

Rosdi
  • 876
  • 2
  • 11
  • 22
  • this doesn't backup the settings but just the installed extensions which can easily be reinstalled if you get the list like mentioned in other comments – Patrick Wolf Nov 15 '21 at 04:29