2014-02-10 02:10:30 +01:00
|
|
|
/*************************************************************************/
|
|
|
|
/* script_debugger_remote.h */
|
|
|
|
/*************************************************************************/
|
|
|
|
/* This file is part of: */
|
|
|
|
/* GODOT ENGINE */
|
2017-08-27 14:16:55 +02:00
|
|
|
/* https://godotengine.org */
|
2014-02-10 02:10:30 +01:00
|
|
|
/*************************************************************************/
|
2019-01-01 12:53:14 +01:00
|
|
|
/* Copyright (c) 2007-2019 Juan Linietsky, Ariel Manzur. */
|
|
|
|
/* Copyright (c) 2014-2019 Godot Engine contributors (cf. AUTHORS.md) */
|
2014-02-10 02:10:30 +01:00
|
|
|
/* */
|
|
|
|
/* 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. */
|
|
|
|
/*************************************************************************/
|
2018-01-05 00:50:27 +01:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
#ifndef SCRIPT_DEBUGGER_REMOTE_H
|
|
|
|
#define SCRIPT_DEBUGGER_REMOTE_H
|
|
|
|
|
2018-09-11 18:13:45 +02:00
|
|
|
#include "core/io/packet_peer.h"
|
|
|
|
#include "core/io/stream_peer_tcp.h"
|
|
|
|
#include "core/list.h"
|
|
|
|
#include "core/os/os.h"
|
|
|
|
#include "core/script_language.h"
|
2015-10-21 14:50:44 +02:00
|
|
|
|
2019-04-06 22:55:01 +02:00
|
|
|
class SceneTree;
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
class ScriptDebuggerRemote : public ScriptDebugger {
|
|
|
|
|
|
|
|
struct Message {
|
|
|
|
|
|
|
|
String message;
|
|
|
|
Array data;
|
|
|
|
};
|
|
|
|
|
2016-05-22 02:18:16 +02:00
|
|
|
struct ProfileInfoSort {
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
bool operator()(ScriptLanguage::ProfilingInfo *A, ScriptLanguage::ProfilingInfo *B) const {
|
2016-05-22 02:18:16 +02:00
|
|
|
return A->total_time < B->total_time;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
Vector<ScriptLanguage::ProfilingInfo> profile_info;
|
2017-03-05 16:44:50 +01:00
|
|
|
Vector<ScriptLanguage::ProfilingInfo *> profile_info_ptrs;
|
2019-09-01 18:38:58 +02:00
|
|
|
Vector<MultiplayerAPI::ProfilingInfo> network_profile_info;
|
2016-05-22 02:18:16 +02:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
Map<StringName, int> profiler_function_signature_map;
|
2017-09-30 16:19:07 +02:00
|
|
|
float frame_time, idle_time, physics_time, physics_frame_time;
|
2016-05-22 02:18:16 +02:00
|
|
|
|
|
|
|
bool profiling;
|
2019-09-01 18:38:58 +02:00
|
|
|
bool profiling_network;
|
2016-05-22 02:18:16 +02:00
|
|
|
int max_frame_functions;
|
|
|
|
bool skip_profile_frame;
|
2016-06-02 01:22:02 +02:00
|
|
|
bool reload_all_scripts;
|
2016-05-22 02:18:16 +02:00
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
Ref<StreamPeerTCP> tcp_client;
|
|
|
|
Ref<PacketPeerStream> packet_peer_stream;
|
|
|
|
|
|
|
|
uint64_t last_perf_time;
|
2019-09-01 18:38:58 +02:00
|
|
|
uint64_t last_net_prof_time;
|
|
|
|
uint64_t last_net_bandwidth_time;
|
2014-02-10 02:10:30 +01:00
|
|
|
Object *performance;
|
|
|
|
bool requested_quit;
|
|
|
|
Mutex *mutex;
|
2015-08-04 14:47:32 +02:00
|
|
|
|
|
|
|
struct OutputError {
|
|
|
|
|
|
|
|
int hr;
|
|
|
|
int min;
|
|
|
|
int sec;
|
|
|
|
int msec;
|
|
|
|
String source_file;
|
|
|
|
String source_func;
|
|
|
|
int source_line;
|
|
|
|
String error;
|
|
|
|
String error_descr;
|
|
|
|
bool warning;
|
|
|
|
Array callstack;
|
|
|
|
};
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
List<String> output_strings;
|
|
|
|
List<Message> messages;
|
2018-01-03 17:04:10 +01:00
|
|
|
int max_messages_per_frame;
|
|
|
|
int n_messages_dropped;
|
2015-08-04 14:47:32 +02:00
|
|
|
List<OutputError> errors;
|
2019-07-31 17:24:53 +02:00
|
|
|
int max_errors_per_second;
|
|
|
|
int max_warnings_per_second;
|
2018-01-03 17:04:10 +01:00
|
|
|
int n_errors_dropped;
|
2019-07-31 17:24:53 +02:00
|
|
|
int n_warnings_dropped;
|
2015-08-04 14:47:32 +02:00
|
|
|
|
|
|
|
int max_cps;
|
|
|
|
int char_count;
|
2019-07-31 17:24:53 +02:00
|
|
|
int err_count;
|
|
|
|
int warn_count;
|
2015-08-04 14:47:32 +02:00
|
|
|
uint64_t last_msec;
|
|
|
|
uint64_t msec_count;
|
2014-02-10 02:10:30 +01:00
|
|
|
|
|
|
|
bool locking; //hack to avoid a deadloop
|
2017-11-14 23:01:45 +01:00
|
|
|
static void _print_handler(void *p_this, const String &p_string, bool p_error);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
|
|
|
PrintHandlerList phl;
|
|
|
|
|
|
|
|
void _get_output();
|
|
|
|
void _poll_events();
|
|
|
|
uint32_t poll_every;
|
|
|
|
|
2019-04-06 22:55:01 +02:00
|
|
|
SceneTree *scene_tree;
|
2015-08-02 17:29:37 +02:00
|
|
|
|
2019-04-06 22:55:01 +02:00
|
|
|
bool _parse_live_edit(const Array &p_command);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
void _set_object_property(ObjectID p_id, const String &p_property, const Variant &p_value);
|
2016-05-23 00:28:37 +02:00
|
|
|
|
|
|
|
void _send_object_id(ObjectID p_id);
|
2015-10-21 14:50:44 +02:00
|
|
|
void _send_video_memory();
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2019-09-01 18:38:58 +02:00
|
|
|
Ref<MultiplayerAPI> multiplayer;
|
|
|
|
|
2015-08-04 14:47:32 +02:00
|
|
|
ErrorHandlerList eh;
|
2017-03-05 16:44:50 +01:00
|
|
|
static void _err_handler(void *, const char *, const char *, int p_line, const char *, const char *, ErrorHandlerType p_type);
|
2015-08-04 14:47:32 +02:00
|
|
|
|
2016-05-22 02:18:16 +02:00
|
|
|
void _send_profiling_data(bool p_for_frame);
|
2019-09-01 18:38:58 +02:00
|
|
|
void _send_network_profiling_data();
|
|
|
|
void _send_network_bandwidth_usage();
|
2016-05-22 02:18:16 +02:00
|
|
|
|
|
|
|
struct FrameData {
|
|
|
|
|
|
|
|
StringName name;
|
|
|
|
Array data;
|
|
|
|
};
|
|
|
|
|
|
|
|
Vector<FrameData> profile_frame_data;
|
|
|
|
|
2017-08-18 15:59:31 +02:00
|
|
|
void _put_variable(const String &p_name, const Variant &p_variable);
|
|
|
|
|
2018-02-21 16:07:49 +01:00
|
|
|
void _save_node(ObjectID id, const String &p_path);
|
|
|
|
|
2019-07-29 20:09:22 +02:00
|
|
|
bool skip_breakpoints;
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
public:
|
2015-10-21 14:50:44 +02:00
|
|
|
struct ResourceUsage {
|
|
|
|
|
|
|
|
String path;
|
|
|
|
String format;
|
|
|
|
String type;
|
|
|
|
RID id;
|
|
|
|
int vram;
|
2017-03-05 16:44:50 +01:00
|
|
|
bool operator<(const ResourceUsage &p_img) const { return vram == p_img.vram ? id < p_img.id : vram > p_img.vram; }
|
2015-10-21 14:50:44 +02:00
|
|
|
};
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
typedef void (*ResourceUsageFunc)(List<ResourceUsage> *);
|
2015-10-21 14:50:44 +02:00
|
|
|
|
|
|
|
static ResourceUsageFunc resource_usage_func;
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
Error connect_to_host(const String &p_host, uint16_t p_port);
|
2019-07-29 20:09:22 +02:00
|
|
|
virtual void debug(ScriptLanguage *p_script, bool p_can_continue = true, bool p_is_error_breakpoint = false);
|
2014-02-10 02:10:30 +01:00
|
|
|
virtual void idle_poll();
|
|
|
|
virtual void line_poll();
|
|
|
|
|
|
|
|
virtual bool is_remote() const { return true; }
|
|
|
|
virtual void request_quit();
|
|
|
|
|
2017-03-05 16:44:50 +01:00
|
|
|
virtual void send_message(const String &p_message, const Array &p_args);
|
2018-01-09 17:19:03 +01:00
|
|
|
virtual void send_error(const String &p_func, const String &p_file, int p_line, const String &p_err, const String &p_descr, ErrorHandlerType p_type, const Vector<ScriptLanguage::StackInfo> &p_stack_info);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2019-09-01 18:38:58 +02:00
|
|
|
virtual void set_multiplayer(Ref<MultiplayerAPI> p_multiplayer);
|
2014-02-10 02:10:30 +01:00
|
|
|
|
2016-05-22 02:18:16 +02:00
|
|
|
virtual bool is_profiling() const;
|
2017-03-05 16:44:50 +01:00
|
|
|
virtual void add_profiling_frame_data(const StringName &p_name, const Array &p_data);
|
2016-05-22 02:18:16 +02:00
|
|
|
|
|
|
|
virtual void profiling_start();
|
|
|
|
virtual void profiling_end();
|
2017-09-30 16:19:07 +02:00
|
|
|
virtual void profiling_set_frame_times(float p_frame_time, float p_idle_time, float p_physics_time, float p_physics_frame_time);
|
2016-06-02 01:22:02 +02:00
|
|
|
|
2019-07-29 20:09:22 +02:00
|
|
|
virtual void set_skip_breakpoints(bool p_skip_breakpoints);
|
|
|
|
|
2019-04-06 22:55:01 +02:00
|
|
|
void set_scene_tree(SceneTree *p_scene_tree) { scene_tree = p_scene_tree; };
|
|
|
|
|
2014-02-10 02:10:30 +01:00
|
|
|
ScriptDebuggerRemote();
|
|
|
|
~ScriptDebuggerRemote();
|
|
|
|
};
|
|
|
|
|
|
|
|
#endif // SCRIPT_DEBUGGER_REMOTE_H
|