src/Pure/System/system_channel.scala
author wenzelm
Fri, 24 Nov 2023 14:11:01 +0100
changeset 79048 caddfe4949a8
parent 75393 87ebf5a50283
child 79049 10b6add456d0
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
45027
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/System/system_channel.scala
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     3
59350
acba5d6fdb2f discontinued fifo channel, always use portable socket;
wenzelm
parents: 59341
diff changeset
     4
Socket-based system channel for inter-process communication.
45027
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     5
*/
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     6
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     7
package isabelle
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     8
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
     9
59350
acba5d6fdb2f discontinued fifo channel, always use portable socket;
wenzelm
parents: 59341
diff changeset
    10
import java.io.{InputStream, OutputStream}
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    11
import java.net.{ServerSocket, InetAddress}
45027
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
    12
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
    13
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73367
diff changeset
    14
object System_Channel {
59350
acba5d6fdb2f discontinued fifo channel, always use portable socket;
wenzelm
parents: 59341
diff changeset
    15
  def apply(): System_Channel = new System_Channel
45027
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
    16
}
f459e93a038e more abstract wrapping of fifos as System_Channel;
wenzelm
parents:
diff changeset
    17
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73367
diff changeset
    18
class System_Channel private {
69463
6439c9024dcc clarified signature;
wenzelm
parents: 69124
diff changeset
    19
  private val server = new ServerSocket(0, 50, Server.localhost)
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    20
69572
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    21
  val address: String = Server.print_address(server.getLocalPort)
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    22
  val password: String = UUID.random().toString
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    23
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    24
  override def toString: String = address
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    25
73367
77ef8bef0593 clarified signature --- fewer warnings;
wenzelm
parents: 73340
diff changeset
    26
  def shutdown(): Unit = server.close()
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    27
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73367
diff changeset
    28
  def rendezvous(): (OutputStream, InputStream) = {
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    29
    val socket = server.accept
69572
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    30
    try {
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    31
      val out_stream = socket.getOutputStream
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    32
      val in_stream = socket.getInputStream
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    33
79048
wenzelm
parents: 75393
diff changeset
    34
      Byte_Message.read_line(in_stream) match {
wenzelm
parents: 75393
diff changeset
    35
        case Some(bs) if bs.text == password => (out_stream, in_stream)
wenzelm
parents: 75393
diff changeset
    36
        case _ =>
wenzelm
parents: 75393
diff changeset
    37
          out_stream.close()
wenzelm
parents: 75393
diff changeset
    38
          in_stream.close()
wenzelm
parents: 75393
diff changeset
    39
          error("Failed to connect system channel: bad password")
69572
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    40
      }
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    41
    }
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    42
    finally { shutdown() }
09a6a7c04b45 more robust system channel via options that are private to the user;
wenzelm
parents: 69463
diff changeset
    43
  }
45028
d608dd8cd409 alternative Socket_Channel;
wenzelm
parents: 45027
diff changeset
    44
}