2020-02-27 03:30:20 +01:00
|
|
|
/**************************************************************************/
|
|
|
|
/* remote_debugger.h */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
|
|
|
/* https://godotengine.org */
|
|
|
|
/**************************************************************************/
|
|
|
|
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
|
|
|
|
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* */
|
|
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
|
|
/* a copy of this software and associated documentation files (the */
|
|
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
|
|
/* the following conditions: */
|
|
|
|
/* */
|
|
|
|
/* The above copyright notice and this permission notice shall be */
|
|
|
|
/* included in all copies or substantial portions of the Software. */
|
|
|
|
/* */
|
|
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
|
|
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
|
|
/**************************************************************************/
|
|
|
|
|
|
|
|
#ifndef REMOTE_DEBUGGER_H
|
|
|
|
#define REMOTE_DEBUGGER_H
|
|
|
|
|
|
|
|
#include "core/debugger/debugger_marshalls.h"
|
|
|
|
#include "core/debugger/engine_debugger.h"
|
|
|
|
#include "core/debugger/remote_debugger_peer.h"
|
2020-11-07 23:33:38 +01:00
|
|
|
#include "core/object/class_db.h"
|
|
|
|
#include "core/string/string_name.h"
|
|
|
|
#include "core/string/ustring.h"
|
|
|
|
#include "core/variant/array.h"
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
class RemoteDebugger : public EngineDebugger {
|
2020-05-01 18:23:51 +02:00
|
|
|
public:
|
|
|
|
enum MessageType {
|
|
|
|
MESSAGE_TYPE_LOG,
|
|
|
|
MESSAGE_TYPE_ERROR,
|
2022-05-03 01:29:38 +02:00
|
|
|
MESSAGE_TYPE_LOG_RICH,
|
2020-05-01 18:23:51 +02:00
|
|
|
};
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
private:
|
|
|
|
typedef DebuggerMarshalls::OutputError ErrorMessage;
|
|
|
|
|
2022-02-06 02:29:08 +01:00
|
|
|
class PerformanceProfiler;
|
2020-02-27 03:30:20 +01:00
|
|
|
|
2022-02-06 02:29:08 +01:00
|
|
|
Ref<PerformanceProfiler> performance_profiler;
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
Ref<RemoteDebuggerPeer> peer;
|
|
|
|
|
2020-05-01 18:23:51 +02:00
|
|
|
struct OutputString {
|
|
|
|
String message;
|
|
|
|
MessageType type;
|
|
|
|
};
|
|
|
|
List<OutputString> output_strings;
|
2020-02-27 03:30:20 +01:00
|
|
|
List<ErrorMessage> errors;
|
|
|
|
|
|
|
|
int n_messages_dropped = 0;
|
|
|
|
int max_errors_per_second = 0;
|
|
|
|
int max_chars_per_second = 0;
|
|
|
|
int max_warnings_per_second = 0;
|
|
|
|
int n_errors_dropped = 0;
|
|
|
|
int n_warnings_dropped = 0;
|
|
|
|
int char_count = 0;
|
|
|
|
int err_count = 0;
|
|
|
|
int warn_count = 0;
|
|
|
|
int last_reset = 0;
|
|
|
|
bool reload_all_scripts = false;
|
2023-12-30 08:06:54 +01:00
|
|
|
Array script_paths_to_reload;
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
// Make handlers and send_message thread safe.
|
|
|
|
Mutex mutex;
|
|
|
|
bool flushing = false;
|
|
|
|
Thread::ID flush_thread = 0;
|
|
|
|
|
2023-04-29 17:20:38 +02:00
|
|
|
struct Message {
|
|
|
|
String message;
|
|
|
|
Array data;
|
|
|
|
};
|
|
|
|
|
|
|
|
HashMap<Thread::ID, List<Message>> messages;
|
|
|
|
|
|
|
|
void _poll_messages();
|
|
|
|
bool _has_messages();
|
|
|
|
Array _get_message();
|
|
|
|
|
2020-02-27 03:30:20 +01:00
|
|
|
PrintHandlerList phl;
|
2022-05-03 01:29:38 +02:00
|
|
|
static void _print_handler(void *p_this, const String &p_string, bool p_error, bool p_rich);
|
2020-02-27 03:30:20 +01:00
|
|
|
ErrorHandlerList eh;
|
2021-09-22 17:36:40 +02:00
|
|
|
static void _err_handler(void *p_this, const char *p_func, const char *p_file, int p_line, const char *p_err, const char *p_descr, bool p_editor_notify, ErrorHandlerType p_type);
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
ErrorMessage _create_overflow_error(const String &p_what, const String &p_descr);
|
2024-01-09 02:36:19 +01:00
|
|
|
Error _put_msg(const String &p_message, const Array &p_data);
|
2020-02-27 03:30:20 +01:00
|
|
|
|
|
|
|
bool is_peer_connected() { return peer->is_peer_connected(); }
|
|
|
|
void flush_output();
|
|
|
|
|
|
|
|
void _send_stack_vars(List<String> &p_names, List<Variant> &p_vals, int p_type);
|
|
|
|
|
|
|
|
Error _profiler_capture(const String &p_cmd, const Array &p_data, bool &r_captured);
|
|
|
|
Error _core_capture(const String &p_cmd, const Array &p_data, bool &r_captured);
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
void _bind_profiler(const String &p_name, T *p_prof);
|
|
|
|
Error _try_capture(const String &p_name, const Array &p_data, bool &r_captured);
|
|
|
|
|
|
|
|
public:
|
|
|
|
// Overrides
|
|
|
|
void poll_events(bool p_is_idle);
|
|
|
|
void send_message(const String &p_message, const Array &p_args);
|
2021-09-22 17:36:40 +02:00
|
|
|
void send_error(const String &p_func, const String &p_file, int p_line, const String &p_err, const String &p_descr, bool p_editor_notify, ErrorHandlerType p_type);
|
2020-02-27 03:30:20 +01:00
|
|
|
void debug(bool p_can_continue = true, bool p_is_error_breakpoint = false);
|
|
|
|
|
2022-04-07 12:23:40 +02:00
|
|
|
explicit RemoteDebugger(Ref<RemoteDebuggerPeer> p_peer);
|
2020-02-27 03:30:20 +01:00
|
|
|
~RemoteDebugger();
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // REMOTE_DEBUGGER_H
|