Pause execution when events occur

Use the Breakpoint navigator to add breakpoints to your project to pause when certain types of events occur, such as exceptions, Swift errors, and test failures.

Pause when exceptions occur

  1. Click the Add button (+) at the bottom of the Breakpoint navigator.

  2. Choose Exception Breakpoint from the pop-up menu.

  3. In the configuration dialog, choose the type of exception on which you want execution to stop from the Exception field pop-up menu:

    • All: Stop on all exceptions.

    • Objective-C: Stops on Objective-C exceptions.

    • C++: Stops on C++ exceptions. To stop on a particular C++ exception, you must specify the exception name.

  4. Choose whether execution should halt when an exception is thrown or caught.

  5. Optionally, configure breakpoint actions to run when the breakpoint is encountered, and set other breakpoint options.

Pause when Swift errors occur

  1. Click the Add button (+) at the bottom of the Breakpoint navigator.

  2. Choose Swift Error Breakpoint from the pop-up menu.

  3. Optionally, Control-click the breakpoint, choose Edit Breakpoint, and configure the behavior of the breakpoint. You can set it to halt execution on a specific type of Swift error, rather than all Swift errors (the default). You can also configure actions to run when the breakpoint is encountered, and set other breakpoint options.

Pause when OpenGL ES errors occur

Xcode can automatically pause when your app encounters an OpenGL ES error.

  1. Click the Add button (+) at the bottom of the Breakpoint navigator.

  2. Choose OpenGL ES Error Breakpoint from the pop-up menu.

  3. To pause only if an expression evaluates to true, enter the expression in the Condition field.

  4. Optionally, configure actions to run when the breakpoint is encountered, and set other breakpoint options.

Pause when a specific function or method starts running

  1. Click the Add button (+) at the bottom of the Breakpoint navigator.

  2. Choose Symbolic Breakpoint from the pop-up menu.

  3. Enter a method or function name in the Symbol field. For example:

    • A method name: pathsMatchingExtensions.

    • A method of a particular class: [SKTLine drawHandlesInView], people::Person::name().

    • A function name: _objc_msgForward.

  4. If the symbol is declared in more than one library, enter the name of the appropriate library in the Module field.

  5. To pause only if an expression evaluates to true, enter the expression in the Condition field.

  6. Optionally, configure actions to run when the breakpoint is encountered, and set other breakpoint options.

Pause when test failures occur

  1. Click the Add button (+) at the bottom of the Breakpoint navigator.

  2. Choose Test Failure Breakpoint from the pop-up menu.

  3. Optionally, configure actions to run when the breakpoint is encountered, and set other breakpoint options.

SEE ALSONavigate and manage breakpointsAdd, remove, disable, and enable breakpoints in your code