Title: Resolution fails for an overloaded CLR method when providing mixed float & int arguments via Python · Issue #1040 · pythonnet/pythonnet · GitHub
Open Graph Title: Resolution fails for an overloaded CLR method when providing mixed float & int arguments via Python · Issue #1040 · pythonnet/pythonnet
X Title: Resolution fails for an overloaded CLR method when providing mixed float & int arguments via Python · Issue #1040 · pythonnet/pythonnet
Description: Environment Pythonnet version: 2.4.0 Python version: 3.7.6 Operating System: Windows 10 Details Given a CLR method Foo with overloads Foo(int a, int b) and Foo(float a, float b), calling Foo from Python with one int and one float argumen...
Open Graph Description: Environment Pythonnet version: 2.4.0 Python version: 3.7.6 Operating System: Windows 10 Details Given a CLR method Foo with overloads Foo(int a, int b) and Foo(float a, float b), calling Foo from P...
X Description: Environment Pythonnet version: 2.4.0 Python version: 3.7.6 Operating System: Windows 10 Details Given a CLR method Foo with overloads Foo(int a, int b) and Foo(float a, float b), calling Foo from P...
Opengraph URL: https://github.com/pythonnet/pythonnet/issues/1040
X: @github
Domain: github.com
{"@context":"https://schema.org","@type":"DiscussionForumPosting","headline":"Resolution fails for an overloaded CLR method when providing mixed float \u0026 int arguments via Python","articleBody":"### Environment\r\n\r\n- Pythonnet version: 2.4.0\r\n- Python version: 3.7.6\r\n- Operating System: Windows 10\r\n\r\n### Details\r\n\r\nGiven a CLR method `Foo` with overloads `Foo(int a, int b)` and `Foo(float a, float b)`, calling `Foo` from Python with one `int` and one `float` argument results in a `TypeError: no method matches given arguments for Foo`. \r\n\r\nIf the method is not overloaded and only exists in the `Foo(float a, float b)` form, then calling from Python with one `int` and one `float` works fine, as does two `ints`, since the `int` arguments can be freely converted to `float`. The existence of the overload prevents this somehow.\r\n\r\nI looked through the existing method resolution issues and didn't see this case.\r\n\r\n### Full example\r\n\r\n_MyModule\\MyClass.cs_\r\n```cs\r\nusing System;\r\n\r\nnamespace MyModule\r\n{\r\n public class MyClass\r\n {\r\n public static float Add(float a, float b)\r\n {\r\n return a + b;\r\n }\r\n \r\n public static int Add(int a, int b)\r\n {\r\n return a + b;\r\n }\r\n }\r\n}\r\n```\r\n_PythonNetFloatTest\\Program.cs_\r\n```cs\r\nusing Python.Runtime;\r\n\r\nnamespace PythonNetFloatTest\r\n{\r\n class Program\r\n {\r\n static void Main(string[] args)\r\n {\r\n string preamble =\r\n \"import clr\\n\" +\r\n \"clr.AddReference('MyModule')\\n\" +\r\n \"from MyModule import MyClass\\n\" +\r\n \"import sys\\n\" +\r\n \"print(sys.version)\";\r\n\r\n string callWithFloatArgs = \"result = MyClass.Add(1.0, 2.0)\";\r\n string callWithIntArgs = \"result = MyClass.Add(1, 2)\";\r\n string callWithMixedArgs = \"result = MyClass.Add(1.0, 2)\";\r\n\r\n PythonEngine.Initialize();\r\n using (Py.GIL())\r\n {\r\n using (PyScope scope = Py.CreateScope())\r\n {\r\n scope.Exec(preamble);\r\n \r\n scope.Exec(callWithFloatArgs);\r\n System.Console.WriteLine(scope.Get(\"result\")); // prints \"3.0\"\r\n\r\n scope.Exec(callWithIntArgs);\r\n System.Console.WriteLine(scope.Get(\"result\")); // prints \"3\"\r\n\r\n scope.Exec(callWithMixedArgs); // throws Python.Runtime.PythonException: \r\n // 'TypeError : No method matches given arguments for Add'\r\n System.Console.WriteLine(scope.Get(\"result\"));\r\n }\r\n }\r\n }\r\n }\r\n}\r\n```\r\nOutput:\r\n```\r\n3.7.6 (tags/v3.7.6:43364a7ae0, Dec 19 2019, 00:42:30) [MSC v.1916 64 bit (AMD64)]\r\n3.0\r\n3\r\n\r\nUnhandled Exception: Python.Runtime.PythonException: TypeError : No method matches given arguments for Add\r\n at Python.Runtime.Runtime.CheckExceptionOccurred()\r\n at Python.Runtime.PyScope.Exec(String code, IntPtr _globals, IntPtr _locals)\r\n at PythonNetFloatTest.Program.Main(String[] args) in .\\PythonNetFloatTest\\PythonNetFloatTest\\Program.cs:line 33\r\n```\r\n\r\nIf you remove the `public static int Add(int a, int b)` overload from `MyModule`, the output is instead:\r\n\r\n```\r\n3.7.6 (tags/v3.7.6:43364a7ae0, Dec 19 2019, 00:42:30) [MSC v.1916 64 bit (AMD64)]\r\n3.0\r\n3.0\r\n3.0\r\n```\r\n\r\n","author":{"url":"https://github.com/Dewb","@type":"Person","name":"Dewb"},"datePublished":"2020-02-05T02:51:09.000Z","interactionStatistic":{"@type":"InteractionCounter","interactionType":"https://schema.org/CommentAction","userInteractionCount":3},"url":"https://github.com/1040/pythonnet/issues/1040"}
| route-pattern | /_view_fragments/issues/show/:user_id/:repository/:id/issue_layout(.:format) |
| route-controller | voltron_issues_fragments |
| route-action | issue_layout |
| fetch-nonce | v2:33c08e81-a5b8-85ae-1a44-a0da19f416db |
| current-catalog-service-hash | 81bb79d38c15960b92d99bca9288a9108c7a47b18f2423d0f6438c5b7bcd2114 |
| request-id | BEB2:3FA0DD:4F3F14:6786C5:697305B8 |
| html-safe-nonce | 66ddcc9fd6a86f3c18a04a2ec6833de53c18cfef610ee269f18ad01507e3e6b7 |
| visitor-payload | eyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiJCRUIyOjNGQTBERDo0RjNGMTQ6Njc4NkM1OjY5NzMwNUI4IiwidmlzaXRvcl9pZCI6IjYyODE2MDg1MTY2NzUxODkwNCIsInJlZ2lvbl9lZGdlIjoiaWFkIiwicmVnaW9uX3JlbmRlciI6ImlhZCJ9 |
| visitor-hmac | dea4cb2096a31afede3aa3eaffdbbfffe5f91f7475e8757637204b0eddb790a8 |
| hovercard-subject-tag | issue:560107463 |
| github-keyboard-shortcuts | repository,issues,copilot |
| google-site-verification | Apib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I |
| octolytics-url | https://collector.github.com/github/collect |
| analytics-location | / |
| fb:app_id | 1401488693436528 |
| apple-itunes-app | app-id=1477376905, app-argument=https://github.com/_view_fragments/issues/show/pythonnet/pythonnet/1040/issue_layout |
| twitter:image | https://opengraph.githubassets.com/a345085324fb142551557c81b2f425656126c852d8f4349e32d2c8cd3cdb2c74/pythonnet/pythonnet/issues/1040 |
| twitter:card | summary_large_image |
| og:image | https://opengraph.githubassets.com/a345085324fb142551557c81b2f425656126c852d8f4349e32d2c8cd3cdb2c74/pythonnet/pythonnet/issues/1040 |
| og:image:alt | Environment Pythonnet version: 2.4.0 Python version: 3.7.6 Operating System: Windows 10 Details Given a CLR method Foo with overloads Foo(int a, int b) and Foo(float a, float b), calling Foo from P... |
| og:image:width | 1200 |
| og:image:height | 600 |
| og:site_name | GitHub |
| og:type | object |
| og:author:username | Dewb |
| hostname | github.com |
| expected-hostname | github.com |
| None | 44ab3188c1dcfe3be0f9c3feca2e04e14fb79f120939ce2395e4f15ab96ec1d4 |
| turbo-cache-control | no-preview |
| go-import | github.com/pythonnet/pythonnet git https://github.com/pythonnet/pythonnet.git |
| octolytics-dimension-user_id | 6050430 |
| octolytics-dimension-user_login | pythonnet |
| octolytics-dimension-repository_id | 14748123 |
| octolytics-dimension-repository_nwo | pythonnet/pythonnet |
| octolytics-dimension-repository_public | true |
| octolytics-dimension-repository_is_fork | false |
| octolytics-dimension-repository_network_root_id | 14748123 |
| octolytics-dimension-repository_network_root_nwo | pythonnet/pythonnet |
| turbo-body-classes | logged-out env-production page-responsive |
| disable-turbo | false |
| browser-stats-url | https://api.github.com/_private/browser/stats |
| browser-errors-url | https://api.github.com/_private/browser/errors |
| release | a5e2b48bd1260476599758f5d253b5d24092ab84 |
| ui-target | full |
| theme-color | #1e2327 |
| color-scheme | light dark |
Links:
Viewport: width=device-width