diff options
author | Rémi Verschelde <rverschelde@gmail.com> | 2024-04-22 12:53:47 +0200 |
---|---|---|
committer | Rémi Verschelde <rverschelde@gmail.com> | 2024-04-22 12:53:47 +0200 |
commit | 2b42352c99f5d4cf16ab83a9995b8a61eeb5e861 (patch) | |
tree | bb7b49e98905ccc22202b4fdf818fa4f214735f3 /modules/mono/csharp_script.cpp | |
parent | e7dc4b4b6bb67efd708adb8eb01e37c22a06dc30 (diff) | |
parent | 7316918a0f546f9fa406fd65b9a70161169426a8 (diff) | |
download | redot-engine-2b42352c99f5d4cf16ab83a9995b8a61eeb5e861.tar.gz |
Merge pull request #90968 from raulsntos/fix-gdscript-analyzer-with-overloaded-dotnet-methods
C#: Don't return MethodInfo for overloaded methods
Diffstat (limited to 'modules/mono/csharp_script.cpp')
-rw-r--r-- | modules/mono/csharp_script.cpp | 11 |
1 files changed, 9 insertions, 2 deletions
diff --git a/modules/mono/csharp_script.cpp b/modules/mono/csharp_script.cpp index dcc18ebdd7..ff2ca9f0ce 100644 --- a/modules/mono/csharp_script.cpp +++ b/modules/mono/csharp_script.cpp @@ -2519,13 +2519,20 @@ MethodInfo CSharpScript::get_method_info(const StringName &p_method) const { return MethodInfo(); } + MethodInfo mi; for (const CSharpMethodInfo &E : methods) { if (E.name == p_method) { - return E.method_info; + if (mi.name == p_method) { + // We already found a method with the same name before so + // that means this method has overloads, the best we can do + // is return an empty MethodInfo. + return MethodInfo(); + } + mi = E.method_info; } } - return MethodInfo(); + return mi; } Variant CSharpScript::callp(const StringName &p_method, const Variant **p_args, int p_argcount, Callable::CallError &r_error) { |