You've already forked godot
mirror of
https://github.com/godotengine/godot.git
synced 2025-11-10 13:00:37 +00:00
Mono/C#: Fix values not updated in remote inspector
This commit is contained in:
@@ -2419,15 +2419,22 @@ bool CSharpScript::_update_exports() {
|
|||||||
StringName member_name = field->get_name();
|
StringName member_name = field->get_name();
|
||||||
|
|
||||||
member_info[member_name] = prop_info;
|
member_info[member_name] = prop_info;
|
||||||
#ifdef TOOLS_ENABLED
|
|
||||||
if (is_editor && exported) {
|
|
||||||
exported_members_cache.push_front(prop_info);
|
|
||||||
|
|
||||||
if (tmp_object) {
|
if (exported) {
|
||||||
exported_members_defval_cache[member_name] = GDMonoMarshal::mono_object_to_variant(field->get_value(tmp_object));
|
#ifdef TOOLS_ENABLED
|
||||||
|
if (is_editor) {
|
||||||
|
exported_members_cache.push_front(prop_info);
|
||||||
|
|
||||||
|
if (tmp_object) {
|
||||||
|
exported_members_defval_cache[member_name] = GDMonoMarshal::mono_object_to_variant(field->get_value(tmp_object));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(TOOLS_ENABLED) || defined(DEBUG_ENABLED)
|
||||||
|
exported_members_names.insert(member_name);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -2440,21 +2447,28 @@ bool CSharpScript::_update_exports() {
|
|||||||
StringName member_name = property->get_name();
|
StringName member_name = property->get_name();
|
||||||
|
|
||||||
member_info[member_name] = prop_info;
|
member_info[member_name] = prop_info;
|
||||||
|
|
||||||
|
if (exported) {
|
||||||
#ifdef TOOLS_ENABLED
|
#ifdef TOOLS_ENABLED
|
||||||
if (is_editor && exported) {
|
if (is_editor) {
|
||||||
exported_members_cache.push_front(prop_info);
|
exported_members_cache.push_front(prop_info);
|
||||||
if (tmp_object) {
|
if (tmp_object) {
|
||||||
MonoException *exc = nullptr;
|
MonoException *exc = nullptr;
|
||||||
MonoObject *ret = property->get_value(tmp_object, &exc);
|
MonoObject *ret = property->get_value(tmp_object, &exc);
|
||||||
if (exc) {
|
if (exc) {
|
||||||
exported_members_defval_cache[member_name] = Variant();
|
exported_members_defval_cache[member_name] = Variant();
|
||||||
GDMonoUtils::debug_print_unhandled_exception(exc);
|
GDMonoUtils::debug_print_unhandled_exception(exc);
|
||||||
} else {
|
} else {
|
||||||
exported_members_defval_cache[member_name] = GDMonoMarshal::mono_object_to_variant(ret);
|
exported_members_defval_cache[member_name] = GDMonoMarshal::mono_object_to_variant(ret);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(TOOLS_ENABLED) || defined(DEBUG_ENABLED)
|
||||||
|
exported_members_names.insert(member_name);
|
||||||
|
#endif
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -3591,6 +3605,16 @@ CSharpScript::~CSharpScript() {
|
|||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CSharpScript::get_members(Set<StringName> *p_members) {
|
||||||
|
#if defined(TOOLS_ENABLED) || defined(DEBUG_ENABLED)
|
||||||
|
if (p_members) {
|
||||||
|
for (Set<StringName>::Element *E = exported_members_names.front(); E; E = E->next()) {
|
||||||
|
p_members->insert(E->get());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/*************** RESOURCE ***************/
|
/*************** RESOURCE ***************/
|
||||||
|
|
||||||
RES ResourceFormatLoaderCSharpScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
RES ResourceFormatLoaderCSharpScript::load(const String &p_path, const String &p_original_path, Error *r_error, bool p_use_sub_threads, float *r_progress, bool p_no_cache) {
|
||||||
|
|||||||
@@ -138,6 +138,10 @@ private:
|
|||||||
virtual void _placeholder_erased(PlaceHolderScriptInstance *p_placeholder);
|
virtual void _placeholder_erased(PlaceHolderScriptInstance *p_placeholder);
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined(TOOLS_ENABLED) || defined(DEBUG_ENABLED)
|
||||||
|
Set<StringName> exported_members_names;
|
||||||
|
#endif
|
||||||
|
|
||||||
Map<StringName, PropertyInfo> member_info;
|
Map<StringName, PropertyInfo> member_info;
|
||||||
|
|
||||||
void _clear();
|
void _clear();
|
||||||
@@ -191,6 +195,8 @@ public:
|
|||||||
virtual void get_script_property_list(List<PropertyInfo> *p_list) const;
|
virtual void get_script_property_list(List<PropertyInfo> *p_list) const;
|
||||||
virtual void update_exports();
|
virtual void update_exports();
|
||||||
|
|
||||||
|
void get_members(Set<StringName> *p_members) override;
|
||||||
|
|
||||||
virtual bool is_tool() const { return tool; }
|
virtual bool is_tool() const { return tool; }
|
||||||
virtual bool is_valid() const { return valid; }
|
virtual bool is_valid() const { return valid; }
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user