src/Pure/Tools/dump.scala
author wenzelm
Tue, 29 May 2018 14:38:32 +0200
changeset 68316 a1e5de3681f0
parent 68308 119fc05f6b00
child 68318 5971199863ea
permissions -rw-r--r--
more formal dump aspects; support output dir;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/dump.scala
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     3
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     4
Dump build database produced by PIDE session.
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     5
*/
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     6
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     7
package isabelle
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     8
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
     9
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    10
object Dump
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    11
{
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    12
  /* aspects */
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    13
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    14
  sealed case class Aspect_Args(
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    15
    options: Options, progress: Progress, output_dir: Path, result: Thy_Resources.Theories_Result)
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    16
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    17
  sealed case class Aspect(name: String, description: String, operation: Aspect_Args => Unit)
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    18
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    19
  private val known_aspects =
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    20
    List(
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    21
      Aspect("list", "list theory nodes",
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    22
        { case args => for ((node, _) <- args.result.nodes) args.progress.echo(node.toString) })
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    23
    )
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    24
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    25
  def show_aspects: String =
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    26
    cat_lines(known_aspects.map(aspect => aspect.name + " - " + aspect.description))
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    27
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    28
  def the_aspect(name: String): Aspect =
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    29
    known_aspects.find(aspect => aspect.name == name) getOrElse
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    30
      error("Unknown aspect " + quote(name))
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    31
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    32
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    33
  /* dump */
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    34
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    35
  val default_output_dir = Path.explode("dump")
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    36
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    37
  def dump(options: Options, logic: String,
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    38
    aspects: List[Aspect] = Nil,
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    39
    progress: Progress = No_Progress,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    40
    log: Logger = No_Logger,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    41
    dirs: List[Path] = Nil,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    42
    select_dirs: List[Path] = Nil,
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    43
    output_dir: Path = default_output_dir,
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    44
    verbose: Boolean = false,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    45
    system_mode: Boolean = false,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    46
    selection: Sessions.Selection = Sessions.Selection.empty): Process_Result =
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    47
  {
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    48
    if (Build.build_logic(options, logic, progress = progress, dirs = dirs,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    49
      system_mode = system_mode) != 0) error(logic + " FAILED")
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    50
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    51
    val dump_options = options.int.update("completion_limit", 0).bool.update("ML_statistics", false)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    52
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    53
    val deps =
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    54
      Sessions.load_structure(dump_options, dirs = dirs, select_dirs = select_dirs).
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    55
        selection_deps(selection)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    56
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    57
    val session =
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    58
      Thy_Resources.start_session(dump_options, logic, session_dirs = dirs,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    59
        include_sessions = deps.sessions_structure.imports_topological_order,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    60
        progress = progress, log = log)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    61
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    62
    val theories = deps.all_known.theory_graph.topological_order.map(_.theory)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    63
    val theories_result = session.use_theories(theories, progress = progress)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    64
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    65
    val args = Aspect_Args(dump_options, progress, output_dir, theories_result)
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    66
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    67
    try { aspects.foreach(aspect => aspect.operation(args)) }
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    68
    catch { case exn: Throwable => session.stop (); throw exn }
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    69
    session.stop()
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    70
  }
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    71
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    72
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    73
  /* Isabelle tool wrapper */
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    74
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    75
  val isabelle_tool =
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    76
    Isabelle_Tool("dump", "dump build database produced by PIDE session.", args =>
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    77
    {
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    78
      var aspects: List[Aspect] = Nil
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    79
      var base_sessions: List[String] = Nil
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    80
      var select_dirs: List[Path] = Nil
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    81
      var output_dir = default_output_dir
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    82
      var requirements = false
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    83
      var exclude_session_groups: List[String] = Nil
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    84
      var all_sessions = false
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    85
      var dirs: List[Path] = Nil
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    86
      var session_groups: List[String] = Nil
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    87
      var logic = Isabelle_System.getenv("ISABELLE_LOGIC")
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    88
      var options = Options.init()
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    89
      var system_mode = false
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    90
      var verbose = false
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    91
      var exclude_sessions: List[String] = Nil
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    92
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    93
      val getopts = Getopts("""
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    94
Usage: isabelle dump [OPTIONS] [SESSIONS ...]
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    95
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    96
  Options are:
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
    97
    -A NAMES     dump named aspects (comma-separated list, see below)
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    98
    -B NAME      include session NAME and all descendants
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
    99
    -D DIR       include session directory and select its sessions
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   100
    -O DIR       output directory for dumped files (default: """ + default_output_dir + """)
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   101
    -R           operate on requirements of selected sessions
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   102
    -X NAME      exclude sessions from group NAME and all descendants
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   103
    -a           select all sessions
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   104
    -d DIR       include session directory
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   105
    -g NAME      select session group NAME
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   106
    -l NAME      logic session name (default ISABELLE_LOGIC=""" + quote(logic) + """)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   107
    -o OPTION    override Isabelle system OPTION (via NAME=VAL or NAME)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   108
    -s           system build mode for logic image
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   109
    -v           verbose
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   110
    -x NAME      exclude session NAME and all descendants
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   111
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   112
  Dump build database produced by PIDE session. The following dump aspects
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   113
  are known (option -A):
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   114
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   115
""" + Library.prefix_lines("    ", show_aspects) + "\n",
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   116
      "A:" -> (arg => aspects = Library.distinct(space_explode(',', arg)).map(the_aspect(_))),
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   117
      "B:" -> (arg => base_sessions = base_sessions ::: List(arg)),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   118
      "D:" -> (arg => select_dirs = select_dirs ::: List(Path.explode(arg))),
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   119
      "O:" -> (arg => output_dir = Path.explode(arg)),
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   120
      "R" -> (_ => requirements = true),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   121
      "X:" -> (arg => exclude_session_groups = exclude_session_groups ::: List(arg)),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   122
      "a" -> (_ => all_sessions = true),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   123
      "d:" -> (arg => dirs = dirs ::: List(Path.explode(arg))),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   124
      "l:" -> (arg => logic = arg),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   125
      "g:" -> (arg => session_groups = session_groups ::: List(arg)),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   126
      "o:" -> (arg => options = options + arg),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   127
      "s" -> (_ => system_mode = true),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   128
      "v" -> (_ => verbose = true),
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   129
      "x:" -> (arg => exclude_sessions = exclude_sessions ::: List(arg)))
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   130
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   131
      val sessions = getopts(args)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   132
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   133
      val progress = new Console_Progress(verbose = verbose)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   134
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   135
      val result =
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   136
        dump(options, logic,
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   137
          aspects = aspects,
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   138
          progress = progress,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   139
          dirs = dirs,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   140
          select_dirs = select_dirs,
68316
a1e5de3681f0 more formal dump aspects;
wenzelm
parents: 68308
diff changeset
   141
          output_dir = output_dir,
68308
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   142
          verbose = verbose,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   143
          selection = Sessions.Selection(
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   144
            requirements = requirements,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   145
            all_sessions = all_sessions,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   146
            base_sessions = base_sessions,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   147
            exclude_session_groups = exclude_session_groups,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   148
            exclude_sessions = exclude_sessions,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   149
            session_groups = session_groups,
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   150
            sessions = sessions))
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   151
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   152
      progress.echo(result.timing.message_resources)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   153
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   154
      sys.exit(result.rc)
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   155
    })
119fc05f6b00 support to dump build database produced by PIDE session;
wenzelm
parents:
diff changeset
   156
}