src/Pure/Tools/print_operation.scala
author wenzelm
Wed, 11 Oct 2023 10:46:50 +0200
changeset 78753 f40b59292288
parent 75440 39011d0d2128
permissions -rw-r--r--
clarified signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59720
f893472fff31 proper headers;
wenzelm
parents: 59366
diff changeset
     1
/*  Title:      Pure/Tools/print_operation.scala
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     3
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     4
Print operations as asynchronous query.
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     5
*/
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     6
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     7
package isabelle
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     8
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
     9
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 72215
diff changeset
    10
object Print_Operation {
72215
8f9cffa78112 clarified signature;
wenzelm
parents: 72212
diff changeset
    11
  def get(session: Session): List[(String, String)] =
8f9cffa78112 clarified signature;
wenzelm
parents: 72212
diff changeset
    12
    session.get_protocol_handler(classOf[Handler]) match {
8f9cffa78112 clarified signature;
wenzelm
parents: 72212
diff changeset
    13
      case Some(h) => h.get
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    14
      case _ => Nil
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    15
    }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    16
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    17
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    18
  /* protocol handler */
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    19
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 72215
diff changeset
    20
  class Handler extends Session.Protocol_Handler {
61590
wenzelm
parents: 59720
diff changeset
    21
    private val print_operations = Synchronized[List[(String, String)]](Nil)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    22
72215
8f9cffa78112 clarified signature;
wenzelm
parents: 72212
diff changeset
    23
    def get: List[(String, String)] = print_operations.value
8f9cffa78112 clarified signature;
wenzelm
parents: 72212
diff changeset
    24
65220
wenzelm
parents: 65219
diff changeset
    25
    override def init(session: Session): Unit =
wenzelm
parents: 65219
diff changeset
    26
      session.protocol_command(Markup.PRINT_OPERATIONS)
wenzelm
parents: 65219
diff changeset
    27
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 72215
diff changeset
    28
    private def put(msg: Prover.Protocol_Output): Boolean = {
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 72215
diff changeset
    29
      val ops = {
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    30
        import XML.Decode._
65344
b99283eed13c clarified YXML vs. symbol encoding: operate on whole message;
wenzelm
parents: 65220
diff changeset
    31
        list(pair(string, string))(Symbol.decode_yxml(msg.text))
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    32
      }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    33
      print_operations.change(_ => ops)
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    34
      true
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    35
    }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    36
75440
39011d0d2128 tuned signature;
wenzelm
parents: 75393
diff changeset
    37
    override val functions: Session.Protocol_Functions =
39011d0d2128 tuned signature;
wenzelm
parents: 75393
diff changeset
    38
      List(Markup.PRINT_OPERATIONS -> put)
56864
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    39
  }
0446c7ac2e32 support print operations as asynchronous query;
wenzelm
parents:
diff changeset
    40
}