src/Pure/Tools/server_commands.scala
author wenzelm
Mon, 30 Jan 2023 15:02:38 +0100
changeset 77137 79231a210f5d
parent 76852 2915740fce1f
child 77519 12ace037d05e
permissions -rw-r--r--
observe option "show_states" in headless server (see also 951abf9db857);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/server_commands.scala
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     3
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     4
Miscellaneous Isabelle server commands.
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     5
*/
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     6
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     7
package isabelle
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     8
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
     9
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    10
object Server_Commands {
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    11
  def default_preferences: String = Options.read_prefs()
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    12
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    13
  object Help extends Server.Command("help") {
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    14
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    15
      { case (context, ()) => context.command_list }
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    16
  }
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    17
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    18
  object Echo extends Server.Command("echo") {
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    19
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    20
      { case (_, t) => t }
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    21
  }
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    22
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    23
  object Cancel extends Server.Command("cancel") {
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
    24
    sealed case class Args(task: UUID.T)
67920
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    25
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    26
    def unapply(json: JSON.T): Option[Args] =
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    27
      for { task <- JSON.uuid(json, "task") }
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    28
      yield Args(task)
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    29
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    30
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    31
      { case (context, Cancel(args)) => context.cancel_task(args.task) }
67920
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    32
  }
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    33
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    34
  object Shutdown extends Server.Command("shutdown") {
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    35
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    36
      { case (context, ()) => context.server.shutdown() }
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
    37
  }
67920
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    38
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    39
  object Session_Build extends Server.Command("session_build") {
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    40
    sealed case class Args(
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    41
      session: String,
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    42
      preferences: String = default_preferences,
67862
wenzelm
parents: 67861
diff changeset
    43
      options: List[String] = Nil,
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    44
      dirs: List[String] = Nil,
67922
9e668ae81f97 clarified signature: prefer selective include_sessions;
wenzelm
parents: 67921
diff changeset
    45
      include_sessions: List[String] = Nil,
67853
74e2a4b62826 more options;
wenzelm
parents: 67852
diff changeset
    46
      verbose: Boolean = false)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    47
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    48
    def unapply(json: JSON.T): Option[Args] =
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    49
      for {
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    50
        session <- JSON.string(json, "session")
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    51
        preferences <- JSON.string_default(json, "preferences", default_preferences)
68742
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
    52
        options <- JSON.strings_default(json, "options")
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
    53
        dirs <- JSON.strings_default(json, "dirs")
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
    54
        include_sessions <- JSON.strings_default(json, "include_sessions")
67853
74e2a4b62826 more options;
wenzelm
parents: 67852
diff changeset
    55
        verbose <- JSON.bool_default(json, "verbose")
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    56
      }
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    57
      yield {
67862
wenzelm
parents: 67861
diff changeset
    58
        Args(session, preferences = preferences, options = options, dirs = dirs,
69854
cc0b3e177b49 system option "system_heaps" supersedes various command-line options for "system build mode";
wenzelm
parents: 69536
diff changeset
    59
          include_sessions = include_sessions, verbose = verbose)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    60
      }
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    61
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    62
    def command(
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    63
      args: Args,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    64
      progress: Progress = new Progress
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
    65
    ) : (JSON.Object.T, Build.Results, Options, Sessions.Background) = {
67862
wenzelm
parents: 67861
diff changeset
    66
      val options = Options.init(prefs = args.preferences, opts = args.options)
71601
97ccf48c2f0c misc tuning based on hints by IntelliJ IDEA;
wenzelm
parents: 71599
diff changeset
    67
      val dirs = args.dirs.map(Path.explode)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    68
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
    69
      val session_background =
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
    70
        Sessions.background(options, args.session, progress = progress, dirs = dirs,
75920
27bf2533f4a4 clarified signature: follow Sessions.Deps.check_errors (despite Process_Result.check);
wenzelm
parents: 75674
diff changeset
    71
          include_sessions = args.include_sessions).check_errors
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    72
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    73
      val results =
71981
0be06f99b210 clarified signature;
wenzelm
parents: 71896
diff changeset
    74
        Build.build(options,
0be06f99b210 clarified signature;
wenzelm
parents: 71896
diff changeset
    75
          selection = Sessions.Selection.session(args.session),
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    76
          progress = progress,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    77
          build_heap = true,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    78
          dirs = dirs,
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
    79
          infos = session_background.infos,
71896
ce06d6456cc8 clarified signature --- fit within limit of 22 arguments;
wenzelm
parents: 71747
diff changeset
    80
          verbose = args.verbose)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    81
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    82
      val sessions_order =
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
    83
        session_background.sessions_structure.imports_topological_order.zipWithIndex.
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    84
          toMap.withDefaultValue(-1)
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    85
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    86
      val results_json =
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    87
        JSON.Object(
67912
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    88
          "ok" -> results.ok,
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    89
          "return_code" -> results.rc,
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    90
          "sessions" ->
75394
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
    91
            results.sessions.toList.sortBy(sessions_order).map { session =>
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    92
              val result = results(session)
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    93
              JSON.Object(
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    94
                "session" -> session,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    95
                "ok" -> result.ok,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    96
                "return_code" -> result.rc,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    97
                "timeout" -> result.timeout,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
    98
                "timing" -> result.timing.json)
75394
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
    99
            })
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
   100
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
   101
      if (results.ok) (results_json, results, options, session_background)
71747
1dd514c8c1df clarified signature;
wenzelm
parents: 71726
diff changeset
   102
      else {
74306
a117c076aa22 clarified signature;
wenzelm
parents: 72866
diff changeset
   103
        throw new Server.Error("Session build failed: " + Process_Result.RC.print(results.rc),
71747
1dd514c8c1df clarified signature;
wenzelm
parents: 71726
diff changeset
   104
          results_json)
1dd514c8c1df clarified signature;
wenzelm
parents: 71726
diff changeset
   105
      }
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   106
    }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   107
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   108
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   109
      { case (context, Session_Build(args)) =>
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   110
        context.make_task(task => Session_Build.command(args, progress = task.progress)._1) }
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   111
  }
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   112
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   113
  object Session_Start extends Server.Command("session_start") {
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   114
    sealed case class Args(
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   115
      build: Session_Build.Args,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   116
      print_mode: List[String] = Nil)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   117
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   118
    def unapply(json: JSON.T): Option[Args] =
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   119
      for {
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   120
        build <- Session_Build.unapply(json)
68742
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
   121
        print_mode <- JSON.strings_default(json, "print_mode")
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   122
      }
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   123
      yield Args(build = build, print_mode = print_mode)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   124
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   125
    def command(
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   126
      args: Args,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   127
      progress: Progress = new Progress,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   128
      log: Logger = No_Logger
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   129
    ) : (JSON.Object.T, (UUID.T, Headless.Session)) = {
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
   130
      val (_, _, options, session_background) =
71599
23d0a45a9283 clarified signature;
wenzelm
parents: 69854
diff changeset
   131
        try { Session_Build.command(args.build, progress = progress) }
67914
9f82f6cc3bfc clarified error result, without JSON object from "session_build";
wenzelm
parents: 67912
diff changeset
   132
        catch { case exn: Server.Error => error(exn.message) }
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   133
76656
a8f452f7c503 clarified names;
wenzelm
parents: 76308
diff changeset
   134
      val resources = Headless.Resources(options, session_background, log = log)
69536
892b68f932f9 clarified signature;
wenzelm
parents: 69520
diff changeset
   135
892b68f932f9 clarified signature;
wenzelm
parents: 69520
diff changeset
   136
      val session = resources.start_session(print_mode = args.print_mode, progress = progress)
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   137
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
   138
      val id = UUID.random()
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   139
67925
74dce5658d4c provide tmp_dir for server session;
wenzelm
parents: 67923
diff changeset
   140
      val res =
74dce5658d4c provide tmp_dir for server session;
wenzelm
parents: 67923
diff changeset
   141
        JSON.Object(
74dce5658d4c provide tmp_dir for server session;
wenzelm
parents: 67923
diff changeset
   142
          "session_id" -> id.toString,
76308
wenzelm
parents: 76278
diff changeset
   143
          "tmp_dir" -> session.tmp_dir_name)
67925
74dce5658d4c provide tmp_dir for server session;
wenzelm
parents: 67923
diff changeset
   144
74dce5658d4c provide tmp_dir for server session;
wenzelm
parents: 67923
diff changeset
   145
      (res, id -> session)
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   146
    }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   147
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   148
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   149
      { case (context, Session_Start(args)) =>
75394
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   150
          context.make_task { task =>
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   151
            val (res, entry) =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   152
              Session_Start.command(args, progress = task.progress, log = context.server.log)
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   153
            context.server.add_session(entry)
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   154
            res
75394
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   155
          }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   156
      }
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   157
  }
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   158
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   159
  object Session_Stop extends Server.Command("session_stop") {
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
   160
    def unapply(json: JSON.T): Option[UUID.T] =
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   161
      JSON.uuid(json, "session_id")
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   162
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   163
    def command(session: Headless.Session): (JSON.Object.T, Process_Result) = {
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   164
      val result = session.stop()
67916
a72f01c63262 clarified result;
wenzelm
parents: 67914
diff changeset
   165
      val result_json = JSON.Object("ok" -> result.ok, "return_code" -> result.rc)
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   166
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   167
      if (result.ok) (result_json, result)
71747
1dd514c8c1df clarified signature;
wenzelm
parents: 71726
diff changeset
   168
      else throw new Server.Error("Session shutdown failed: " + result.print_rc, result_json)
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   169
    }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   170
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   171
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   172
      { case (context, Session_Stop(id)) =>
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   173
        context.make_task(_ =>
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   174
        {
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   175
          val session = context.server.remove_session(id)
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   176
          Session_Stop.command(session)._1
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   177
        })
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   178
      }
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   179
  }
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   180
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   181
  object Use_Theories extends Server.Command("use_theories") {
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   182
    sealed case class Args(
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
   183
      session_id: UUID.T,
67940
b4e80f062fbf clarified signature -- eliminated somewhat pointless positions;
wenzelm
parents: 67937
diff changeset
   184
      theories: List[String],
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   185
      master_dir: String = "",
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   186
      pretty_margin: Double = Pretty.default_margin,
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   187
      unicode_symbols: Boolean = false,
68694
03e104be99af added check_delay / check_limit for more robust treatment of structurally broken theory sources (or genuine non-termination);
wenzelm
parents: 68365
diff changeset
   188
      export_pattern: String = "",
69520
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   189
      check_delay: Option[Time] = None,
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   190
      check_limit: Option[Int] = None,
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   191
      watchdog_timeout: Option[Time] = None,
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   192
      nodes_status_delay: Option[Time] = None,
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   193
      commit_cleanup_delay: Option[Time] = None)
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   194
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   195
    def unapply(json: JSON.T): Option[Args] =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   196
      for {
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   197
        session_id <- JSON.uuid(json, "session_id")
68742
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
   198
        theories <- JSON.strings(json, "theories")
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   199
        master_dir <- JSON.string_default(json, "master_dir")
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   200
        pretty_margin <- JSON.double_default(json, "pretty_margin", Pretty.default_margin)
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   201
        unicode_symbols <- JSON.bool_default(json, "unicode_symbols")
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   202
        export_pattern <- JSON.string_default(json, "export_pattern")
69520
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   203
        check_delay = JSON.seconds(json, "check_delay")
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   204
        check_limit = JSON.int(json, "check_limit")
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   205
        watchdog_timeout = JSON.seconds(json, "watchdog_timeout")
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   206
        nodes_status_delay = JSON.seconds(json, "nodes_status_delay")
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   207
        commit_cleanup_delay = JSON.seconds(json, "commit_cleanup_delay")
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   208
      }
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   209
      yield {
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   210
        Args(session_id, theories, master_dir = master_dir, pretty_margin = pretty_margin,
68694
03e104be99af added check_delay / check_limit for more robust treatment of structurally broken theory sources (or genuine non-termination);
wenzelm
parents: 68365
diff changeset
   211
          unicode_symbols = unicode_symbols, export_pattern = export_pattern,
68908
abc338d25640 support for watchdog_timeout;
wenzelm
parents: 68770
diff changeset
   212
          check_delay = check_delay, check_limit = check_limit, watchdog_timeout = watchdog_timeout,
69520
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   213
          nodes_status_delay = nodes_status_delay, commit_cleanup_delay = commit_cleanup_delay)
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   214
      }
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   215
67884
43af581d7d8e unload_theories after consolidation -- reset node_required;
wenzelm
parents: 67883
diff changeset
   216
    def command(args: Args,
69012
c91d14ab065f clarified modules;
wenzelm
parents: 68947
diff changeset
   217
      session: Headless.Session,
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
   218
      id: UUID.T = UUID.random(),
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   219
      progress: Progress = new Progress
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   220
    ): (JSON.Object.T, Headless.Use_Theories_Result) = {
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   221
      val result =
67937
91eb307511bb removed somewhat pointless argument;
wenzelm
parents: 67931
diff changeset
   222
        session.use_theories(args.theories, master_dir = args.master_dir,
69520
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   223
          check_delay = args.check_delay.getOrElse(session.default_check_delay),
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   224
          check_limit = args.check_limit.getOrElse(session.default_check_limit),
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   225
          watchdog_timeout = args.watchdog_timeout.getOrElse(session.default_watchdog_timeout),
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   226
          nodes_status_delay = args.nodes_status_delay.getOrElse(session.default_nodes_status_delay),
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   227
          commit_cleanup_delay =
16779868de1f clarified defaults via system options;
wenzelm
parents: 69458
diff changeset
   228
            args.commit_cleanup_delay.getOrElse(session.default_commit_cleanup_delay),
67937
91eb307511bb removed somewhat pointless argument;
wenzelm
parents: 67931
diff changeset
   229
          id = id, progress = progress)
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   230
72866
1d21b4c8023d tuned signature;
wenzelm
parents: 72847
diff changeset
   231
      def output_text(text: String): String =
1d21b4c8023d tuned signature;
wenzelm
parents: 72847
diff changeset
   232
        Symbol.output(args.unicode_symbols, text)
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   233
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   234
      def output_message(tree: XML.Tree, pos: Position.T): JSON.Object.T = {
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   235
        val position = "pos" -> Position.JSON(pos)
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   236
        tree match {
67901
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   237
          case XML.Text(msg) => Server.Reply.message(output_text(msg)) + position
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   238
          case elem: XML.Elem =>
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   239
            val msg = XML.content(Pretty.formatted(List(elem), margin = args.pretty_margin))
67923
3e072441c96a clarified exported messages, e.g. suppress "information", "tracing";
wenzelm
parents: 67922
diff changeset
   240
            val kind =
3e072441c96a clarified exported messages, e.g. suppress "information", "tracing";
wenzelm
parents: 67922
diff changeset
   241
              Markup.messages.collectFirst({ case (a, b) if b == elem.name =>
67931
f7917c15b566 field "kind" is always present, with default "writeln";
wenzelm
parents: 67925
diff changeset
   242
                if (Protocol.is_legacy(elem)) Markup.WARNING else a }) getOrElse ""
f7917c15b566 field "kind" is always present, with default "writeln";
wenzelm
parents: 67925
diff changeset
   243
            Server.Reply.message(output_text(msg), kind = kind) + position
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   244
        }
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   245
      }
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   246
77137
79231a210f5d observe option "show_states" in headless server (see also 951abf9db857);
wenzelm
parents: 76852
diff changeset
   247
      def show_message(tree: XML.Tree): Boolean =
79231a210f5d observe option "show_states" in headless server (see also 951abf9db857);
wenzelm
parents: 76852
diff changeset
   248
        Protocol.is_exported(tree) || session.show_states && Protocol.is_state(tree)
79231a210f5d observe option "show_states" in headless server (see also 951abf9db857);
wenzelm
parents: 76852
diff changeset
   249
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   250
      val result_json =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   251
        JSON.Object(
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   252
          "ok" -> result.ok,
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   253
          "errors" ->
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   254
            (for {
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   255
              (name, status) <- result.nodes if !status.ok
68365
f9379279f98c clarified signature: prefer Document.Snapshot;
wenzelm
parents: 68167
diff changeset
   256
              (tree, pos) <- result.snapshot(name).messages if Protocol.is_error(tree)
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   257
            } yield output_message(tree, pos)),
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   258
          "nodes" ->
68365
f9379279f98c clarified signature: prefer Document.Snapshot;
wenzelm
parents: 68167
diff changeset
   259
            (for ((name, status) <- result.nodes) yield {
f9379279f98c clarified signature: prefer Document.Snapshot;
wenzelm
parents: 68167
diff changeset
   260
              val snapshot = result.snapshot(name)
67943
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   261
              name.json +
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   262
                ("status" -> status.json) +
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   263
                ("messages" ->
67947
ad735a551a11 clarified messages (amending 3e072441c96a);
wenzelm
parents: 67943
diff changeset
   264
                  (for {
77137
79231a210f5d observe option "show_states" in headless server (see also 951abf9db857);
wenzelm
parents: 76852
diff changeset
   265
                    (tree, pos) <- snapshot.messages if show_message(tree)
68106
a514e29db980 return exports as result for Isabelle server;
wenzelm
parents: 67947
diff changeset
   266
                  } yield output_message(tree, pos))) +
a514e29db980 return exports as result for Isabelle server;
wenzelm
parents: 67947
diff changeset
   267
                ("exports" ->
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   268
                  (if (args.export_pattern == "") Nil else {
75658
5905c7f484b3 clarified signature: read_theory_exports is already ordered;
wenzelm
parents: 75587
diff changeset
   269
                    val matcher = Export.make_matcher(List(args.export_pattern))
75674
c8e6078fee73 clarified signature;
wenzelm
parents: 75658
diff changeset
   270
                    for { entry <- snapshot.exports if matcher(entry.entry_name) }
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   271
                    yield {
76852
2915740fce1f tunes signature;
wenzelm
parents: 76656
diff changeset
   272
                      val (base64, body) = entry.bytes.maybe_encode_base64
68152
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   273
                      JSON.Object("name" -> entry.name, "base64" -> base64, "body" -> body)
619de043389f guard result exports via export_pattern -- avoid bombing client via huge blobs;
wenzelm
parents: 68106
diff changeset
   274
                    }
68365
f9379279f98c clarified signature: prefer Document.Snapshot;
wenzelm
parents: 68167
diff changeset
   275
                  }))
f9379279f98c clarified signature: prefer Document.Snapshot;
wenzelm
parents: 68167
diff changeset
   276
            }))
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   277
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   278
      (result_json, result)
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   279
    }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   280
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   281
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   282
      { case (context, Use_Theories(args)) =>
75394
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   283
          context.make_task { task =>
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   284
            val session = context.server.the_session(args.session_id)
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   285
            Use_Theories.command(args, session, id = task.id, progress = task.progress)._1
42267c650205 tuned formatting;
wenzelm
parents: 75393
diff changeset
   286
          }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   287
      }
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   288
  }
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   289
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   290
  object Purge_Theories extends Server.Command("purge_theories") {
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   291
    sealed case class Args(
69458
5655af3ea5bd clarified modules and signature;
wenzelm
parents: 69013
diff changeset
   292
      session_id: UUID.T,
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   293
      theories: List[String] = Nil,
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   294
      master_dir: String = "",
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   295
      all: Boolean = false)
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   296
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   297
    def unapply(json: JSON.T): Option[Args] =
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   298
      for {
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   299
        session_id <- JSON.uuid(json, "session_id")
68742
a6cc4302c380 tuned signature;
wenzelm
parents: 68694
diff changeset
   300
        theories <- JSON.strings_default(json, "theories")
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   301
        master_dir <- JSON.string_default(json, "master_dir")
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   302
        all <- JSON.bool_default(json, "all")
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   303
      }
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   304
      yield { Args(session_id, theories = theories, master_dir = master_dir, all = all) }
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   305
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   306
    def command(
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   307
      args: Args,
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   308
      session: Headless.Session
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 74306
diff changeset
   309
    ) : (JSON.Object.T, (List[Document.Node.Name], List[Document.Node.Name])) = {
67943
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   310
      val (purged, retained) =
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   311
        session.purge_theories(
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   312
          theories = args.theories, master_dir = args.master_dir, all = args.all)
67943
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   313
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   314
      val result_json =
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   315
        JSON.Object("purged" -> purged.map(_.json), "retained" -> retained.map(_.json))
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   316
b45f0c0ea14f clarified theory node name;
wenzelm
parents: 67941
diff changeset
   317
      (result_json, (purged, retained))
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   318
    }
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   319
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   320
    override val command_body: Server.Command_Body =
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   321
      { case (context, Purge_Theories(args)) =>
76278
6aeb18e8a557 tuned whitespace;
wenzelm
parents: 75920
diff changeset
   322
          val session = context.server.the_session(args.session_id)
6aeb18e8a557 tuned whitespace;
wenzelm
parents: 75920
diff changeset
   323
          command(args, session)._1
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   324
      }
67941
49a34b2fa788 added command "purge_theories";
wenzelm
parents: 67940
diff changeset
   325
  }
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   326
}
72163
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   327
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   328
class Server_Commands extends Server.Commands(
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   329
  Server_Commands.Help,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   330
  Server_Commands.Echo,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   331
  Server_Commands.Cancel,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   332
  Server_Commands.Shutdown,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   333
  Server_Commands.Session_Build,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   334
  Server_Commands.Session_Start,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   335
  Server_Commands.Session_Stop,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   336
  Server_Commands.Use_Theories,
f5722290a4d0 allow user-defined server commands via isabelle_scala_service;
wenzelm
parents: 71981
diff changeset
   337
  Server_Commands.Purge_Theories)