Merge pull request #59358 from strank/debug-inner-classes

This commit is contained in:
George Marques 2022-06-15 10:37:18 -03:00 committed by GitHub
commit 1aa6e33bf5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -134,6 +134,34 @@ static void test_parser(const String &p_code, const String &p_script_path, const
#endif #endif
} }
static void recursively_disassemble_functions(const Ref<GDScript> script, const Vector<String> &p_lines) {
for (const KeyValue<StringName, GDScriptFunction *> &E : script->get_member_functions()) {
const GDScriptFunction *func = E.value;
String signature = "Disassembling " + func->get_name().operator String() + "(";
for (int i = 0; i < func->get_argument_count(); i++) {
if (i > 0) {
signature += ", ";
}
signature += func->get_argument_name(i);
}
print_line(signature + ")");
#ifdef TOOLS_ENABLED
func->disassemble(p_lines);
#endif
print_line("");
print_line("");
}
for (const KeyValue<StringName, Ref<GDScript>> &F : script->get_subclasses()) {
const Ref<GDScript> inner_script = F.value;
print_line("");
print_line(vformat("Inner Class: %s", inner_script->get_script_class_name()));
print_line("");
recursively_disassemble_functions(inner_script, p_lines);
}
}
static void test_compiler(const String &p_code, const String &p_script_path, const Vector<String> &p_lines) { static void test_compiler(const String &p_code, const String &p_script_path, const Vector<String> &p_lines) {
GDScriptParser parser; GDScriptParser parser;
Error err = parser.parse(p_code, p_script_path, false); Error err = parser.parse(p_code, p_script_path, false);
@ -172,23 +200,7 @@ static void test_compiler(const String &p_code, const String &p_script_path, con
return; return;
} }
for (const KeyValue<StringName, GDScriptFunction *> &E : script->get_member_functions()) { recursively_disassemble_functions(script, p_lines);
const GDScriptFunction *func = E.value;
String signature = "Disassembling " + func->get_name().operator String() + "(";
for (int i = 0; i < func->get_argument_count(); i++) {
if (i > 0) {
signature += ", ";
}
signature += func->get_argument_name(i);
}
print_line(signature + ")");
#ifdef TOOLS_ENABLED
func->disassemble(p_lines);
#endif
print_line("");
print_line("");
}
} }
void test(TestType p_type) { void test(TestType p_type) {