src/Tools/Graphview/mutator_dialog.scala
author wenzelm
Thu, 01 Jan 2015 13:07:30 +0100
changeset 59221 f779f83ef4ec
parent 59218 eadd82d440b0
child 59222 74798d216b1f
permissions -rw-r--r--
tuned signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
59202
711c2446dc9d clarified source location;
wenzelm
parents: 55618
diff changeset
     1
/*  Title:      Tools/Graphview/mutator_dialog.scala
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     2
    Author:     Markus Kaiser, TU Muenchen
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     3
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     4
Mutator selection and configuration dialog.
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     5
*/
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     6
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     7
package isabelle.graphview
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
     8
55618
995162143ef4 tuned imports;
wenzelm
parents: 50475
diff changeset
     9
49558
af7b652180d5 minimal component and build setup for graphview;
wenzelm
parents: 49557
diff changeset
    10
import isabelle._
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    11
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    12
import java.awt.Color
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    13
import java.awt.FocusTraversalPolicy
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    14
import javax.swing.JColorChooser
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    15
import javax.swing.border.EmptyBorder
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    16
import scala.collection.JavaConversions._
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    17
import scala.swing._
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    18
import scala.swing.event.ValueChanged
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    19
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    20
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    21
class Mutator_Dialog(
50475
8cc351df4a23 just one class with parameters;
wenzelm
parents: 50472
diff changeset
    22
    visualizer: Visualizer,
50472
bad1a1ca61e1 separate instance of class Parameters for each Main_Panel -- avoid global program state;
wenzelm
parents: 50467
diff changeset
    23
    container: Mutator_Container,
bad1a1ca61e1 separate instance of class Parameters for each Main_Panel -- avoid global program state;
wenzelm
parents: 50467
diff changeset
    24
    caption: String,
49733
38a68e6593be prefer synchronous Mutator_Event.Bus on Swing_Thread;
wenzelm
parents: 49565
diff changeset
    25
    reverse_caption: String = "Inverse",
38a68e6593be prefer synchronous Mutator_Event.Bus on Swing_Thread;
wenzelm
parents: 49565
diff changeset
    26
    show_color_chooser: Boolean = true)
