Allow signal connecting even if script is invalid (only when compiled with tools), fixes #17070

This commit is contained in:
Juan Linietsky 2018-11-27 19:55:37 -03:00
parent 616b91b498
commit 3a93499f89
11 changed files with 33 additions and 4 deletions

View file

@ -1443,8 +1443,20 @@ Error Object::connect(const StringName &p_signal, Object *p_to_object, const Str
if (!s) { if (!s) {
bool signal_is_valid = ClassDB::has_signal(get_class_name(), p_signal); bool signal_is_valid = ClassDB::has_signal(get_class_name(), p_signal);
//check in script //check in script
if (!signal_is_valid && !script.is_null() && Ref<Script>(script)->has_script_signal(p_signal)) if (!signal_is_valid && !script.is_null()) {
signal_is_valid = true;
if (Ref<Script>(script)->has_script_signal(p_signal)) {
signal_is_valid = true;
}
#ifdef TOOLS_ENABLED
else {
//allow connecting signals anyway if script is invalid, see issue #17070
if (!Ref<Script>(script)->is_valid()) {
signal_is_valid = true;
}
}
#endif
}
if (!signal_is_valid) { if (!signal_is_valid) {
ERR_EXPLAIN("In Object of type '" + String(get_class()) + "': Attempt to connect nonexistent signal '" + p_signal + "' to method '" + p_to_object->get_class() + "." + p_to_method + "'"); ERR_EXPLAIN("In Object of type '" + String(get_class()) + "': Attempt to connect nonexistent signal '" + p_signal + "' to method '" + p_to_object->get_class() + "." + p_to_method + "'");

View file

@ -128,6 +128,7 @@ public:
virtual MethodInfo get_method_info(const StringName &p_method) const = 0; virtual MethodInfo get_method_info(const StringName &p_method) const = 0;
virtual bool is_tool() const = 0; virtual bool is_tool() const = 0;
virtual bool is_valid() const = 0;
virtual ScriptLanguage *get_language() const = 0; virtual ScriptLanguage *get_language() const = 0;

View file

@ -294,6 +294,10 @@ MethodInfo NativeScript::get_method_info(const StringName &p_method) const {
return MethodInfo(); return MethodInfo();
} }
bool NativeScript::is_valid() const {
return true;
}
bool NativeScript::is_tool() const { bool NativeScript::is_tool() const {
NativeScriptDesc *script_data = get_script_desc(); NativeScriptDesc *script_data = get_script_desc();

View file

@ -160,6 +160,7 @@ public:
virtual MethodInfo get_method_info(const StringName &p_method) const; virtual MethodInfo get_method_info(const StringName &p_method) const;
virtual bool is_tool() const; virtual bool is_tool() const;
virtual bool is_valid() const;
virtual ScriptLanguage *get_language() const; virtual ScriptLanguage *get_language() const;

View file

@ -102,6 +102,7 @@ public:
PropertyInfo get_property_info(const StringName &p_property) const; PropertyInfo get_property_info(const StringName &p_property) const;
bool is_tool() const { return _tool; } bool is_tool() const { return _tool; }
bool is_valid() const { return true; }
virtual ScriptLanguage *get_language() const; virtual ScriptLanguage *get_language() const;

View file

@ -867,7 +867,6 @@ bool GDScript::has_script_signal(const StringName &p_signal) const {
else if (base_cache.is_valid()) { else if (base_cache.is_valid()) {
return base_cache->has_script_signal(p_signal); return base_cache->has_script_signal(p_signal);
} }
#endif #endif
return false; return false;
} }

View file

@ -141,7 +141,7 @@ protected:
static void _bind_methods(); static void _bind_methods();
public: public:
bool is_valid() const { return valid; } virtual bool is_valid() const { return valid; }
const Map<StringName, Ref<GDScript> > &get_subclasses() const { return subclasses; } const Map<StringName, Ref<GDScript> > &get_subclasses() const { return subclasses; }
const Map<StringName, Variant> &get_constants() const { return constants; } const Map<StringName, Variant> &get_constants() const { return constants; }

View file

@ -2571,6 +2571,10 @@ void CSharpScript::update_exports() {
#endif #endif
} }
bool CSharpScript::is_valid() const {
return true; //TODO return false if invalid
}
bool CSharpScript::has_script_signal(const StringName &p_signal) const { bool CSharpScript::has_script_signal(const StringName &p_signal) const {
if (_signals.has(p_signal)) if (_signals.has(p_signal))
return true; return true;

View file

@ -158,6 +158,8 @@ public:
virtual void update_exports(); virtual void update_exports();
virtual bool is_tool() const { return tool; } virtual bool is_tool() const { return tool; }
virtual bool is_valid() const;
virtual Ref<Script> get_base_script() const; virtual Ref<Script> get_base_script() const;
virtual ScriptLanguage *get_language() const; virtual ScriptLanguage *get_language() const;

View file

@ -981,6 +981,10 @@ bool VisualScript::is_tool() const {
return false; return false;
} }
bool VisualScript::is_valid() const {
return true; //always valid
}
ScriptLanguage *VisualScript::get_language() const { ScriptLanguage *VisualScript::get_language() const {
return VisualScriptLanguage::singleton; return VisualScriptLanguage::singleton;

View file

@ -341,6 +341,7 @@ public:
virtual Error reload(bool p_keep_state = false); virtual Error reload(bool p_keep_state = false);
virtual bool is_tool() const; virtual bool is_tool() const;
virtual bool is_valid() const;
virtual ScriptLanguage *get_language() const; virtual ScriptLanguage *get_language() const;