Commit 83a3da2
committed
[jvm] fix self-recursing Object bridge for closures with non-Object typed return
When a closure's typed return is a specific reference type (e.g. SyncStats)
and a functional interface in the conversion set has an Object-erased
abstract method also named `invoke` — the shape of Function0<T>,
Callable<V> after erasure — the FI loop in jvmFunctions.generate_invoke
synthesized an `Object invoke()` bridge but pointed it at
(meth.name, meth.dargs, meth.dret). At that program point meth came from
register_signature with dret already declassified to Object, so the bridge
body emitted `invokevirtual invoke()Object` against itself. The later
`loop meth_typed` block that would have produced the proper Object→typed
bridge was then short-circuited by has_method (the slot was already taken).
First invocation StackOverflowError'd.
Forward to (meth.name, arg_sigs, ret) — the typed invoke that was actually
spawned earlier in generate_invoke — so the Object-returning bridge
dispatches to the real implementation and casts the result on return.
Repro shape (also added as a misc/jvm test extending StructuralSam):
public interface GenericInvoke<T> { T invoke(); }
Listeners.runGenericInvoke(() -> new Boxed(7));1 parent 52e31ac commit 83a3da2
5 files changed
Lines changed: 60 additions & 11 deletions
File tree
- src/generators/jvm
- tests/misc/jvm/projects/StructuralSam
- project/test
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
411 | 411 | | |
412 | 412 | | |
413 | 413 | | |
414 | | - | |
| 414 | + | |
| 415 | + | |
| 416 | + | |
| 417 | + | |
| 418 | + | |
| 419 | + | |
| 420 | + | |
| 421 | + | |
| 422 | + | |
415 | 423 | | |
416 | 424 | | |
417 | 425 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
| 9 | + | |
9 | 10 | | |
10 | 11 | | |
11 | 12 | | |
| |||
50 | 51 | | |
51 | 52 | | |
52 | 53 | | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
53 | 68 | | |
54 | 69 | | |
55 | 70 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
17 | 17 | | |
18 | 18 | | |
19 | 19 | | |
20 | | - | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
21 | 23 | | |
Lines changed: 10 additions & 9 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | | - | |
3 | | - | |
4 | | - | |
5 | | - | |
6 | | - | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
7 | 7 | | |
8 | | - | |
9 | | - | |
| 8 | + | |
| 9 | + | |
10 | 10 | | |
11 | | - | |
12 | | - | |
| 11 | + | |
| 12 | + | |
13 | 13 | | |
| 14 | + | |
Lines changed: 23 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
123 | 123 | | |
124 | 124 | | |
125 | 125 | | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
126 | 149 | | |
0 commit comments