src/Pure/Tools/server_commands.scala
author wenzelm
Thu, 22 Mar 2018 16:20:53 +0100
changeset 67922 9e668ae81f97
parent 67921 1722384ffd4a
child 67923 3e072441c96a
permissions -rw-r--r--
clarified signature: prefer selective include_sessions;
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
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    10
object Server_Commands
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    11
{
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    12
  def default_preferences: String = Options.read_prefs()
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    13
  def default_qualifier: String = Sessions.DRAFT
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    14
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    15
  def unapply_name_pos(json: JSON.T): Option[(String, Position.T)] =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    16
    json match {
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    17
      case JSON.Value.String(name) => Some((name, Position.none))
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    18
      case JSON.Object(map) if map.keySet == Set("name", "pos") =>
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    19
      (map("name"), map("pos")) match {
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    20
        case (JSON.Value.String(name), Position.JSON(pos)) => Some((name, pos))
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    21
        case _ => None
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    22
      }
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    23
      case _ => None
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
    24
    }
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    25
67920
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    26
  object Cancel
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    27
  {
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    28
    sealed case class Args(task: UUID)
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    29
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    30
    def unapply(json: JSON.T): Option[Args] =
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    31
      for { task <- JSON.uuid(json, "task") }
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    32
      yield Args(task)
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    33
  }
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    34
c3c74310154e clarified signature;
wenzelm
parents: 67919
diff changeset
    35
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    36
  object Session_Build
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    37
  {
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    38
    sealed case class Args(
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    39
      session: String,
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    40
      preferences: String = default_preferences,
67862
wenzelm
parents: 67861
diff changeset
    41
      options: List[String] = Nil,
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    42
      dirs: List[String] = Nil,
67922
9e668ae81f97 clarified signature: prefer selective include_sessions;
wenzelm
parents: 67921
diff changeset
    43
      include_sessions: List[String] = Nil,
67853
74e2a4b62826 more options;
wenzelm
parents: 67852
diff changeset
    44
      system_mode: Boolean = false,
74e2a4b62826 more options;
wenzelm
parents: 67852
diff changeset
    45
      verbose: Boolean = false)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    46
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    47
    def unapply(json: JSON.T): Option[Args] =
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    48
      for {
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    49
        session <- JSON.string(json, "session")
67863
1805960b4a9f clarified default;
wenzelm
parents: 67862
diff changeset
    50
        preferences <- JSON.string_default(json, "preferences", default_preferences)
67862
wenzelm
parents: 67861
diff changeset
    51
        options <- JSON.list_default(json, "options", JSON.Value.String.unapply _)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    52
        dirs <- JSON.list_default(json, "dirs", JSON.Value.String.unapply _)
67922
9e668ae81f97 clarified signature: prefer selective include_sessions;
wenzelm
parents: 67921
diff changeset
    53
        include_sessions <- JSON.list_default(json, "include_sessions", JSON.Value.String.unapply _)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    54
        system_mode <- JSON.bool_default(json, "system_mode")
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,
67922
9e668ae81f97 clarified signature: prefer selective include_sessions;
wenzelm
parents: 67921
diff changeset
    59
          include_sessions = include_sessions, system_mode = system_mode, 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
67886
26510aad2ec6 tuned signature;
wenzelm
parents: 67885
diff changeset
    62
    def command(args: Args, progress: Progress = No_Progress)
67861
cd1cac824ef8 asynchronous "session_build";
wenzelm
parents: 67858
diff changeset
    63
      : (JSON.Object.T, Build.Results, Sessions.Base_Info) =
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    64
    {
67862
wenzelm
parents: 67861
diff changeset
    65
      val options = Options.init(prefs = args.preferences, opts = args.options)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    66
      val dirs = args.dirs.map(Path.explode(_))
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    67
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    68
      val base_info =
67919
dd90faed43b2 clarified signature: do not expose somewhat accidental internal options;
wenzelm
parents: 67916
diff changeset
    69
        Sessions.base_info(options, args.session, progress = progress, dirs = dirs,
67922
9e668ae81f97 clarified signature: prefer selective include_sessions;
wenzelm
parents: 67921
diff changeset
    70
          include_sessions = args.include_sessions)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    71
      val base = base_info.check_base
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 =
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    74
        Build.build(options,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    75
          progress = progress,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    76
          build_heap = true,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    77
          system_mode = args.system_mode,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    78
          dirs = dirs,
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    79
          infos = base_info.infos,
67853
74e2a4b62826 more options;
wenzelm
parents: 67852
diff changeset
    80
          verbose = args.verbose,
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    81
          sessions = List(args.session))
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
    82
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    83
      val sessions_order =
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    84
        base_info.sessions_structure.imports_topological_order.zipWithIndex.
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    85
          toMap.withDefaultValue(-1)
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    86
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    87
      val results_json =
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    88
        JSON.Object(
67912
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    89
          "ok" -> results.ok,
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    90
          "return_code" -> results.rc,
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    91
          "sessions" ->
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
    92
            results.sessions.toList.sortBy(sessions_order).map(session =>
67912
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    93
              {
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    94
                val result = results(session)
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    95
                JSON.Object(
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    96
                  "session" -> session,
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    97
                  "ok" -> result.ok,
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    98
                  "return_code" -> result.rc,
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
    99
                  "timeout" -> result.timeout,
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
   100
                  "timing" -> result.timing.json)
a7731d581bbc clarified result;
wenzelm
parents: 67901
diff changeset
   101
              }))
67858
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
   102
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
   103
      if (results.ok) (results_json, results, base_info)
cba5c5657378 more informative JSON results;
wenzelm
parents: 67853
diff changeset
   104
      else throw new Server.Error("Session build failed: return code " + results.rc, results_json)
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   105
    }
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   106
  }
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   107
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   108
  object Session_Start
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   109
  {
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   110
    sealed case class Args(
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   111
      build: Session_Build.Args,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   112
      print_mode: List[String] = Nil)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   113
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   114
    def unapply(json: JSON.T): Option[Args] =
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   115
      for {
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   116
        build <- Session_Build.unapply(json)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   117
        print_mode <- JSON.list_default(json, "print_mode", JSON.Value.String.unapply _)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   118
      }
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   119
      yield Args(build = build, print_mode = print_mode)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   120
67886
26510aad2ec6 tuned signature;
wenzelm
parents: 67885
diff changeset
   121
    def command(args: Args, progress: Progress = No_Progress, log: Logger = No_Logger)
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   122
      : (JSON.Object.T, (UUID, Thy_Resources.Session)) =
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   123
    {
67914
9f82f6cc3bfc clarified error result, without JSON object from "session_build";
wenzelm
parents: 67912
diff changeset
   124
      val base_info =
9f82f6cc3bfc clarified error result, without JSON object from "session_build";
wenzelm
parents: 67912
diff changeset
   125
        try { Session_Build.command(args.build, progress = progress)._3 }
9f82f6cc3bfc clarified error result, without JSON object from "session_build";
wenzelm
parents: 67912
diff changeset
   126
        catch { case exn: Server.Error => error(exn.message) }
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   127
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   128
      val session =
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   129
        Thy_Resources.start_session(
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   130
          base_info.options,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   131
          base_info.session,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   132
          session_dirs = base_info.dirs,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   133
          session_base = Some(base_info.check_base),
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   134
          print_mode = args.print_mode,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   135
          progress = progress,
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   136
          log = log)
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   137
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   138
      val id = UUID()
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   139
67921
1722384ffd4a clarified signature: more uniform session_id;
wenzelm
parents: 67920
diff changeset
   140
      (JSON.Object("session_id" -> id.toString), id -> session)
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   141
    }
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   142
  }
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   143
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   144
  object Session_Stop
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   145
  {
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   146
    def unapply(json: JSON.T): Option[UUID] =
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   147
      JSON.uuid(json, "session_id")
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   148
67878
15027fb50a0c clarified signature;
wenzelm
parents: 67871
diff changeset
   149
    def command(session: Thy_Resources.Session): (JSON.Object.T, Process_Result) =
67871
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   150
    {
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   151
      val result = session.stop()
67916
a72f01c63262 clarified result;
wenzelm
parents: 67914
diff changeset
   152
      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
   153
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   154
      if (result.ok) (result_json, result)
195ff117894c store session: per Server/Context, not Connection;
wenzelm
parents: 67869
diff changeset
   155
      else throw new Server.Error("Session shutdown failed: return code " + result.rc, result_json)
67869
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   156
    }
8cb4fef58379 support for "session_start";
wenzelm
parents: 67863
diff changeset
   157
  }
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   158
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   159
  object Use_Theories
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   160
  {
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   161
    sealed case class Args(
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   162
      session_id: UUID,
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   163
      theories: List[(String, Position.T)],
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   164
      qualifier: String = default_qualifier,
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   165
      master_dir: String = "",
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   166
      pretty_margin: Double = Pretty.default_margin,
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   167
      unicode_symbols: Boolean = false)
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   168
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   169
    def unapply(json: JSON.T): Option[Args] =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   170
      for {
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   171
        session_id <- JSON.uuid(json, "session_id")
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   172
        theories <- JSON.list(json, "theories", unapply_name_pos _)
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   173
        qualifier <- JSON.string_default(json, "qualifier", default_qualifier)
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   174
        master_dir <- JSON.string_default(json, "master_dir")
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   175
        pretty_margin <- JSON.double_default(json, "pretty_margin", Pretty.default_margin)
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   176
        unicode_symbols <- JSON.bool_default(json, "unicode_symbols")
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   177
      }
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   178
      yield {
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   179
        Args(session_id, theories, qualifier = qualifier, master_dir = master_dir,
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   180
          pretty_margin = pretty_margin, unicode_symbols)
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   181
      }
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   182
67884
43af581d7d8e unload_theories after consolidation -- reset node_required;
wenzelm
parents: 67883
diff changeset
   183
    def command(args: Args,
43af581d7d8e unload_theories after consolidation -- reset node_required;
wenzelm
parents: 67883
diff changeset
   184
      session: Thy_Resources.Session,
67885
839a624aabb9 prefer typed UUID;
wenzelm
parents: 67884
diff changeset
   185
      id: UUID = UUID(),
67884
43af581d7d8e unload_theories after consolidation -- reset node_required;
wenzelm
parents: 67883
diff changeset
   186
      progress: Progress = No_Progress): (JSON.Object.T, Thy_Resources.Theories_Result) =
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   187
    {
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   188
      val result =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   189
        session.use_theories(args.theories, qualifier = args.qualifier,
67884
43af581d7d8e unload_theories after consolidation -- reset node_required;
wenzelm
parents: 67883
diff changeset
   190
          master_dir = args.master_dir, id = id, progress = progress)
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   191
67901
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   192
      def output_text(s: String): String =
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   193
        if (args.unicode_symbols) Symbol.decode(s) else Symbol.encode(s)
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   194
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   195
      def output_message(tree: XML.Tree, pos: Position.T): JSON.Object.T =
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   196
      {
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   197
        val position = "pos" -> Position.JSON(pos)
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   198
        tree match {
67901
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   199
          case XML.Text(msg) => Server.Reply.message(output_text(msg)) + position
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   200
          case elem: XML.Elem =>
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   201
            val msg = XML.content(Pretty.formatted(List(elem), margin = args.pretty_margin))
67901
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   202
            val kind = Markup.messages.collectFirst({ case (a, b) if b == elem.name => a })
3e6864cf387f more explicit error messages;
wenzelm
parents: 67900
diff changeset
   203
            Server.Reply.message(output_text(msg), kind = kind getOrElse "") + position
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   204
        }
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   205
      }
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   206
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   207
      val result_json =
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   208
        JSON.Object(
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   209
          "ok" -> result.ok,
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   210
          "errors" ->
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   211
            (for {
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   212
              (name, status) <- result.nodes if !status.ok
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   213
              (tree, pos) <- result.messages(name) if Protocol.is_error(tree)
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   214
            } yield output_message(tree, pos)),
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   215
          "nodes" ->
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   216
            (for ((name, status) <- result.nodes) yield
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   217
              JSON.Object(
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   218
                "node_name" -> name.node,
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   219
                "theory" -> name.theory,
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   220
                "status" -> status.json,
67897
a5b9d1f51b04 output result messages;
wenzelm
parents: 67886
diff changeset
   221
                "messages" ->
67900
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   222
                  (for ((tree, pos) <- result.messages(name))
5a1b0076d7f0 more explicit errors;
wenzelm
parents: 67897
diff changeset
   223
                    yield output_message(tree, pos)))))
67883
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   224
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   225
      (result_json, result)
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   226
    }
171e7735ce25 support for "use_theories";
wenzelm
parents: 67878
diff changeset
   227
  }
67848
dd83610333de added server command "session_build": similar to JEdit_Resources.session_build;
wenzelm
parents:
diff changeset
   228
}