summaryrefslogtreecommitdiffstats
path: root/core/object.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2020-03-23 16:16:25 +0100
committerGitHub <noreply@github.com>2020-03-23 16:16:25 +0100
commit20edf69f96160fcf7c0ea2449f4daf50f572ce99 (patch)
tree96ca71593fb38b96eba0f366a8120a374002e3ae /core/object.cpp
parentcbbe0743a9155f06d03d4b906209933192a02731 (diff)
parent258d91f883eb3db0ebc709f4f7e43ccb6948a7fc (diff)
downloadredot-engine-20edf69f96160fcf7c0ea2449f4daf50f572ce99.tar.gz
Merge pull request #33508 from nekomatata/object-has-signal
Added has_signal method for Object
Diffstat (limited to 'core/object.cpp')
-rw-r--r--core/object.cpp20
1 files changed, 20 insertions, 0 deletions
diff --git a/core/object.cpp b/core/object.cpp
index 140ee811fe..188c0ee5c2 100644
--- a/core/object.cpp
+++ b/core/object.cpp
@@ -1324,6 +1324,25 @@ Array Object::_get_incoming_connections() const {
return ret;
}
+bool Object::has_signal(const StringName &p_name) const {
+ if (!script.is_null()) {
+ Ref<Script> scr = script;
+ if (scr.is_valid() && scr->has_script_signal(p_name)) {
+ return true;
+ }
+ }
+
+ if (ClassDB::has_signal(get_class_name(), p_name)) {
+ return true;
+ }
+
+ if (_has_user_signal(p_name)) {
+ return true;
+ }
+
+ return false;
+}
+
void Object::get_signal_list(List<MethodInfo> *p_signals) const {
if (!script.is_null()) {
@@ -1696,6 +1715,7 @@ void Object::_bind_methods() {
ClassDB::bind_method(D_METHOD("has_method", "method"), &Object::has_method);
+ ClassDB::bind_method(D_METHOD("has_signal", "signal"), &Object::has_signal);
ClassDB::bind_method(D_METHOD("get_signal_list"), &Object::_get_signal_list);
ClassDB::bind_method(D_METHOD("get_signal_connection_list", "signal"), &Object::_get_signal_connection_list);
ClassDB::bind_method(D_METHOD("get_incoming_connections"), &Object::_get_incoming_connections);