Commit 00e257d
committed
Do not generate certain interface mixin forwarders if not necessary
This affects indirectly extended java interfaces, bringing
the behavior closer to how scala 2 handles it. After this commit, the
methods from those interfaces will not be generated, if they are
unnecessary (e.g., where there is no conflict between parents when
calling that method) even if `-Xmixin-force-forwarders` is set to true.
Those previously added mixin forwarders caused meant that since specific
parents were referenced in those methods, they had to be added to the
`interfaces` array in the generated classfile (without being added to
the signature, which caused an issue with getInterfaces and
getGenericInterfaces not being equal).1 parent 74b9e85 commit 00e257d
File tree
6 files changed
+38
-1
lines changed- compiler/src/dotty/tools/dotc/transform
- tests/run
- i21177a
- i21177b
6 files changed
+38
-1
lines changed| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
67 | 67 | | |
68 | 68 | | |
69 | 69 | | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
70 | 77 | | |
71 | 78 | | |
72 | | - | |
| 79 | + | |
73 | 80 | | |
74 | 81 | | |
75 | 82 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
0 commit comments