Details
-
Bug
-
Status: Closed
-
Major
-
Resolution: Fixed
-
2.4.4
-
None
-
None
Description
The following…
interface Action<T> { void exec(T thing) } interface Block { void exec() } class Container { void m(Action<?> action) {} void m(Block block) {} } def c = new Container() c.m { -> 1 }
Yields…
groovy.lang.GroovyRuntimeException: Ambiguous method overloading for method Container#m. Cannot resolve which method to invoke for [class ConsoleScript0$_run_closure1] due to overlapping prototypes between: [interface Action] [interface Block] at ConsoleScript0.run(ConsoleScript0:16)
It seems that Groovy should be able to deal with the case where the SAM parameter signatures are different. Java does this with lambda expressions. That is, the following works in Java…
Container c = new Container();
c.m(() -> {});
c.m(arg -> {});
Attachments
Issue Links
- relates to
-
GROOVY-11010 Ambiguous method reference when expecting a SAM type
- Open
-
GROOVY-11121 unexpected error when having overloaded methods, one of which receiving an Iterable
- Closed