Skip to content

Commit

Permalink
Fallback erasing term references
Browse files Browse the repository at this point in the history
  • Loading branch information
dwijnand committed Oct 20, 2023
1 parent 2fa54e8 commit f35261d
Show file tree
Hide file tree
Showing 3 changed files with 9 additions and 2 deletions.
3 changes: 1 addition & 2 deletions compiler/src/dotty/tools/dotc/core/TypeErasure.scala
Original file line number Diff line number Diff line change
Expand Up @@ -239,8 +239,7 @@ object TypeErasure {
* TermRefs are kept instead of being widened away.
*/
def erasedRef(tp: Type)(using Context): Type = tp match {
case tp: TermRef =>
assert(tp.symbol.exists, tp)
case tp: TermRef if tp.symbol.exists =>
val tp1 = makePackageObjPrefixExplicit(tp)
if (tp1 ne tp) erasedRef(tp1)
else TermRef(erasedRef(tp.prefix), tp.symbol.asTerm)
Expand Down
5 changes: 5 additions & 0 deletions tests/pos/i18721.min/core.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
class Foo
class Bar extends Selectable:
def selectDynamic(name: String): Foo = null

inline def meth(inline foo: Foo): Foo = foo
3 changes: 3 additions & 0 deletions tests/pos/i18721.min/main.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
class Test:
def t1(bar: Bar { val foo: Foo }): Any =
meth(bar.foo)

0 comments on commit f35261d

Please sign in to comment.