Skip to content

Commit

Permalink
Mark genSJSIR as *disabled* (rather than non-*runnable*) when no `-sc…
Browse files Browse the repository at this point in the history
…alajs`. (#20815)

This works around the issue seen in #20296. However, the issue
resurfaces if we actually run `-Ycheck:all` in a Scala.js-enabled build.
  • Loading branch information
sjrd authored Jun 28, 2024
2 parents 41f1489 + a88312b commit fff4ee6
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 2 deletions.
5 changes: 4 additions & 1 deletion compiler/src/dotty/tools/backend/sjs/GenSJSIR.scala
Original file line number Diff line number Diff line change
Expand Up @@ -11,8 +11,11 @@ class GenSJSIR extends Phase {

override def description: String = GenSJSIR.description

override def isEnabled(using Context): Boolean =
ctx.settings.scalajs.value

override def isRunnable(using Context): Boolean =
super.isRunnable && ctx.settings.scalajs.value && !ctx.usedBestEffortTasty
super.isRunnable && !ctx.usedBestEffortTasty

def run(using Context): Unit =
new JSCodeGen().run()
Expand Down
1 change: 0 additions & 1 deletion sbt-bridge/test/xsbt/CompileProgressSpecification.scala
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,6 @@ class CompileProgressSpecification {
"MegaPhase{pruneErasedDefs,...,arrayConstructors}",
"erasure",
"constructors",
"genSJSIR",
"genBCode"
)
val missingExpectedPhases = someExpectedPhases -- allPhases.toSet
Expand Down
14 changes: 14 additions & 0 deletions tests/pos/i20296.scala
Original file line number Diff line number Diff line change
@@ -0,0 +1,14 @@
trait Foo

object Foo {
inline def bar(): Foo =
class InlinedFoo extends Foo {}
new InlinedFoo

inline def foo(): Foo =
bar()
class InlinedFoo extends Foo {}
new InlinedFoo

def Test: Foo = Foo.foo()
}

0 comments on commit fff4ee6

Please sign in to comment.