Overview of debugging tools

    Godot comes with a powerful debugger and profilers to track down bugs, inspect your game at runtime, monitor essential metrics, and measure performances. It also offers options to visualize collision boxes and navigation polygons in the running game.

    Finally, you have options to debug the game running on a remote device and to reload changes to your scenes or your code while the game is running.

    Many of Godot’s debugging tools are part of the Debugger panel, which you can find information about in .

    There are a few common debug options you can toggle on or off when running your game in the editor, which can help you in debugging your game.

    You can find these options in the Debug editor menu.

    Here are the descriptions of the options:

    When exporting and deploying, the resulting executable will attempt to connect to the IP of your computer for debugging.

    Small Deploy with Network FS

    This option speeds up testing for games with a large footprint on remote devices.

    Also, on Android, the game is deployed using the USB cable to speed up deployment.

    Visible Collision Shapes

    This option makes collision shapes and raycast nodes visible in the running game.

    Navigation meshes and polygons will be visible on the running game.

    Sync Scene Changes

    With this option, any change you make to a scene in the editor at runtime appears instantly. When used remotely on a device, this is more efficient with the network filesystem.

    Sync Script Changes

    Any script that is saved will be reloaded on the running game. When used remotely on a device, this is more efficient with the network filesystem.

    The script editor has its own set of debug tools for use with breakpoints and two options. The breakpoint tools can also be found in the Debugger tab of the debugger.

    ../../../_images/overview_script_editor.png

    The Break button causes a break in the script like a breakpoint would. Continue makes the game continue after pausing at a breakpoint. Step Over goes to the next line of code, and Step Into goes into a function if possible. Otherwise, it does the same thing as Step Over.

    The Keep Debugger Open option keeps the debugger open after a scene has been closed. And the Debug with External Editor option lets you debug your game with an external editor.

    Breakpoints won’t break on code if it’s running in a thread. This is a current limitation of the GDScript debugger.

    In the project settings, there is a Debug category with three subcategories which control different things.

    These are some general settings such as printing the current FPS to the Output panel, the maximum amount of functions when profiling and others.

    GDScript

    These settings allow you to toggle specific GDScript warnings, such as for unused variables. You can also turn off warnings completely.

    Shapes

    Shapes are where you can adjust the color of shapes that only appear for debugging purposes, such as collision and navigation shapes.

    When running a game in the editor two options appear at the top of the Scene dock, Remote and Local. While using Remote you can inspect or change the nodes’ parameters in the running project.

    Note

    Some editor settings related to debugging can be found inside the Editor Settings, under the Network > Debug and Debugger sections.