summaryrefslogtreecommitdiffstats
path: root/modules/mono/csharp_script.cpp
diff options
context:
space:
mode:
authorRémi Verschelde <rverschelde@gmail.com>2024-04-22 12:53:47 +0200
committerRémi Verschelde <rverschelde@gmail.com>2024-04-22 12:53:47 +0200
commit2b42352c99f5d4cf16ab83a9995b8a61eeb5e861 (patch)
treebb7b49e98905ccc22202b4fdf818fa4f214735f3 /modules/mono/csharp_script.cpp
parente7dc4b4b6bb67efd708adb8eb01e37c22a06dc30 (diff)
parent7316918a0f546f9fa406fd65b9a70161169426a8 (diff)
downloadredot-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.cpp11
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) {