27

I have the Creators update installed. WSL is operational. I can execute most .exe files by simply calling notepad.exe But when it comes to VS Code.... I can't use the default code command or call code.exe... I have also tried code and code.cmd. Why doesn't VS Code execute like other programs? And is there a way to enable the code command?

EDIT: I now get these errors:

me@mypc:/mnt/c/Users/me/Documents/project_folder$ code . /mnt/c/Program Files (x86)/Microsoft VS Code/bin/code: line 7: realpath: comma nd not found /mnt/c/Program Files (x86)/Microsoft VS Code/bin/code: line 14: ./Code.exe: No such file or directory

Auzy
  • 2,135
  • 2
  • 25
  • 35

10 Answers10

28

The Creators update did install the interop functionality. However, it seems you need to install realpath in WSL in order for the path to be recognized. I'm not sure why this is the case but running sudo apt-get install realpath fixed it for me!

EDIT: After updating to the Fall Creators Update launching VSCode from WSL works out of the box

Auzy
  • 2,135
  • 2
  • 25
  • 35
  • This might be helpful to others if you have a simliar issue and are using zsh https://medium.com/@finnzeit/set-and-use-zsh-as-default-shell-in-wsl-on-windows-10-the-right-way-4f30ed9592dc – Samwise Dec 05 '17 at 09:37
23

You could always create an alias in the WSL Bash shell

alias code="/mnt/c/Program\ Files/Microsoft\ VS\ Code/Code.exe"

If you add this to your .bashrc or .zshrc file then it will always be available when you start a new instance of your environment.

Damo
  • 5,698
  • 3
  • 37
  • 55
  • Throws error: `-bash: /mnt/c/Program: No such file or directory` – Melvin Abraham Aug 31 '20 at 05:37
  • 1
    Are you correctly escaping the space in "Program Files"? – Damo Sep 04 '20 at 14:42
  • 1
    Yeah, I am escaping the spaces in the path the exact way you did but that doesn't seem to work... – Melvin Abraham Sep 05 '20 at 03:37
  • @MelvinAbraham you could use path like so `alias code="/mnt/c/Users/[WINDOW_USER_NAME]/AppData/Local/Programs/Microsoft\ VS\ Code/Code.exe"` – DevHub May 06 '23 at 20:17
  • @Damo using this solution, I keep getting logs in terminal when I did the above and tried opening a directory using the following command `code .` the terminal keep getting logs when any changes are made to vscode – DevHub May 06 '23 at 20:18
3

WARNING: Do not change Linux files using Windows apps and tools

Update: The above is not relevant to version 1903 or newer.

With that out of the way, I recently experienced the exact same behavior. Turns out, in my noobish first whack at WSL with VS Code I also installed a native copy from apt which overwrote the Windows path.

So in WSL I removed it with something like this...

$ sudo apt remove code -y; sudo apt autoremove -y

Then confirmed the path was correct...

$ which code
/mnt/c/Program Files/Microsoft VS Code/bin/code

Then relaunched WSL terminal and all was well in the wonderful world of coding once again. :)

Note: I suppose another option would be to fix the path in WSL, but without a GUI package installed it will just launch in the background and never appear anyway.

Chiramisu
  • 4,687
  • 7
  • 47
  • 77
3

Another alternative is to use the following:

cmd.exe /c code

This also works for VSCodium:

cmd.exe /c codium

An alias can used so that the user only needs to call code:

alias code="cmd.exe /c code"
Daniel
  • 8,655
  • 5
  • 60
  • 87
1

I had the same problem after manually updating Ubuntu on wsl2. I solved this by adding this function to .bashrc config file. It's better solution than alias because it does not block the console.

Before adding it to your config test the function in bash and adjust the path if needed. For sure, you must change {username} to your Windows account username.

function code () { /mnt/c/Users/{username}/AppData/Local/Programs/Microsoft\ VS\ Code/Code.exe; }

If that work add it to your configuration script e.g. .bashrc, .zshrc. Here's a script that does that.

