2018-03-05 18:19:19 +00:00
|
|
|
## Debugging with XCode
|
|
|
|
|
|
|
|
### Build Debug Electron with Release libchromiumcontent
|
2018-07-20 17:58:19 +00:00
|
|
|
You can create a debug build of Electron by following [build instructions for macOS](build-instructions-osx.md).
|
2018-03-05 18:19:19 +00:00
|
|
|
The bootstrap process will download Release version of libchromiumcontent by default,
|
2018-07-20 17:58:19 +00:00
|
|
|
so you will not be able to step through the Chromium source.
|
2018-03-05 18:19:19 +00:00
|
|
|
|
|
|
|
### Build Debug Electron with Debug libchromiumcontent
|
2018-07-20 17:58:19 +00:00
|
|
|
If you want to debug and step through libchromiumcontent, you will have to run the
|
2018-03-05 18:19:19 +00:00
|
|
|
bootsrap script with the `--build_debug_libcc` argument.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ cd electron
|
|
|
|
$ ./script/bootstrap.py -v --build_debug_libcc
|
|
|
|
```
|
|
|
|
This can take a significant amount of time depending on build machine as it has to
|
|
|
|
build all of the libchromium source.
|
|
|
|
|
|
|
|
Once, the lib is built, create a symlink to the built directory under download
|
|
|
|
|
|
|
|
`ln -s vendor/libchromiumcontent/dist/main/shared_library vendor/download/libchromiumcontent/shared_library`
|
|
|
|
|
|
|
|
Electron debug builds will use this shared library to link against.
|
|
|
|
|
|
|
|
```sh
|
|
|
|
$ ./script/build.py -c D --libcc
|
|
|
|
```
|
2018-07-20 17:58:19 +00:00
|
|
|
This will build debug Electron with debug version of libchromiumcontent.
|
2018-03-05 18:19:19 +00:00
|
|
|
|
|
|
|
### Generate xcode project for debugging sources (cannot build code from xcode)
|
|
|
|
Run the update script with the --xcode argument.
|
|
|
|
```sh
|
|
|
|
$ ./script/update.py --xcode
|
|
|
|
```
|
|
|
|
This will generate the electron.ninjs.xcworkspace. You will have to open this workspace
|
|
|
|
to set breakpoints and inspect.
|
|
|
|
|
|
|
|
### Debugging and breakpoints
|
|
|
|
|
2018-07-20 17:58:19 +00:00
|
|
|
Launch Electron app after build.
|
|
|
|
You can now open the xcode workspace created above and attach to the Electron process
|
2018-03-05 18:19:19 +00:00
|
|
|
through the Debug > Attach To Process > Electron debug menu. [Note: If you want to debug
|
|
|
|
the renderer process, you need to attach to the Electron Helper as well.]
|
|
|
|
|
|
|
|
You can now set breakpoints in any of the indexed files. However, you will not be able
|
2018-07-20 17:58:19 +00:00
|
|
|
to set breakpoints directly in the Chromium source.
|
|
|
|
To set break points in the Chromium source, you can choose Debug > Breakpoints > Create
|
2018-03-05 18:19:19 +00:00
|
|
|
Symbolic Breakpoint and set any function name as the symbol. This will set the breakpoint
|
|
|
|
for all functions with that name, from all the classes if there are more than one.
|
|
|
|
You can also do this step of setting break points prior to attaching the debugger,
|
|
|
|
however, actual breakpoints for symbolic breakpoint functions may not show up until the
|
2018-07-20 17:58:19 +00:00
|
|
|
debugger is attached to the app.
|