Merge pull request #72312 from KoBeWi/signature_move
Improve Connection Dialog method list
This commit is contained in:
commit
17a8597355
2 changed files with 46 additions and 40 deletions
|
@ -186,7 +186,7 @@ void ConnectDialog::_unbind_count_changed(double p_count) {
|
|||
|
||||
void ConnectDialog::_method_selected() {
|
||||
TreeItem *selected_item = method_tree->get_selected();
|
||||
dst_method->set_text(selected_item->get_text(0));
|
||||
dst_method->set_text(selected_item->get_metadata(0));
|
||||
}
|
||||
|
||||
/*
|
||||
|
@ -260,12 +260,8 @@ StringName ConnectDialog::generate_method_callback_name(Node *p_source, String p
|
|||
void ConnectDialog::_create_method_tree_items(const List<MethodInfo> &p_methods, TreeItem *p_parent_item) {
|
||||
for (const MethodInfo &mi : p_methods) {
|
||||
TreeItem *method_item = method_tree->create_item(p_parent_item);
|
||||
method_item->set_text(0, mi.name);
|
||||
if (mi.return_val.type == Variant::NIL) {
|
||||
method_item->set_icon(0, get_theme_icon(SNAME("Variant"), "EditorIcons"));
|
||||
} else {
|
||||
method_item->set_icon(0, get_theme_icon(Variant::get_type_name(mi.return_val.type), "EditorIcons"));
|
||||
}
|
||||
method_item->set_text(0, get_signature(mi));
|
||||
method_item->set_metadata(0, mi.name);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -293,6 +289,11 @@ List<MethodInfo> ConnectDialog::_filter_method_list(const List<MethodInfo> &p_me
|
|||
type_mismatch = true;
|
||||
break;
|
||||
}
|
||||
|
||||
if (stype == Variant::OBJECT && mtype == Variant::OBJECT && E->get().class_name != F->get().class_name) {
|
||||
type_mismatch = true;
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
if (type_mismatch) {
|
||||
|
@ -488,6 +489,34 @@ Vector<Variant> ConnectDialog::get_binds() const {
|
|||
return cdbinds->params;
|
||||
}
|
||||
|
||||
String ConnectDialog::get_signature(const MethodInfo &p_method, PackedStringArray *r_arg_names) {
|
||||
PackedStringArray signature;
|
||||
signature.append(p_method.name);
|
||||
signature.append("(");
|
||||
|
||||
for (int i = 0; i < p_method.arguments.size(); i++) {
|
||||
if (i > 0) {
|
||||
signature.append(", ");
|
||||
}
|
||||
|
||||
const PropertyInfo &pi = p_method.arguments[i];
|
||||
String tname = "var";
|
||||
if (pi.type == Variant::OBJECT && pi.class_name != StringName()) {
|
||||
tname = pi.class_name.operator String();
|
||||
} else if (pi.type != Variant::NIL) {
|
||||
tname = Variant::get_type_name(pi.type);
|
||||
}
|
||||
|
||||
signature.append((pi.name.is_empty() ? String("arg " + itos(i)) : pi.name) + ": " + tname);
|
||||
if (r_arg_names) {
|
||||
r_arg_names->push_back(pi.name + ":" + tname);
|
||||
}
|
||||
}
|
||||
|
||||
signature.append(")");
|
||||
return String().join(signature);
|
||||
}
|
||||
|
||||
bool ConnectDialog::get_deferred() const {
|
||||
return deferred->is_pressed();
|
||||
}
|
||||
|
@ -545,7 +574,7 @@ void ConnectDialog::init(const ConnectionData &p_cd, const PackedStringArray &p_
|
|||
source_connection_data = p_cd;
|
||||
}
|
||||
|
||||
void ConnectDialog::popup_dialog(const String &p_for_signal) {
|
||||
void ConnectDialog::popup_dialog(const String p_for_signal) {
|
||||
from_signal->set_text(p_for_signal);
|
||||
error_label->add_theme_color_override("font_color", error_label->get_theme_color(SNAME("error_color"), SNAME("Editor")));
|
||||
if (!advanced->is_pressed()) {
|
||||
|
@ -972,8 +1001,6 @@ void ConnectionsDock::_open_connection_dialog(TreeItem &p_item) {
|
|||
String signal_name = sinfo["name"];
|
||||
PackedStringArray signal_args = sinfo["args"];
|
||||
|
||||
const String &signal_name_ref = signal_name;
|
||||
|
||||
Node *dst_node = selected_node->get_owner() ? selected_node->get_owner() : selected_node;
|
||||
if (!dst_node || dst_node->get_script().is_null()) {
|
||||
dst_node = _find_first_script(get_tree()->get_edited_scene_root(), get_tree()->get_edited_scene_root());
|
||||
|
@ -981,10 +1008,10 @@ void ConnectionsDock::_open_connection_dialog(TreeItem &p_item) {
|
|||
|
||||
ConnectDialog::ConnectionData cd;
|
||||
cd.source = selected_node;
|
||||
cd.signal = StringName(signal_name_ref);
|
||||
cd.signal = StringName(signal_name);
|
||||
cd.target = dst_node;
|
||||
cd.method = ConnectDialog::generate_method_callback_name(cd.source, signal_name, cd.target);
|
||||
connect_dialog->popup_dialog(signal_name_ref);
|
||||
connect_dialog->popup_dialog(signal_name + "(" + String(", ").join(signal_args) + ")");
|
||||
connect_dialog->init(cd, signal_args);
|
||||
connect_dialog->set_title(TTR("Connect a Signal to a Method"));
|
||||
}
|
||||
|
@ -1235,37 +1262,15 @@ void ConnectionsDock::update_tree() {
|
|||
}
|
||||
|
||||
for (MethodInfo &mi : node_signals2) {
|
||||
StringName signal_name = mi.name;
|
||||
String signaldesc = "(";
|
||||
PackedStringArray argnames;
|
||||
|
||||
String filter_text = search_box->get_text();
|
||||
if (!filter_text.is_subsequence_ofn(signal_name)) {
|
||||
const StringName signal_name = mi.name;
|
||||
if (!search_box->get_text().is_subsequence_ofn(signal_name)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if (mi.arguments.size()) {
|
||||
for (int i = 0; i < mi.arguments.size(); i++) {
|
||||
PropertyInfo &pi = mi.arguments[i];
|
||||
|
||||
if (i > 0) {
|
||||
signaldesc += ", ";
|
||||
}
|
||||
String tname = "var";
|
||||
if (pi.type == Variant::OBJECT && pi.class_name != StringName()) {
|
||||
tname = pi.class_name.operator String();
|
||||
} else if (pi.type != Variant::NIL) {
|
||||
tname = Variant::get_type_name(pi.type);
|
||||
}
|
||||
signaldesc += (pi.name.is_empty() ? String("arg " + itos(i)) : pi.name) + ": " + tname;
|
||||
argnames.push_back(pi.name + ":" + tname);
|
||||
}
|
||||
}
|
||||
signaldesc += ")";
|
||||
PackedStringArray argnames;
|
||||
|
||||
// Create the children of the subsection - the actual list of signals.
|
||||
TreeItem *signal_item = tree->create_item(section_item);
|
||||
String signame = String(signal_name) + signaldesc;
|
||||
String signame = connect_dialog->get_signature(mi, &argnames);
|
||||
signal_item->set_text(0, signame);
|
||||
|
||||
if (signame == prev_selected) {
|
||||
|
@ -1313,7 +1318,7 @@ void ConnectionsDock::update_tree() {
|
|||
}
|
||||
|
||||
// "::" separators used in make_custom_tooltip for formatting.
|
||||
signal_item->set_tooltip_text(0, String(signal_name) + "::" + signaldesc + "::" + descr);
|
||||
signal_item->set_tooltip_text(0, String(signal_name) + "::" + signame.trim_prefix(mi.name) + "::" + descr);
|
||||
}
|
||||
|
||||
// List existing connections.
|
||||
|
|
|
@ -172,6 +172,7 @@ public:
|
|||
void set_dst_method(const StringName &p_method);
|
||||
int get_unbinds() const;
|
||||
Vector<Variant> get_binds() const;
|
||||
String get_signature(const MethodInfo &p_method, PackedStringArray *r_arg_names = nullptr);
|
||||
|
||||
bool get_deferred() const;
|
||||
bool get_one_shot() const;
|
||||
|
@ -179,7 +180,7 @@ public:
|
|||
|
||||
void init(const ConnectionData &p_cd, const PackedStringArray &p_signal_args, bool p_edit = false);
|
||||
|
||||
void popup_dialog(const String &p_for_signal);
|
||||
void popup_dialog(const String p_for_signal);
|
||||
ConnectDialog();
|
||||
~ConnectDialog();
|
||||
};
|
||||
|
|
Loading…
Reference in a new issue