2023-01-12 20:49:14 +01:00
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Overview of debugging tools
|
|
|
|
===========================
|
|
|
|
|
|
|
|
This guide will give you an overview of the available debugging tools in the
|
|
|
|
engine.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Debugger Panel
|
|
|
|
--------------
|
|
|
|
|
|
|
|
Many of Godot's debugging tools are part of the Debugger panel, which you can
|
2023-01-12 19:29:11 +01:00
|
|
|
find information about in `doc_debugger_panel`.
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Debug menu options
|
|
|
|
------------------
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/overview_debug.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Here are the descriptions of the options:
|
|
|
|
|
|
|
|
Deploy with Remote Debug
|
|
|
|
++++++++++++++++++++++++
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
When **Small Deploy with Network FS** is on, instead of exporting the full game,
|
|
|
|
deploying the game builds a minimal executable. The editor then provides files
|
|
|
|
from the project over the network.
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Visible Navigation
|
|
|
|
++++++++++++++++++
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Script editor debug tools and options
|
|
|
|
-------------------------------------
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/overview_script_editor.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Warning:
|
|
|
|
|
2022-03-18 17:46:08 +01:00
|
|
|
|
|
|
|
Breakpoints won't break on code if it's
|
2023-01-12 20:47:54 +01:00
|
|
|
`running in a thread ( doc_using_multiple_threads )`.
|
2022-03-18 17:46:08 +01:00
|
|
|
This is a current limitation of the GDScript debugger.
|
|
|
|
|
|
|
|
Debug project settings
|
|
|
|
----------------------
|
|
|
|
|
|
|
|
In the project settings, there is a **Debug** category with three subcategories
|
|
|
|
which control different things.
|
|
|
|
|
|
|
|
Settings
|
|
|
|
++++++++
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
|
|
|
Remote in scene dock
|
|
|
|
--------------------
|
|
|
|
|
|
|
|
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.
|
|
|
|
|
2023-01-12 20:16:00 +01:00
|
|
|
![](img/overview_remote.png)
|
2022-03-18 17:46:08 +01:00
|
|
|
|
2023-01-12 20:55:57 +01:00
|
|
|
Note:
|
|
|
|
Some editor settings related to debugging can be found inside
|
2022-03-18 17:46:08 +01:00
|
|
|
the **Editor Settings**, under the **Network > Debug** and **Debugger** sections.
|