2015-08-31 05:31:25 +00:00
|
|
|
# Setting Up Symbol Server in Debugger
|
2014-11-10 08:09:13 +00:00
|
|
|
|
|
|
|
Debug symbols allow you to have better debugging sessions. They have information
|
|
|
|
about the functions contained in executables and dynamic libraries and provide
|
|
|
|
you with information to get clean call stacks. A Symbol Server allows the
|
|
|
|
debugger to load the correct symbols, binaries and sources automatically without
|
|
|
|
forcing users to download large debugging files. The server functions like
|
2018-01-12 15:24:48 +00:00
|
|
|
[Microsoft's symbol server](https://support.microsoft.com/kb/311503) so the
|
2014-11-10 08:09:13 +00:00
|
|
|
documentation there can be useful.
|
|
|
|
|
2015-04-16 03:31:12 +00:00
|
|
|
Note that because released Electron builds are heavily optimized, debugging is
|
2014-11-10 08:09:13 +00:00
|
|
|
not always easy. The debugger will not be able to show you the content of all
|
|
|
|
variables and the execution path can seem strange because of inlining, tail
|
|
|
|
calls, and other compiler optimizations. The only workaround is to build an
|
|
|
|
unoptimized local build.
|
|
|
|
|
2015-04-16 03:31:12 +00:00
|
|
|
The official symbol server URL for Electron is
|
2024-05-09 02:12:29 +00:00
|
|
|
[https://symbols.electronjs.org](https://symbols.electronjs.org).
|
2015-08-31 05:31:25 +00:00
|
|
|
You cannot visit this URL directly, you must add it to the symbol path of your
|
2014-11-10 08:09:13 +00:00
|
|
|
debugging tool. In the examples below, a local cache directory is used to avoid
|
2015-08-31 05:31:25 +00:00
|
|
|
repeatedly fetching the PDB from the server. Replace `c:\code\symbols` with an
|
2014-11-10 08:09:13 +00:00
|
|
|
appropriate cache directory on your machine.
|
|
|
|
|
2015-08-31 05:31:25 +00:00
|
|
|
## Using the Symbol Server in Windbg
|
2014-11-10 08:09:13 +00:00
|
|
|
|
|
|
|
The Windbg symbol path is configured with a string value delimited with asterisk
|
2015-04-16 03:31:12 +00:00
|
|
|
characters. To use only the Electron symbol server, add the following entry to
|
2016-03-31 05:17:50 +00:00
|
|
|
your symbol path (**Note:** you can replace `c:\code\symbols` with any writable
|
2014-11-10 08:09:13 +00:00
|
|
|
directory on your computer, if you'd prefer a different location for downloaded
|
|
|
|
symbols):
|
|
|
|
|
2017-11-20 06:18:24 +00:00
|
|
|
```powershell
|
2020-07-27 20:25:39 +00:00
|
|
|
SRV*c:\code\symbols\*https://symbols.electronjs.org
|
2014-11-10 08:09:13 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
Set this string as `_NT_SYMBOL_PATH` in the environment, using the Windbg menus,
|
|
|
|
or by typing the `.sympath` command. If you would like to get symbols from
|
|
|
|
Microsoft's symbol server as well, you should list that first:
|
|
|
|
|
2017-11-20 06:18:24 +00:00
|
|
|
```powershell
|
2020-07-27 20:25:39 +00:00
|
|
|
SRV*c:\code\symbols\*https://msdl.microsoft.com/download/symbols;SRV*c:\code\symbols\*https://symbols.electronjs.org
|
2014-11-10 08:09:13 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Using the symbol server in Visual Studio
|
|
|
|
|
2022-01-18 17:14:48 +00:00
|
|
|
![Tools -> Options](../images/vs-tools-options.png)
|
|
|
|
|
|
|
|
![Symbols Settings](../images/vs-options-debugging-symbols.png)
|
2014-11-10 08:09:13 +00:00
|
|
|
|
|
|
|
## Troubleshooting: Symbols will not load
|
|
|
|
|
|
|
|
Type the following commands in Windbg to print why symbols are not loading:
|
|
|
|
|
2017-11-20 06:18:24 +00:00
|
|
|
```powershell
|
2014-11-10 08:09:13 +00:00
|
|
|
> !sym noisy
|
2016-07-07 01:17:49 +00:00
|
|
|
> .reload /f electron.exe
|
2014-11-10 08:09:13 +00:00
|
|
|
```
|