echo "function code () {
  /mnt/c/Users/{username}/AppData/Local/Programs/Microsoft\ VS\ Code/Code.exe \"\$@\"; 
}" >> ~/.bashrc
source ~/.bashrc
code .

Although my recommendation is to make backup and install fresh distro from Microsoft Store then open VS Code with Remote - WSL extension. If there came out an error with initializing WSL Extensions reinstall it first. If you used 19.04 Ubuntu and upgraded to 20.04 it sometimes needs to download initialization scripts for that version or it fails. That should help :)

proximab
  • 1,865
  • 1
  • 13
  • 18
  • 1
    Code's Linux Binary lives in .\bin in the VS Code's installation dir. This worked for me: ``function code () { /mnt/c/Program\ Files/Microsoft\ VS\ Code/bin/code "$@"; }`` Don't forget the "$@" as that passes any file or folder into the workspace. – JonShipman Jun 18 '21 at 20:55
1

I'm new so I don't have enough reputation to comment

I just want to point out that some people(like me) have visual studio code installed in C:\Users\YourUserNameGoesHere\AppData\Local\Programs\Microsoft VS Code instead of C:\Program Files\Microsoft Visual Studio If you cant get it to work, try checking if it is installed in Appdata instead of Program Files.

The escaped WSL path to the x86 visual studio executable is

/mnt/c/Users/UserName/AppData/Local/Programs/Microsoft\ VS\ Code/code.exe
0

for me what worked was

alias code="/mnt/c/Users/<USERNAME>/AppData/Local/Programs/'Microsoft VS Code'/Code.exe"

and then you can simply invoke it with something like

code .
krisvibes
  • 1
  • 1
0

For some reason code . doesn't open in WSL for me (i.e. it would open using in Windows file system without the WSL extension). So I would have to constantly ctrl + shift + p then WSL: Reopen Folder in WSL. You could force it with the --remote wsl+Ubuntu-20.04 flag, but then for me the . wouldn't work; it just opens a VS Code instance in WSL, not in the current dir.

So I added a function to my .bashrc/.zshrc called c that opens the current dir in VSCode + WSL:

alias code="/mnt/c/Users/yourusernamehere/AppData/Local/Programs/Microsoft\ VS\ Code/Code.exe"
function c () { code --remote wsl+Ubuntu-20.04 -n "`pwd`" }

Use wsl --list to find your distro's name. It must be prefixed with wsl+; see docs.

DharmaTurtle
  • 6,858
  • 6
  • 38
  • 52
0

In recent versions of WSL you just type code at the terminal and this will update the VSCode installation as needed.

See below for an example:

result of running code in a terminal

SuperStormer
  • 4,997
  • 5
  • 25
  • 35
ahsan dev
  • 31
  • 2
0

Using Windows 10 and WSL2, canceled the install that gets triggered when running code for the first time. I found per https://stackoverflow.com/a/64108942/1919793 and https://code.visualstudio.com/docs/remote/wsl-tutorial#_run-in-wsl that it is better to reinstall VS Code WSL server:

~$ rm -r ~/.vscode-server
~$ code
Installing VS Code Server for x64 (6261075646f055b99068d3688932416f2346dd3b)
Downloading: 100%
Unpacking: 100%
Unpacked 2457 files and folders to /home/user/.vscode-server/bin/6261075646f055b99068d3688932416f2346dd3b.
~$

Previously I was using this code in ~/.bash_aliases

function code {
    if [ -e "/mnt/c/Program Files/Microsoft VS Code/Code.exe" ]; then
        "/mnt/c/Program Files/Microsoft VS Code/Code.exe" &
    else
        username=$(cd /mnt/c && cmd.exe /c 'echo %username%')
        username="${username/$'\r'/}"
        echo "/mnt/c/Users/${username}/AppData/Local/Programs/Microsoft VS Code/code.exe" &
    fi
}
theSparky
  • 440
  • 3
  • 13