Skip to content

Commit

Permalink
[Debugger] Fully disable debugger in release builds by default
Browse files Browse the repository at this point in the history
The debugger can still be manually enabled by forcing the
enable_engine_debugger build flag, enabling all debugger features in
that case (including e.g. scene live edit).
  • Loading branch information
Faless committed Nov 28, 2024
1 parent 0eadbdb commit 8df9ac6
Show file tree
Hide file tree
Showing 16 changed files with 116 additions and 19 deletions.
9 changes: 9 additions & 0 deletions SConstruct
Original file line number Diff line number Diff line change
Expand Up @@ -259,6 +259,7 @@ opts.Add(BoolVariable("disable_advanced_gui", "Disable advanced GUI nodes and be
opts.Add("build_profile", "Path to a file containing a feature build profile", "")
opts.Add(BoolVariable("modules_enabled_by_default", "If no, disable all modules except ones explicitly enabled", True))
opts.Add(BoolVariable("no_editor_splash", "Don't use the custom splash screen for the editor", True))
opts.Add(BoolVariable("enable_engine_debugger", "Enable engine-specific debugging features", True))
opts.Add(
"system_certs_path",
"Use this path as TLS certificates default for editor and Linux/BSD export templates (for package maintainers)",
Expand Down Expand Up @@ -501,6 +502,14 @@ else:
# Disable assert() for production targets (only used in thirdparty code).
env.Append(CPPDEFINES=["NDEBUG"])

env["enable_engine_debugger"] = methods.get_cmdline_bool("enable_engine_debugger", env.debug_features)

if env["enable_engine_debugger"]:
env.Append(CPPDEFINES=["DEBUGGER_ENABLED"])
elif env.editor_build:
print_error(f'Engine debugger is required for editor builds.')
Exit(255)

# SCons speed optimization controlled by the `fast_unsafe` option, which provide
# more than 10 s speed up for incremental rebuilds.
# Unsafe as they reduce the certainty of rebuilding all changed files, so it's
Expand Down
64 changes: 64 additions & 0 deletions core/debugger/engine_debugger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,6 +45,16 @@ HashMap<String, EngineDebugger::CreatePeerFunc> EngineDebugger::protocols;

void (*EngineDebugger::allow_focus_steal_fn)();

#ifdef DEBUGGER_ENABLED

void EngineDebugger::line_poll() {
// The purpose of this is just processing events every now and then when the script might get too busy otherwise bugs like infinite loops can't be caught.
if (unlikely(poll_every % 2048) == 0) {
poll_events(false);
}
poll_every++;
}

void EngineDebugger::register_profiler(const StringName &p_name, const Profiler &p_func) {
ERR_FAIL_COND_MSG(profilers.has(p_name), vformat("Profiler already registered: '%s'.", p_name));
profilers.insert(p_name, p_func);
Expand Down Expand Up @@ -194,6 +204,60 @@ void EngineDebugger::deinitialize() {
protocols.clear();
}

#else

void EngineDebugger::line_poll() {
}

void EngineDebugger::register_profiler(const StringName &p_name, const Profiler &p_func) {
}

void EngineDebugger::unregister_profiler(const StringName &p_name) {
}

void EngineDebugger::register_message_capture(const StringName &p_name, Capture p_func) {
}

void EngineDebugger::unregister_message_capture(const StringName &p_name) {
}

void EngineDebugger::register_uri_handler(const String &p_protocol, CreatePeerFunc p_func) {
}

void EngineDebugger::profiler_enable(const StringName &p_name, bool p_enabled, const Array &p_opts) {
}

void EngineDebugger::profiler_add_frame_data(const StringName &p_name, const Array &p_data) {
}

bool EngineDebugger::is_profiling(const StringName &p_name) {
return false;
}

bool EngineDebugger::has_profiler(const StringName &p_name) {
return false;
}

bool EngineDebugger::has_capture(const StringName &p_name) {
return false;
}

Error EngineDebugger::capture_parse(const StringName &p_name, const String &p_msg, const Array &p_args, bool &r_captured) {
r_captured = false;
return ERR_UNAVAILABLE;
}

void EngineDebugger::iteration(uint64_t p_frame_ticks, uint64_t p_process_ticks, uint64_t p_physics_ticks, double p_physics_frame_time) {
}

void EngineDebugger::initialize(const String &p_uri, bool p_skip_breakpoints, const Vector<String> &p_breakpoints, void (*p_allow_focus_steal_fn)()) {
}

void EngineDebugger::deinitialize() {
}

#endif

EngineDebugger::~EngineDebugger() {
if (script_debugger) {
memdelete(script_debugger);
Expand Down
12 changes: 5 additions & 7 deletions core/debugger/engine_debugger.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,7 +58,9 @@ class EngineDebugger {
ProfilingAdd add = nullptr;
ProfilingTick tick = nullptr;
void *data = nullptr;
#ifdef DEBUGGER_ENABLED
bool active = false;
#endif

public:
Profiler() {}
Expand All @@ -85,12 +87,14 @@ class EngineDebugger {
};

private:
#ifdef DEBUGGER_ENABLED
double frame_time = 0.0;
double process_time = 0.0;
double physics_time = 0.0;
double physics_frame_time = 0.0;

uint32_t poll_every = 0;
#endif

protected:
static EngineDebugger *singleton;
Expand Down Expand Up @@ -126,13 +130,7 @@ class EngineDebugger {
void profiler_enable(const StringName &p_name, bool p_enabled, const Array &p_opts = Array());
Error capture_parse(const StringName &p_name, const String &p_msg, const Array &p_args, bool &r_captured);

void line_poll() {
// The purpose of this is just processing events every now and then when the script might get too busy otherwise bugs like infinite loops can't be caught.
if (unlikely(poll_every % 2048) == 0) {
poll_events(false);
}
poll_every++;
}
void line_poll();

virtual void poll_events(bool p_is_idle) {}
virtual void send_message(const String &p_msg, const Array &p_data) = 0;
Expand Down
4 changes: 4 additions & 0 deletions core/debugger/local_debugger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/**************************************************************************/

#ifdef DEBUGGER_ENABLED

#include "local_debugger.h"

#include "core/debugger/script_debugger.h"
Expand Down Expand Up @@ -388,3 +390,5 @@ LocalDebugger::~LocalDebugger() {
memdelete(scripts_profiler);
}
}

#endif // DEBUGGER_ENABLED
4 changes: 4 additions & 0 deletions core/debugger/local_debugger.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@
#ifndef LOCAL_DEBUGGER_H
#define LOCAL_DEBUGGER_H

#ifdef DEBUGGER_ENABLED

#include "core/debugger/engine_debugger.h"
#include "core/object/script_language.h"
#include "core/templates/list.h"
Expand All @@ -56,4 +58,6 @@ class LocalDebugger : public EngineDebugger {
~LocalDebugger();
};

#endif // DEBUGGER_ENABLED

#endif // LOCAL_DEBUGGER_H
4 changes: 4 additions & 0 deletions core/debugger/remote_debugger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/**************************************************************************/

#ifdef DEBUGGER_ENABLED

#include "remote_debugger.h"

#include "core/config/project_settings.h"
Expand Down Expand Up @@ -734,3 +736,5 @@ RemoteDebugger::~RemoteDebugger() {
remove_print_handler(&phl);
remove_error_handler(&eh);
}

#endif // DEBUGGER_ENABLED
4 changes: 4 additions & 0 deletions core/debugger/remote_debugger.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@
#ifndef REMOTE_DEBUGGER_H
#define REMOTE_DEBUGGER_H

#ifdef DEBUGGER_ENABLED

#include "core/debugger/debugger_marshalls.h"
#include "core/debugger/engine_debugger.h"
#include "core/debugger/remote_debugger_peer.h"
Expand Down Expand Up @@ -123,4 +125,6 @@ class RemoteDebugger : public EngineDebugger {
~RemoteDebugger();
};

#endif // DEBUGGER_ENABLED

#endif // REMOTE_DEBUGGER_H
2 changes: 2 additions & 0 deletions modules/websocket/register_types.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -70,8 +70,10 @@ void initialize_websocket_module(ModuleInitializationLevel p_level) {
GDREGISTER_CLASS(WebSocketMultiplayerPeer);
ClassDB::register_custom_instance_class<WebSocketPeer>();

#ifdef DEBUGGER_ENABLED
EngineDebugger::register_uri_handler("ws://", RemoteDebuggerPeerWebSocket::create);
EngineDebugger::register_uri_handler("wss://", RemoteDebuggerPeerWebSocket::create);
#endif
}

#ifdef TOOLS_ENABLED
Expand Down
4 changes: 4 additions & 0 deletions modules/websocket/remote_debugger_peer_websocket.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,8 @@
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
/**************************************************************************/

#ifdef DEBUGGER_ENABLED

#include "remote_debugger_peer_websocket.h"

#include "core/config/project_settings.h"
Expand Down Expand Up @@ -139,3 +141,5 @@ RemoteDebuggerPeer *RemoteDebuggerPeerWebSocket::create(const String &p_uri) {
}
return peer;
}

#endif // DEBUGGER_ENABLED
4 changes: 4 additions & 0 deletions modules/websocket/remote_debugger_peer_websocket.h
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,8 @@
#ifndef REMOTE_DEBUGGER_PEER_WEBSOCKET_H
#define REMOTE_DEBUGGER_PEER_WEBSOCKET_H

#ifdef DEBUGGER_ENABLED

#include "websocket_peer.h"

#include "core/debugger/remote_debugger_peer.h"
Expand Down Expand Up @@ -59,4 +61,6 @@ class RemoteDebuggerPeerWebSocket : public RemoteDebuggerPeer {
RemoteDebuggerPeerWebSocket(Ref<WebSocketPeer> p_peer = Ref<WebSocketPeer>());
};

#endif // DEBUGGER_ENABLED

#endif // REMOTE_DEBUGGER_PEER_WEBSOCKET_H
3 changes: 2 additions & 1 deletion scene/SCsub
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,8 @@ SConscript("2d/SCsub")
SConscript("animation/SCsub")
SConscript("audio/SCsub")
SConscript("resources/SCsub")
SConscript("debugger/SCsub")
if env["enable_engine_debugger"]:
SConscript("debugger/SCsub")
SConscript("theme/SCsub")

# Build it all as a library
Expand Down
6 changes: 0 additions & 6 deletions scene/debugger/scene_debugger.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -56,16 +56,13 @@
SceneDebugger::SceneDebugger() {
singleton = this;

#ifdef DEBUG_ENABLED
LiveEditor::singleton = memnew(LiveEditor);
RuntimeNodeSelect::singleton = memnew(RuntimeNodeSelect);

EngineDebugger::register_message_capture("scene", EngineDebugger::Capture(nullptr, SceneDebugger::parse_message));
#endif
}

SceneDebugger::~SceneDebugger() {
#ifdef DEBUG_ENABLED
if (LiveEditor::singleton) {
EngineDebugger::unregister_message_capture("scene");
memdelete(LiveEditor::singleton);
Expand All @@ -76,7 +73,6 @@ SceneDebugger::~SceneDebugger() {
memdelete(RuntimeNodeSelect::singleton);
RuntimeNodeSelect::singleton = nullptr;
}
#endif

singleton = nullptr;
}
Expand All @@ -93,7 +89,6 @@ void SceneDebugger::deinitialize() {
}
}

#ifdef DEBUG_ENABLED
void SceneDebugger::_handle_input(const Ref<InputEvent> &p_event, const Ref<Shortcut> &p_shortcut) {
Ref<InputEventKey> k = p_event;
if (k.is_valid() && k->is_pressed() && !k->is_echo() && p_shortcut->matches_event(k)) {
Expand Down Expand Up @@ -2156,4 +2151,3 @@ void RuntimeNodeSelect::_reset_camera_3d() {
SceneTree::get_singleton()->get_root()->set_camera_3d_override_perspective(CAMERA_BASE_FOV * cursor.fov_scale, CAMERA_ZNEAR, CAMERA_ZFAR);
}
#endif // _3D_DISABLED
#endif
4 changes: 0 additions & 4 deletions scene/debugger/scene_debugger.h
Original file line number Diff line number Diff line change
Expand Up @@ -55,7 +55,6 @@ class SceneDebugger {

~SceneDebugger();

#ifdef DEBUG_ENABLED
private:
static void _handle_input(const Ref<InputEvent> &p_event, const Ref<Shortcut> &p_shortcut);

Expand All @@ -70,10 +69,8 @@ class SceneDebugger {
static void add_to_cache(const String &p_filename, Node *p_node);
static void remove_from_cache(const String &p_filename, Node *p_node);
static void reload_cached_files(const PackedStringArray &p_files);
#endif
};

#ifdef DEBUG_ENABLED
class SceneDebuggerObject {
private:
void _parse_script_properties(Script *p_script, ScriptInstance *p_instance);
Expand Down Expand Up @@ -322,6 +319,5 @@ class RuntimeNodeSelect : public Object {

~RuntimeNodeSelect();
};
#endif

#endif // SCENE_DEBUGGER_H
4 changes: 4 additions & 0 deletions scene/register_scene_types.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1239,15 +1239,19 @@ void register_scene_types() {
GraphEdit::init_shaders();
}

#ifdef DEBUGGER_ENABLED
SceneDebugger::initialize();
#endif

OS::get_singleton()->benchmark_end_measure("Scene", "Register Types");
}

void unregister_scene_types() {
OS::get_singleton()->benchmark_begin_measure("Scene", "Unregister Types");

#ifdef DEBUGGER_ENABLED
SceneDebugger::deinitialize();
#endif

ResourceLoader::remove_resource_format_loader(resource_loader_texture_layered);
resource_loader_texture_layered.unref();
Expand Down
3 changes: 2 additions & 1 deletion servers/SCsub
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,8 @@ env.add_source_files(env.servers_sources, "text_server.cpp")

SConscript("audio/SCsub")
SConscript("camera/SCsub")
SConscript("debugger/SCsub")
if env["enable_engine_debugger"]:
SConscript("debugger/SCsub")
SConscript("display/SCsub")
SConscript("extensions/SCsub")
SConscript("movie_writer/SCsub")
Expand Down
4 changes: 4 additions & 0 deletions servers/register_server_types.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -247,7 +247,9 @@ void register_server_types() {

GDREGISTER_VIRTUAL_CLASS(MovieWriter);

#ifdef DEBUGGER_ENABLED
ServersDebugger::initialize();
#endif

// Physics 2D
GDREGISTER_CLASS(PhysicsServer2DManager);
Expand Down Expand Up @@ -337,7 +339,9 @@ void register_server_types() {
void unregister_server_types() {
OS::get_singleton()->benchmark_begin_measure("Servers", "Unregister Extensions");

#ifdef DEBUGGER_ENABLED
ServersDebugger::deinitialize();
#endif
memdelete(shader_types);
memdelete(writer_mjpeg);
memdelete(writer_pngwav);
Expand Down

0 comments on commit 8df9ac6

Please sign in to comment.