Skip to main content

Debugging

To debug an iOS application extension, provide thin integration with the CodeLLDB extension, powered by LLDB.

Tutorial

  1. Create a launch.json configuration file in the .vscode directory of your project. The configuration file should contain the following configuration:
.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "sweetpad-lldb",
"request": "launch",
"name": "Attach to running app (SweetPad)",
"preLaunchTask": "sweetpad: launch"
}
]
}

Also, you can create that file by clicking on the "Create a launch.json file" link in the Debug panel.

Create launch.json

Select Sweetpad LLDB

Update launch.json

  1. Press F5 to start debugging. The debugger will build and launch the application on the iOS simulator and then attach to the running application.

Launch debugger

  1. Set breakpoints in your code and start debugging your application. Next time, you can just press F5 to start and attach the debugger to the running application.

Breakpoints

Customise "preLaunchTask"

You can customise the preLaunchTask property in the launch.json by creating custom task configurations in the .vscode/tasks.json file. For example, you can create a task that will build the application with the Release scheme and then launch the debugger.

.vscode/tasks.json
{
"version": "2.0.0",
"tasks": [
{
"type": "sweetpad",
"action": "launch",
"problemMatcher": [
"$sweetpad-watch",
"$sweetpad-xcodebuild-default",
"$sweetpad-xcbeautify-errors",
"$sweetpad-xcbeautify-warnings"
],
"label": "sweetpad: launch release",
"detail": "Build and Launch the app",
"scheme": "Release",
"configuration": "Release",
"isBackground": true // !!! This is important to detect when the task is finished
}
]
}

Then, update the preLaunchTask property in the launch.json file to use the new task:

.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "sweetpad-lldb",
"request": "launch",
"name": "Attach to running app (SweetPad)",
"preLaunchTask": "sweetpad: launch release"
}
]
}

Old tutorial (deprecated)

Warning: This tutorial shows the old way of debugging iOS applications. It's deprecated, but it's still working.

  1. Install the CodeLLDB extension from the Visual Studio Code marketplace.

Install CodeLLDB

  1. Create a launch.json configuration file in the .vscode directory of your project. The configuration file should contain the following configuration:

  2. Now set breakpoints in your code and start debugging your application. Next time, you can just attach the debugger to the running application without the previous steps.

Breakpoints

.vscode/launch.json
{
"version": "0.2.0",
"configurations": [
{
"type": "lldb",
"request": "attach",
"name": "Attach to iOS Simulator",
"waitFor": true,
"program": "${command:sweetpad.debugger.getAppPath}"
}
]
}

Create launch.json

Update launch.json

Do you notice the ${command:sweetpad.debugger.getAppPath}? This is a command that will be executed before debugging starts and will return the path to the application that was recently built by SweetPad. That path is required by the CodeLLDB extension in order to attach to the running application. You can read more about the CodeLLDB debugger options in the official documentation.

  1. Start the iOS simulator and run the application using the SweetPad "Launch" command on the "Build" panel. Wait until the application is launched on the simulator.

Launch

  1. Attach the debugger to the running application by clicking on the "Attach to iOS Simulator" configuration on the Debug panel. It takes a few seconds to attach the debugger to the running application. If you see the "Call Stack" panel with the list of threads and frames, then the debugger is successfully attached.

Attach

  1. Now set breakpoints in your code and start debugging your application. Next time, you can just attach the debugger to the running application without the previous steps.

Breakpoints