src/Pure/System/build_dialog.scala
author wenzelm
Wed, 05 Dec 2012 20:24:49 +0100
changeset 50377 fe4bc5b2abb4
parent 50376 82cbe4051d98
child 50378 72367327bab2
permissions -rw-r--r--
center main window;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/System/build_dialog.scala
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     3
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     4
Dialog for session build process.
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     5
*/
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     6
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     7
package isabelle
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     8
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
     9
50377
fe4bc5b2abb4 center main window;
wenzelm
parents: 50376
diff changeset
    10
import java.awt.{GraphicsEnvironment, Point}
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    11
import scala.swing.{ScrollPane, Button, CheckBox, FlowPanel,
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    12
  BorderPanel, MainFrame, TextArea, SwingApplication}
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    13
import scala.swing.event.ButtonClicked
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    14
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    15
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    16
object Build_Dialog extends SwingApplication
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    17
{
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    18
  def startup(args: Array[String]) =
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    19
  {
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    20
    Platform.init_laf()
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    21
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    22
    try {
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    23
      args.toList match {
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    24
        case
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    25
          Properties.Value.Boolean(system_mode) ::
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    26
          session :: include_dirs =>
50377
fe4bc5b2abb4 center main window;
wenzelm
parents: 50376
diff changeset
    27
            val center = GraphicsEnvironment.getLocalGraphicsEnvironment().getCenterPoint()
50370
d5dbb63df0c7 check for existing image (even if outdated);
wenzelm
parents: 50369
diff changeset
    28
            val top = build_dialog(system_mode, include_dirs.map(Path.explode), session)
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    29
            top.pack()
50377
fe4bc5b2abb4 center main window;
wenzelm
parents: 50376
diff changeset
    30
            top.location = new Point(center.x - top.size.width / 2, center.y - top.size.height / 2)
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    31
            top.visible = true
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    32
        case _ => error("Bad arguments:\n" + cat_lines(args))
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    33
      }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    34
    }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    35
    catch {
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    36
      case exn: Throwable =>
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    37
        Library.error_dialog(null, "Isabelle build failure",
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    38
          Library.scrollable_text(Exn.message(exn)))
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    39
        sys.exit(2)
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    40
    }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    41
  }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    42
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    43
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    44
  def build_dialog(
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    45
    system_mode: Boolean,
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    46
    include_dirs: List[Path],
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    47
    session: String): MainFrame = new MainFrame
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    48
  {
50368
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    49
    /* GUI state */
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    50
50368
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    51
    private var is_stopped = false
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    52
    private var return_code = 0
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    53
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    54
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    55
    /* text */
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    56
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    57
    val text = new TextArea {
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    58
      editable = false
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    59
      columns = 40
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    60
      rows = 10
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    61
    }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    62
50368
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    63
    val progress = new Build.Progress
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    64
    {
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    65
      override def echo(msg: String): Unit = Swing_Thread.now { text.append(msg + "\n") }
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    66
      override def stopped: Boolean =
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    67
        Swing_Thread.now { val b = is_stopped; is_stopped = false; b  }
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    68
    }
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    69
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    70
50376
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    71
    /* action button */
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    72
50376
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    73
    var button_action: () => Unit = (() => is_stopped = true)
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    74
    val button = new Button("Cancel") {
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    75
      reactions += { case ButtonClicked(_) => button_action() }
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    76
    }
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    77
    def button_exit(rc: Int)
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    78
    {
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    79
      button.text = if (rc == 0) "OK" else "Exit"
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    80
      button_action = (() => sys.exit(rc))
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    81
    }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
    82
50376
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    83
    val action_panel = new FlowPanel(FlowPanel.Alignment.Center)(button)
50368
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    84
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    85
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    86
    /* layout panel */
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    87
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    88
    val layout_panel = new BorderPanel
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    89
    layout_panel.layout(new ScrollPane(text)) = BorderPanel.Position.Center
50376
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
    90
    layout_panel.layout(action_panel) = BorderPanel.Position.South
50368
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    91
e6c0720e4cef basic interaction with build process;
wenzelm
parents: 50365
diff changeset
    92
    contents = layout_panel
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    93
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    94
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    95
    /* main build */
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    96
50374
1a7cae0711d2 tuned message;
wenzelm
parents: 50372
diff changeset
    97
    title = "Isabelle build (" + Isabelle_System.getenv("ML_IDENTIFIER") + ")"
50372
11c96cac860d tuned message;
wenzelm
parents: 50371
diff changeset
    98
    progress.echo("Build started for Isabelle/" + session + " ...")
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
    99
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   100
    default_thread_pool.submit(() => {
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   101
      val (out, rc) =
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   102
        try {
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   103
          ("",
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   104
            Build.build(progress, build_heap = true,
50370
d5dbb63df0c7 check for existing image (even if outdated);
wenzelm
parents: 50369
diff changeset
   105
              system_mode = system_mode, sessions = List(session)))
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   106
        }
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   107
        catch { case exn: Throwable => (Exn.message(exn) + "\n", 2) }
50376
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
   108
      Swing_Thread.now {
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
   109
        progress.echo(out + (if (rc == 0) "OK\n" else "Return code: " + rc + "\n"))
82cbe4051d98 more direct dialog via existing GUI components;
wenzelm
parents: 50374
diff changeset
   110
        button_exit(rc)
50371
9b6f5f758c31 tuned OK feedback;
wenzelm
parents: 50370
diff changeset
   111
      }
50369
622002c702ad more elementary dialog, with less interaction;
wenzelm
parents: 50368
diff changeset
   112
    })
50365
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
   113
  }
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
   114
}
82f5aea343e7 basic wrapper for session build dialog;
wenzelm
parents:
diff changeset
   115