| 
59720
 | 
     1  | 
/*  Title:      Pure/System/posix_interrupt.scala
  | 
| 
51250
 | 
     2  | 
    Author:     Makarius
  | 
| 
 | 
     3  | 
  | 
| 
 | 
     4  | 
Support for POSIX interrupts (bypassed on Windows).
  | 
| 
 | 
     5  | 
*/
  | 
| 
 | 
     6  | 
  | 
| 
 | 
     7  | 
package isabelle
  | 
| 
 | 
     8  | 
  | 
| 
 | 
     9  | 
  | 
| 
 | 
    10  | 
import sun.misc.{Signal, SignalHandler}
 | 
| 
 | 
    11  | 
  | 
| 
 | 
    12  | 
  | 
| 
56860
 | 
    13  | 
object POSIX_Interrupt
  | 
| 
51250
 | 
    14  | 
{
 | 
| 
 | 
    15  | 
  def handler[A](h: => Unit)(e: => A): A =
  | 
| 
 | 
    16  | 
  {
 | 
| 
 | 
    17  | 
    val SIGINT = new Signal("INT")
 | 
| 
73340
 | 
    18  | 
    val new_handler = new SignalHandler { def handle(s: Signal): Unit = h }
 | 
| 
51250
 | 
    19  | 
    val old_handler = Signal.handle(SIGINT, new_handler)
  | 
| 
 | 
    20  | 
    try { e } finally { Signal.handle(SIGINT, old_handler) }
 | 
| 
 | 
    21  | 
  }
  | 
| 
 | 
    22  | 
  | 
| 
 | 
    23  | 
  def exception[A](e: => A): A =
  | 
| 
 | 
    24  | 
  {
 | 
| 
 | 
    25  | 
    val thread = Thread.currentThread
  | 
| 
73367
 | 
    26  | 
    handler { thread.interrupt() } { e }
 | 
| 
51250
 | 
    27  | 
  }
  | 
| 
 | 
    28  | 
}
  | 
| 
 | 
    29  | 
  |