I have been asked a couple of times recently what my Visual Studio Code extensions are at the moment so I thought I would write a quick post and also look at workspaces and how you can enable and disable extensions within them
Listing Extensions
From the command line you can list your extensions using
code --list-extensions
code-insiders --list-extensions
My list looks like this
data:image/s3,"s3://crabby-images/8319b/8319b6d464ce99c7c75d12f82af0f0a9e1936b68" alt=""
You can also see them in the view on the left of default Visual Studio Code and open them with CTRL + SHIFT + X (unless like me you have Snaggit installed and it has taken that shortcut
data:image/s3,"s3://crabby-images/bae8b/bae8b7a655202477f16dfd8d1cb16aa5b21e9d7f" alt=""
Installing Extensions
You can install extensions by opening the Extensions view in Visual Studio Code and searching for the extension. The list I have below has the precise names for each extension which you can use to search
data:image/s3,"s3://crabby-images/4e251/4e2511abe04c314fac28e26e48ca702192805cd2" alt=""
You can also install extensions from the command-line with
code --install-extension <extensionid>
code-insiders --install-extension <extensionid>
My Extensions
I am going to list these in alphabetical order by display name for ease (my ease that is!)
data:image/s3,"s3://crabby-images/bc523/bc523928b512fe3e7d2196c06149db2731bde026" alt=""
Because Chrissy LeMaire and I are writing dbatools in a Month of Lunches using AsciiDoc, it makes sense to have an extension enabling previewing and syntax, you can find it here
data:image/s3,"s3://crabby-images/bb9dc/bb9dc0f20a1d442e7c297e4fceeb3eac83998ec9" alt=""
For interacting with Azure I use the Azure Account Extension – ms-vscode.azure-account
data:image/s3,"s3://crabby-images/c1de0/c1de0c86c3ae43500ad4f96a66ccf6059194ae23" alt=""
I use Azure CLI so I make use of the functionality of the Azure CLI Tools extension ms-vscode.azurecli
data:image/s3,"s3://crabby-images/5b4de/5b4de7c84ea55c9217cee8b3371b91d0199bbc97" alt=""
For interacting with Azure Repos I use the ms-vsts.team extension
data:image/s3,"s3://crabby-images/e6cca/e6ccaca708e15821897bb07fd827172c92c5f638" alt=""
When creating ARM templates, this extension is very useful msazurermtools.azurerm-vscode-tools
data:image/s3,"s3://crabby-images/3dcae/3dcae8a20d2b1927d9b0473725d5f222cb03e3b0" alt=""
I have a few theme extensions, this one is for fun in demos beardedbear.beardedtheme
data:image/s3,"s3://crabby-images/003ae/003ae37317852ffd017a44825b70c98d4df70e51" alt=""
The blackboard theme is my default one gerane.theme-blackboard
data:image/s3,"s3://crabby-images/32855/32855e09ebd3867c3b587766d3da0825f5b71a75" alt=""
Chasing closing brackets is much easier with the Bracket Pair Colorixer, I use the beta version coenraads.bracket-pair-colorizer-2
data:image/s3,"s3://crabby-images/0fa37/0fa37dabe57c54f0a40e8d983f99361516726149" alt=""
I am rubbish at spelling and typing so I use this to help point out the issues! streetsidesoftware.code-spell-checker
data:image/s3,"s3://crabby-images/3eb0a/3eb0ae6874e916fea3f3d0fd7a3491e40497a53a" alt=""
Using the Docker extension adds another view to Visual Studio Code to ease working with containers ms-azuretools.vscode-docker
data:image/s3,"s3://crabby-images/601a2/601a24d8fbde97fb1a982297d1f421fa0af87234" alt=""
As an open-source project maintainer it is good to be able to work with GitHub pull requests without leaving Visual Studio Code github.vscode-pull-request-githubPreview
data:image/s3,"s3://crabby-images/f999d/f999dba5f16fe5f9086dd4d74a5fe74c922fb69b" alt=""
GitLens is absolutely invaluable when working with source control. It has so many features. This is an absolute must eamodio.gitlens
data:image/s3,"s3://crabby-images/fa33a/fa33a719089ff336406b32560765990b1b74d0fd" alt=""
Working with Kubernetes? This extension adds another view for interacting with your cluster ms-kubernetes-tools.vscode-kubernetes-tools
data:image/s3,"s3://crabby-images/d5766/d5766ad21cd638a549f9730b8e9aa5b00689d4f0" alt=""
Visual Studio Live Share enables you to collaborate in real-time in Visual Studio Code with your colleagues or friends. I blogged about this here ms-vsliveshare.vsliveshare
data:image/s3,"s3://crabby-images/42e25/42e25a0fbcd86d44f4db6e5a0620085a618f9e3c" alt=""
I lvoe writing markdown and this linter assists me to ensure that my markdown is correct davidanson.vscode-markdownlint
data:image/s3,"s3://crabby-images/a9544/a9544850cc82cb7550586b1067a8e6ca7ff7be6a" alt=""
The Material Icon Theme ensures that there are pretty icons in my editor! pkief.material-icon-theme
data:image/s3,"s3://crabby-images/39578/3957845393b10c998eadb774f90945b5bc3e01e7" alt=""
I have both the PowerShell extension ms-vscode.powershell and the PowerShell preview extension ms-vscode.powershell-preview installed but only one can be enabled at a time
data:image/s3,"s3://crabby-images/3d024/3d024d9c7a59cf0c924c938949bae197ae001509" alt=""
This suite of extensions enables easy remote development so that you can develop your PowerShell scripts, for example, inside a ubuntu container running PowerShell 7 or inside Windows Subsystem for LInux ms-vscode-remote.vscode-remote-extensionpackPreview
data:image/s3,"s3://crabby-images/12f07/12f0766d99b5d3af0126f93e9d4b67d6bde594f9" alt=""
Writing for cross-platform means looking out for line endings and this extension will display them and any whitespace in your editor medo64.render-crlf
data:image/s3,"s3://crabby-images/553eb/553eb48ed42df31939db3926d35d88f9e42a2553" alt=""
An absolutely essential extension which enables me to backup all of my Visual Studio Code settings, shortcuts, extensions into a GitHub gist and keep all of my machines feeling the same. shan.code-settings-sync
data:image/s3,"s3://crabby-images/e204f/e204f82dee6b16102a8a531b5247bede269cc792" alt=""
For working with SQL Server within Visual Studio Code and having a view for my instances as well as a linter and intellisense I use ms-mssql.mssql
data:image/s3,"s3://crabby-images/eee29/eee29a87f7ed9bd2df66522424acae8505ec7875" alt=""
Yaml files and spaces! I no longer get so confused with this extension to help me redhat.vscode-yaml
Workspaces
Now that is a lot of extensions and I dont need all of them everytime. I use workspaces to help with this. I will create a workspace file for the project I am working on.
I open or create the folders I will be working on and then click File and Save Workspace As and save the file in the root of the folder.
data:image/s3,"s3://crabby-images/b9886/b9886de3321415109fdf15c3c79053f21d924c3f" alt=""
Now, the next time I want to open the workspace, I can open the workspace file or if I open the folder Visual Studio Code will helpfully prompt me
data:image/s3,"s3://crabby-images/ce946/ce9461614c006f48188f5ba964b8eec1adba944e" alt=""
Now I can have all of my settings retained for that workspace
data:image/s3,"s3://crabby-images/dcb9a/dcb9a1ecf4d6e71325652661fa8373e736cefc95" alt=""
For this folder, I am ensuring that the PowerShell extension uses the PSScriptAnalyzer Settings file that I have created so that it will show if the code is compatible with the versions of PowerShell I have chosen. I can define settings for a workspace in the settings file, which you can open using CTRL and ,
data:image/s3,"s3://crabby-images/fba9e/fba9e5fc11b7ae2767c9278e9caac5af020aa3d6" alt=""
But I can also enable or disable extensions for a workspace
data:image/s3,"s3://crabby-images/d174e/d174e0197fcbfe8022fe57984713964dca41164d" alt=""
So everytime I open this workspace I am only loading the extensions I want
data:image/s3,"s3://crabby-images/c6829/c68290b3f14f296507e2b1c2ccefd4289bba492e" alt=""