sbt 0.10.1 から Scala 2.8.1 で記述された単純な JavaFX 2.0 ベータ アプリケーションを実行しようとすると、アプリケーション ウィンドウが閉じられた後に例外がスローされます。
> run
[info] Running com.tradex.priceviewer.Main
Exception while removing reference: java.lang.InterruptedException
java.lang.InterruptedException
[ at java.lang.Object.wait(Native Method)success
] at java.lang.ref.ReferenceQueue.remove(Unknown Source)Total time: 5 s, completed Aug 5, 2011 1:12:04 PM
at java.lang.ref.ReferenceQueue.remove(Unknown Source)
at com.sun.glass.utils.Disposer.run(Disposer.java:64)>
at java.lang.Thread.run(Unknown Source)
コマンド ラインからアプリケーションを実行すると、例外はスローされず、返されるステータスは 0 です。アプリケーションのコードを以下に示します。
class Starter extends Application {
def main(args: Array[String]) {
Application.launch(args)
}
override def start(s: Stage) {
s.setVisible(true)
}
}
object Main {
def main(args: Array[String]) {
val gui = new Starter
gui.main(args)
}
}
例外がスローされた後、sbt を終了して再起動する必要があります (リロードは機能しません)。Scala 2.8.1 コンソールから同じアプリケーションを実行すると、2 回目の実行後に次の例外がスローされます。
scala> m.main(Array(""))
scala> m.main(Array(""))
java.lang.IllegalStateException: Application launch must not be called more than once
at com.sun.javafx.application.LauncherImpl.launchApplication(LauncherImpl.java:41)
at javafx.application.Application.launch(Application.java:115)
at com.tradex.priceviewer.Starter.main(Main.scala:19)
at .<init>(<console>:11)
at .<clinit>(<console>)
at RequestResult$.<init>(<console>:9)
at RequestResult$.<clinit>(<console>)
at RequestResult$scala_repl_result(<console>)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source)
at java.lang.reflect.Method.invoke(Unknown Source)
at scala.tools.nsc.Interpreter$Request$$anonfun$loadAndRun$1$$anonfun$apply$17.appl...
scala>
この scala/javafx アプリケーションを適切に終了する方法を知っている人はいますか (そのため、sbt や scala コンソールを再起動する必要はありません)。