| author | wenzelm | 
| Sat, 07 Mar 2015 00:45:15 +0100 | |
| changeset 59644 | cc78fd8d955d | 
| parent 59136 | c2b23cb8a677 | 
| child 61194 | e4699ef5cf90 | 
| permissions | -rw-r--r-- | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 1 | /* Title: Pure/Concurrent/simple_thread.scala | 
| 45673 
cd41e3903fbf
separate compilation of PIDE vs. Pure sources, which enables independent Scala library;
 wenzelm parents: 
45667diff
changeset | 2 | Module: PIDE | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 3 | Author: Makarius | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 4 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 5 | Simplified thread operations. | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 6 | */ | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 7 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 8 | package isabelle | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 9 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 10 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 11 | import java.lang.Thread | 
| 59136 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 12 | import java.util.concurrent.{Callable, Future => JFuture, ThreadPoolExecutor,
 | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 13 | TimeUnit, LinkedBlockingQueue} | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 14 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 15 | |
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 16 | object Simple_Thread | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 17 | {
 | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 18 | /* plain thread */ | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 19 | |
| 39577 | 20 | def fork(name: String = "", daemon: Boolean = false)(body: => Unit): Thread = | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 21 |   {
 | 
| 39577 | 22 | val thread = | 
| 23 |       if (name == null || name == "") new Thread() { override def run = body }
 | |
| 24 |       else new Thread(name) { override def run = body }
 | |
| 38638 | 25 | thread.setDaemon(daemon) | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 26 | thread.start | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 27 | thread | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 28 | } | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 29 | |
| 39579 | 30 | |
| 31 | /* future result via thread */ | |
| 39577 | 32 | |
| 48355 
6b36da29a0bf
support for detached Bash_Job with some control operations;
 wenzelm parents: 
45673diff
changeset | 33 | def future[A](name: String = "", daemon: Boolean = false)(body: => A): (Thread, Future[A]) = | 
| 39577 | 34 |   {
 | 
| 35 | val result = Future.promise[A] | |
| 48355 
6b36da29a0bf
support for detached Bash_Job with some control operations;
 wenzelm parents: 
45673diff
changeset | 36 |     val thread = fork(name, daemon) { result.fulfill_result(Exn.capture(body)) }
 | 
| 
6b36da29a0bf
support for detached Bash_Job with some control operations;
 wenzelm parents: 
45673diff
changeset | 37 | (thread, result) | 
| 39577 | 38 | } | 
| 56730 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 39 | |
| 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 40 | |
| 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 41 | /* thread pool */ | 
| 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 42 | |
| 59136 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 43 | lazy val default_pool = | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 44 |     {
 | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 45 |       val m = Properties.Value.Int.unapply(System.getProperty("isabelle.threads", "0")) getOrElse 0
 | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 46 | val n = if (m > 0) m else (Runtime.getRuntime.availableProcessors max 1) min 8 | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 47 | new ThreadPoolExecutor(n, n, 2500L, TimeUnit.MILLISECONDS, new LinkedBlockingQueue[Runnable]) | 
| 
c2b23cb8a677
added Par_List in Scala, in accordance to ML version;
 wenzelm parents: 
56860diff
changeset | 48 | } | 
| 56730 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 49 | |
| 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 50 | def submit_task[A](body: => A): JFuture[A] = | 
| 
e723f041b6d0
tuned signature -- separate pool for JFuture tasks, which can be canceled;
 wenzelm parents: 
56707diff
changeset | 51 |     default_pool.submit(new Callable[A] { def call = body })
 | 
| 56770 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 52 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 53 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 54 | /* delayed events */ | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 55 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 56 | final class Delay private [Simple_Thread](first: Boolean, delay: => Time, event: => Unit) | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 57 |   {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 58 | private var running: Option[Event_Timer.Request] = None | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 59 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 60 | private def run: Unit = | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 61 |     {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 62 |       val do_run = synchronized {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 63 |         if (running.isDefined) { running = None; true } else false
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 64 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 65 | if (do_run) event | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 66 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 67 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 68 | def invoke(): Unit = synchronized | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 69 |     {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 70 | val new_run = | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 71 |         running match {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 72 |           case Some(request) => if (first) false else { request.cancel; true }
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 73 | case None => true | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 74 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 75 | if (new_run) | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 76 | running = Some(Event_Timer.request(Time.now() + delay)(run)) | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 77 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 78 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 79 | def revoke(): Unit = synchronized | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 80 |     {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 81 |       running match {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 82 | case Some(request) => request.cancel; running = None | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 83 | case None => | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 84 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 85 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 86 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 87 | def postpone(alt_delay: Time): Unit = | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 88 |     {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 89 |       running match {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 90 | case Some(request) => | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 91 | val alt_time = Time.now() + alt_delay | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 92 |           if (request.time < alt_time && request.cancel) {
 | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 93 | running = Some(Event_Timer.request(alt_time)(run)) | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 94 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 95 | case None => | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 96 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 97 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 98 | } | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 99 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 100 | // delayed event after first invocation | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 101 | def delay_first(delay: => Time)(event: => Unit): Delay = new Delay(true, delay, event) | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 102 | |
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 103 | // delayed event after last invocation | 
| 
e160ae47db94
mane delayed events outside of Swing thread -- triggers no longer require Swing_Thread.later;
 wenzelm parents: 
56730diff
changeset | 104 | def delay_last(delay: => Time)(event: => Unit): Delay = new Delay(false, delay, event) | 
| 38636 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 105 | } | 
| 
b7647ca7de5a
module for simplified thread operations (Scala version);
 wenzelm parents: diff
changeset | 106 |