eliminated pointless output actors;
authorwenzelm
Thu, 24 Apr 2014 13:54:45 +0200
changeset 56697 76b38be47feb
parent 56696 ff782c5450bf
child 56698 e0655270d3f3
eliminated pointless output actors; clarified command_input, which already includes thread.join;
src/Pure/System/isabelle_process.scala
--- a/src/Pure/System/isabelle_process.scala	Thu Apr 24 13:40:29 2014 +0200
+++ b/src/Pure/System/isabelle_process.scala	Thu Apr 24 13:54:45 2014 +0200
@@ -57,19 +57,19 @@
 
   /* command input actor */
 
+  @volatile private var command_input: (Thread, Actor) = null
+
   private case class Input_Chunks(chunks: List[Bytes])
 
   private case object Close
-  private def close(p: (Thread, Actor))
+  private def close_input()
   {
-    if (p != null && p._1.isAlive) {
-      p._2 ! Close
-      p._1.join
+    if (command_input != null && command_input._1.isAlive) {
+      command_input._2 ! Close
+      command_input._1.join
     }
   }
 
-  @volatile private var command_input: (Thread, Actor) = null
-
 
 
   /** process manager **/
@@ -126,16 +126,16 @@
     else {
       val (command_stream, message_stream) = system_channel.rendezvous()
 
-      val stdout = physical_output_actor(false)
-      val stderr = physical_output_actor(true)
+      val stdout = physical_output(false)
+      val stderr = physical_output(true)
+      val message = message_output(message_stream)
+
       command_input = input_actor(command_stream)
-      val message = message_actor(message_stream)
 
       val rc = process_result.join
       system_output("process terminated")
-      close(command_input)
-      for ((thread, _) <- List(stdout, stderr, command_input, message))
-        thread.join
+      close_input()
+      for (thread <- List(stdout, stderr, message)) thread.join
       system_output("process_manager terminated")
       exit_message(rc)
     }
@@ -155,7 +155,7 @@
 
   def terminate()
   {
-    close(command_input)
+    close_input()
     system_output("Terminating Isabelle process")
     terminate_process()
   }
@@ -166,13 +166,13 @@
 
   /* physical output */
 
-  private def physical_output_actor(err: Boolean): (Thread, Actor) =
+  private def physical_output(err: Boolean): Thread =
   {
     val (name, reader, markup) =
       if (err) ("standard_error", process.stderr, Markup.STDERR)
       else ("standard_output", process.stdout, Markup.STDOUT)
 
-    Simple_Thread.actor(name) {
+    Simple_Thread.fork(name) {
       try {
         var result = new StringBuilder(100)
         var finished = false
@@ -234,13 +234,13 @@
 
   /* message output */
 
-  private def message_actor(stream: InputStream): (Thread, Actor) =
+  private def message_output(stream: InputStream): Thread =
   {
     class EOF extends Exception
     class Protocol_Error(msg: String) extends Exception(msg)
 
     val name = "message_output"
-    Simple_Thread.actor(name) {
+    Simple_Thread.fork(name) {
       val default_buffer = new Array[Byte](65536)
       var c = -1