38a68e6593be prefer synchronous Mutator_Event.Bus on Swing_Thread;
wenzelm
parents: 49565
diff changeset
    27
  extends Dialog
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    28
{
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    29
  title = caption
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    30
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    31
  private var _panels: List[Mutator_Panel] = Nil
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    32
  private def panels = _panels
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    33
  private def panels_=(panels: List[Mutator_Panel])
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    34
  {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    35
    _panels = panels
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    36
    paintPanels
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    37
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    38
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    39
  container.events +=
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    40
  {
49733
38a68e6593be prefer synchronous Mutator_Event.Bus on Swing_Thread;
wenzelm
parents: 49565
diff changeset
    41
    case Mutator_Event.Add(m) => addPanel(new Mutator_Panel(m))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    42
    case Mutator_Event.New_List(ms) => panels = get_panels(ms)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    43
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    44
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    45
  override def open()
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    46
  {
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    47
    if (!visible) panels = get_panels(container())
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    48
    super.open
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    49
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    50
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    51
  minimumSize = new Dimension(700, 200)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    52
  preferredSize = new Dimension(1000, 300)
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    53
  peer.setFocusTraversalPolicy(Focus_Traversal)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    54
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    55
  private def get_panels(m: List[Mutator.Info]): List[Mutator_Panel] =
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    56
    m.filter({ case Mutator.Info(_, _, Mutator.Identity()) => false case _ => true })
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    57
    .map(m => new Mutator_Panel(m))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    58
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    59
  private def get_mutators(panels: List[Mutator_Panel]): List[Mutator.Info] =
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    60
    panels.map(panel => panel.get_mutator)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    61
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    62
  private def movePanelUp(m: Mutator_Panel) =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    63
  {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    64
    def moveUp(l: List[Mutator_Panel]): List[Mutator_Panel] =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    65
      l match {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    66
        case x :: y :: xs => if (y == m) y :: x :: xs else x :: moveUp(y :: xs)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    67
        case _ => l
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    68
      }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    69
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    70
    panels = moveUp(panels)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    71
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    72
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    73
  private def movePanelDown(m: Mutator_Panel) =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    74
  {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    75
    def moveDown(l: List[Mutator_Panel]): List[Mutator_Panel] =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    76
      l match {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    77
        case x :: y :: xs => if (x == m) y :: x :: xs else x :: moveDown(y :: xs)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    78
        case _ => l
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    79
      }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    80
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    81
    panels = moveDown(panels)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    82
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    83
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    84
  private def removePanel(m: Mutator_Panel)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    85
  {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    86
    panels = panels.filter(_ != m).toList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    87
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    88
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    89
  private def addPanel(m: Mutator_Panel)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    90
  {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    91
    panels = panels ::: List(m)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    92
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    93
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    94
  def paintPanels
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
    95
  {
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
    96
    Focus_Traversal.clear
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    97
    filterPanel.contents.clear
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    98
    panels.map(x => {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
    99
        filterPanel.contents += x
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   100
        Focus_Traversal.addAll(x.focusList)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   101
      })
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   102
    filterPanel.contents += Swing.VGlue
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   103
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   104
    Focus_Traversal.add(mutator_box.peer.asInstanceOf[java.awt.Component])
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   105
    Focus_Traversal.add(add_button.peer)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   106
    Focus_Traversal.add(apply_button.peer)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   107
    Focus_Traversal.add(cancel_button.peer)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   108
    filterPanel.revalidate
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   109
    filterPanel.repaint
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   110
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   111
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   112
  val filterPanel = new BoxPanel(Orientation.Vertical) {}
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   113
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   114
  private val mutator_box = new ComboBox[Mutator](container.available)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   115
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   116
  private val add_button: Button = new Button {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   117
    action = Action("Add") {
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   118
      addPanel(
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   119
        new Mutator_Panel(Mutator.Info(true, visualizer.Colors.next, mutator_box.selection.item)))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   120
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   121
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   122
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   123
  private val apply_button = new Button {
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   124
    action = Action("Apply") { container(get_mutators(panels)) }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   125
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   126
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   127
  private val reset_button = new Button {
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   128
    action = Action("Reset") { panels = get_panels(container()) }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   129
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   130
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   131
  private val cancel_button = new Button {
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   132
    action = Action("Close") { close }
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   133
  }
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   134
  defaultButton = cancel_button
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   135
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   136
  private val botPanel = new BoxPanel(Orientation.Horizontal) {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   137
    border = new EmptyBorder(10, 0, 0, 0)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   138
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   139
    contents += mutator_box
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   140
    contents += Swing.RigidBox(new Dimension(10, 0))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   141
    contents += add_button
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   142
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   143
    contents += Swing.HGlue
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   144
    contents += Swing.RigidBox(new Dimension(30, 0))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   145
    contents += apply_button
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   146
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   147
    contents += Swing.RigidBox(new Dimension(5, 0))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   148
    contents += reset_button
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   149
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   150
    contents += Swing.RigidBox(new Dimension(5, 0))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   151
    contents += cancel_button
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   152
  }
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   153
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   154
  contents = new BorderPanel {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   155
    border = new EmptyBorder(5, 5, 5, 5)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   156
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   157
    add(new ScrollPane(filterPanel), BorderPanel.Position.Center)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   158
    add(botPanel, BorderPanel.Position.South)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   159
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   160
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   161
  private class Mutator_Panel(initials: Mutator.Info)
50472
bad1a1ca61e1 separate instance of class Parameters for each Main_Panel -- avoid global program state;
wenzelm
parents: 50467
diff changeset
   162
    extends BoxPanel(Orientation.Horizontal)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   163
  {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   164
    private val inputs: List[(String, Mutator_Input_Value)] = get_Inputs()
50467
wenzelm
parents: 50463
diff changeset
   165
    var focusList = List.empty[java.awt.Component]
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   166
    private val enabledBox = new iCheckBox("Enabled", initials.enabled)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   167
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   168
    border = new EmptyBorder(5, 5, 5, 5)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   169
    maximumSize = new Dimension(Integer.MAX_VALUE, 30)
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   170
    background = initials.color
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   171
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   172
    contents += new Label(initials.mutator.name) {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   173
      preferredSize = new Dimension(175, 20)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   174
      horizontalAlignment = Alignment.Left
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   175
      if (initials.mutator.description != "") tooltip = initials.mutator.description
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   176
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   177
    contents += Swing.RigidBox(new Dimension(10, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   178
    contents += enabledBox
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   179
    contents += Swing.RigidBox(new Dimension(5, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   180
    focusList = enabledBox.peer :: focusList
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   181
    inputs.map(_ match {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   182
      case (n, c) =>
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   183
        contents += Swing.RigidBox(new Dimension(10, 0))
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   184
        if (n != "") {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   185
          contents += new Label(n)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   186
          contents += Swing.RigidBox(new Dimension(5, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   187
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   188
        contents += c.asInstanceOf[Component]
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   189
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   190
        focusList = c.asInstanceOf[Component].peer :: focusList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   191
      case _ =>
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   192
    })
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   193
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   194
    {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   195
      val t = this
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   196
      contents += Swing.HGlue
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   197
      contents += Swing.RigidBox(new Dimension(10, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   198
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   199
      if (show_color_chooser) {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   200
        contents += new Button {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   201
          maximumSize = new Dimension(20, 20)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   202
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   203
          action = Action("Color") {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   204
            t.background =
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   205
              JColorChooser.showDialog(t.peer, "Choose new Color", t.background)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   206
          }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   207
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   208
          focusList = this.peer :: focusList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   209
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   210
        contents += Swing.RigidBox(new Dimension(2, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   211
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   212
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   213
      contents += new Button {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   214
        maximumSize = new Dimension(20, 20)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   215
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   216
        action = Action("Up") {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   217
          movePanelUp(t)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   218
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   219
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   220
        focusList = this.peer :: focusList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   221
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   222
      contents += Swing.RigidBox(new Dimension(2, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   223
      contents += new Button {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   224
        maximumSize = new Dimension(20, 20)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   225
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   226
        action = Action("Down") {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   227
          movePanelDown(t)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   228
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   229
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   230
        focusList = this.peer :: focusList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   231
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   232
      contents += Swing.RigidBox(new Dimension(2, 0))
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   233
      contents += new Button {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   234
        maximumSize = new Dimension(20, 20)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   235
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   236
        action = Action("Del") {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   237
          removePanel(t)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   238
        }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   239
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   240
        focusList = this.peer :: focusList
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   241
      }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   242
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   243
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   244
    focusList = focusList.reverse
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   245
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   246
    private def isRegex(regex: String): Boolean =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   247
    {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   248
      try { regex.r; true }
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   249
      catch { case _: java.util.regex.PatternSyntaxException =>  false }
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   250
    }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   251
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   252
    def get_mutator: Mutator.Info =
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   253
    {
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   254
      def regexOrElse(regex: String, orElse: String): String =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   255
      {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   256
        if (isRegex(regex)) regex
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   257
        else orElse
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   258
      }
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   259
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   260
      val m =
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   261
        initials.mutator match {
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   262
          case Mutator.Identity() =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   263
            Mutator.Identity()
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   264
          case Mutator.Node_Expression(r, _, _, _) =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   265
            Mutator.Node_Expression(
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   266
              regexOrElse(inputs(2)._2.getString, r),
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   267
              inputs(3)._2.getBool,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   268
              // "Parents" means "Show parents" or "Matching Children"
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   269
              inputs(1)._2.getBool,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   270
              inputs(0)._2.getBool)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   271
          case Mutator.Node_List(_, _, _, _) =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   272
            Mutator.Node_List(
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   273
              inputs(2)._2.getString.split(',').filter(_ != "").toList,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   274
              inputs(3)._2.getBool,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   275
              // "Parents" means "Show parents" or "Matching Children"
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   276
              inputs(1)._2.getBool,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   277
              inputs(0)._2.getBool)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   278
          case Mutator.Edge_Endpoints(_, _) =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   279
            Mutator.Edge_Endpoints(
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   280
              inputs(0)._2.getString,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   281
              inputs(1)._2.getString)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   282
          case Mutator.Add_Node_Expression(r) =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   283
            Mutator.Add_Node_Expression(regexOrElse(inputs(0)._2.getString, r))
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   284
          case Mutator.Add_Transitive_Closure(_, _) =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   285
            Mutator.Add_Transitive_Closure(
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   286
              inputs(0)._2.getBool,
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   287
              inputs(1)._2.getBool)
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   288
          case _ =>
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   289
            Mutator.Identity()
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   290
        }
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   291
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   292
      Mutator.Info(enabledBox.selected, background, m)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   293
    }
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   294
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   295
    private def get_Inputs(): List[(String, Mutator_Input_Value)] =
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   296
      initials.mutator match {
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   297
        case Mutator.Node_Expression(regex, reverse, check_parents, check_children) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   298
          List(
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   299
            ("", new iCheckBox("Parents", check_children)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   300
            ("", new iCheckBox("Children", check_parents)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   301
            ("Regex", new iTextField(regex, x => !isRegex(x))),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   302
            ("", new iCheckBox(reverse_caption, reverse)))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   303
        case Mutator.Node_List(list, reverse, check_parents, check_children) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   304
          List(
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   305
            ("", new iCheckBox("Parents", check_children)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   306
            ("", new iCheckBox("Children", check_parents)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   307
            ("Names", new iTextField(list.mkString(","))),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   308
            ("", new iCheckBox(reverse_caption, reverse)))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   309
        case Mutator.Edge_Endpoints(source, dest) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   310
          List(
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   311
            ("Source", new iTextField(source)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   312
            ("Destination", new iTextField(dest)))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   313
        case Mutator.Add_Node_Expression(regex) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   314
          List(("Regex", new iTextField(regex, x => !isRegex(x))))
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   315
        case Mutator.Add_Transitive_Closure(parents, children) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   316
          List(
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   317
            ("", new iCheckBox("Parents", parents)),
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   318
            ("", new iCheckBox("Children", children)))
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   319
        case _ => Nil
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   320
      }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   321
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   322
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   323
  private trait Mutator_Input_Value
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   324
  {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   325
    def getString: String
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   326
    def getBool: Boolean
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   327
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   328
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   329
  private class iTextField(t: String, colorator: String => Boolean)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   330
  extends TextField(t) with Mutator_Input_Value
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   331
  {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   332
    def this(t: String) = this(t, x => false)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   333
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   334
    preferredSize = new Dimension(125, 18)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   335
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   336
    reactions +=
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   337
    {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   338
      case ValueChanged(_) =>
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   339
        if (colorator(text)) background = Color.RED
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   340
        else background = Color.WHITE
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   341
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   342
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   343
    def getString = text
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   344
    def getBool = true
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   345
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   346
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   347
  private class iCheckBox(t: String, s: Boolean)
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   348
  extends CheckBox(t) with Mutator_Input_Value
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   349
  {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   350
    selected = s
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   351
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   352
    def getString = ""
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   353
    def getBool = selected
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   354
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   355
59221
f779f83ef4ec tuned signature;
wenzelm
parents: 59218
diff changeset
   356
  private object Focus_Traversal extends FocusTraversalPolicy
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   357
  {
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   358
    private var items = Vector[java.awt.Component]()
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   359
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   360
    def add(c: java.awt.Component) { items = items :+ c }
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   361
    def addAll(cs: TraversableOnce[java.awt.Component]) { items = items ++ cs }
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   362
    def clear() { items = Vector[java.awt.Component]() }
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   363
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   364
    def getComponentAfter(root: java.awt.Container, c: java.awt.Component): java.awt.Component =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   365
    {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   366
      val i = items.indexOf(c)
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   367
      if (i < 0) getDefaultComponent(root)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   368
      else items((i + 1) % items.length)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   369
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   370
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   371
    def getComponentBefore(root: java.awt.Container, c: java.awt.Component): java.awt.Component =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   372
    {
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   373
      val i = items.indexOf(c)
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   374
      if (i < 0) getDefaultComponent(root)
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   375
      else items((i - 1) % items.length)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   376
    }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   377
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   378
    def getFirstComponent(root: java.awt.Container): java.awt.Component =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   379
      if (items.length > 0) items(0) else null
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   380
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   381
    def getDefaultComponent(root: java.awt.Container): java.awt.Component =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   382
      getFirstComponent(root)
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   383
59218
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   384
    def getLastComponent(root: java.awt.Container): java.awt.Component =
eadd82d440b0 tuned whitespace;
wenzelm
parents: 59202
diff changeset
   385
      if (items.length > 0) items.last else null
49557
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   386
  }
61988f9df94d added Graphview tool, based on Isabelle/Scala and Swing/Graphics2D;
Markus Kaiser <markus.kaiser@in.tum.de>
parents:
diff changeset
   387
}