Skip to content

Debugging with Xcode

Joshua Groves edited this page Oct 28, 2020 · 2 revisions

First we'll start by opening Xcode and creating a new project using the menu or "Create a new Xcode project" in the startup dialog.

Xcode Startup Dialog

Select "External Build System" as the project type.

Xcode Project Type

Choose which build tool to use in the "Build Tool" field. This will be called whenever we build in Xcode.

We can write our cargo build command here if we'd like Xcode to run it, but we could also skip the build step to avoid Xcode building the project for us.

It's possible to skip the build step by specifying our build command as ls, echo, or anything else that exits successfully (note: : doesn't appear to work here).

The rest of the fields don't actually matter to us, so we can put any values there.

Xcode Build Tool

Click on the project name and then click "Edit Scheme".

Xcode Edit Scheme

Under the "Options" tab we can choose the level of validation for Metal and whether to enable GPU frame capture.

Xcode Scheme Options

Under the "Arguments" tab we'll choose which executable to run. We want this to be the binary created by cargo. We'll select "Other" and then find the binary in the target directory.

Xcode Scheme Arguments

Xcode Select Binary

Next we'll click the play button to run our binary and attach Xcode to it.

Xcode Play Button

Now we should see our application running and some output telling us that Metal validation has been enabled.

Xcode Attached

To start a GPU capture, click the camera button while Xcode is attached to our running application.

Xcode Start Capture

After a frame has been captured, we will be able to use all the regular Metal tools (e.g. shader debugging, GPU statistics, etc.).