src/Tools/jEdit/src/prover/MarkupNode.scala
author wenzelm
Sat, 05 Sep 2009 00:43:59 +0200
changeset 34708 611864f2729d
parent 34707 cc5d388fcbf2
child 34717 3f32e08bbb6c
permissions -rw-r--r--
tuned MarkupNode argument order; tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     1
/*
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34402
diff changeset
     2
 * Document markup nodes, with connection to Swing tree model
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     3
 *
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34402
diff changeset
     4
 * @author Fabian Immler, TU Munich
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     5
 */
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     6
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     7
package isabelle.prover
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
     8
34701
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
     9
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    10
import javax.swing.tree.DefaultMutableTreeNode
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    11
34554
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34517
diff changeset
    12
import isabelle.proofdocument.ProofDocument
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34517
diff changeset
    13
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
    14
34708
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    15
class MarkupNode(val start: Int, val stop: Int, val content: String, val info: Any,
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    16
  val children: List[MarkupNode])
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    17
{
34656
2740439a86b4 decode offsets with respect to symbols
immler@in.tum.de
parents: 34597
diff changeset
    18
34704
504cab625d3e simplified MarkupNode -- independent of Command and ProofDocument;
wenzelm
parents: 34703
diff changeset
    19
  def swing_tree(make_node: MarkupNode => DefaultMutableTreeNode): DefaultMutableTreeNode =
34701
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    20
  {
34704
504cab625d3e simplified MarkupNode -- independent of Command and ProofDocument;
wenzelm
parents: 34703
diff changeset
    21
    val node = make_node(this)
504cab625d3e simplified MarkupNode -- independent of Command and ProofDocument;
wenzelm
parents: 34703
diff changeset
    22
    children.foreach(node add _.swing_tree(make_node))
34554
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34517
diff changeset
    23
    node
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34517
diff changeset
    24
  }
34557
647a2430d1cd immutable markup-nodes;
immler@in.tum.de
parents: 34555
diff changeset
    25
34701
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    26
  def set_children(new_children: List[MarkupNode]): MarkupNode =
34708
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    27
    new MarkupNode(start, stop, content, info, new_children)
34514
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    28
34701
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    29
  private def add(child: MarkupNode) =   // FIXME avoid sort?
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    30
    set_children ((child :: children) sort ((a, b) => a.start < b.start))
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
    31
34708
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    32
  def remove(nodes: List[MarkupNode]) = set_children(children -- nodes)
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
    33
34703
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    34
  def fits_into(node: MarkupNode): Boolean =
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    35
    node.start <= this.start && this.stop <= node.stop
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    36
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    37
  def + (new_child: MarkupNode): MarkupNode =
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    38
  {
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    39
    if (new_child fits_into this) {
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    40
      var inserted = false
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    41
      val new_children =
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    42
        children.map(c =>
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    43
          if ((new_child fits_into c) && !inserted) {inserted = true; c + new_child}
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    44
          else c)
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    45
      if (!inserted) {
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    46
        // new_child did not fit into children of this
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    47
        // -> insert new_child between this and its children
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    48
        val fitting = children filter(_ fits_into new_child)
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    49
        (this remove fitting) add ((new_child /: fitting) (_ + _))
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    50
      }
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    51
      else this set_children new_children
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    52
    }
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    53
    else {
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    54
      System.err.println("ignored nonfitting markup: " + new_child)
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    55
      this
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    56
    }
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    57
  }
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    58
34514
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    59
  def flatten: List[MarkupNode] = {
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    60
    var next_x = start
34703
ff037c17332a minor tuning;
wenzelm
parents: 34701
diff changeset
    61
    if (children.isEmpty) List(this)
34514
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    62
    else {
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    63
      val filled_gaps = for {
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    64
        child <- children
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    65
        markups =
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    66
          if (next_x < child.start) {
34708
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    67
            // FIXME proper content!?
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    68
            new MarkupNode(next_x, child.start, content, info, Nil) :: child.flatten
34704
504cab625d3e simplified MarkupNode -- independent of Command and ProofDocument;
wenzelm
parents: 34703
diff changeset
    69
          }
504cab625d3e simplified MarkupNode -- independent of Command and ProofDocument;
wenzelm
parents: 34703
diff changeset
    70
          else child.flatten
34514
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    71
        update = (next_x = child.stop)
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    72
        markup <- markups
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    73
      } yield markup
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    74
      if (next_x < stop)
34708
611864f2729d tuned MarkupNode argument order;
wenzelm
parents: 34707
diff changeset
    75
        filled_gaps + new MarkupNode(next_x, stop, content, info, Nil) // FIXME proper content!?
34514
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    76
      else filled_gaps
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    77
    }
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    78
  }
2104a836b415 renamed fields of MarkupNode; implemented flatten and leafs
immler@in.tum.de
parents: 34503
diff changeset
    79
34701
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    80
  def filter(p: MarkupNode => Boolean): List[MarkupNode] =
80b0add08eef IsabelleSideKickParser: incorporate former MarkupNode.markup2default_node, observe stopped flag;
wenzelm
parents: 34676
diff changeset
    81
  {
34559
2adb23c3e5d1 implemented filter on markup-tree
immler@in.tum.de
parents: 34558
diff changeset
    82
    val filtered = children.flatMap(_.filter(p))
2adb23c3e5d1 implemented filter on markup-tree
immler@in.tum.de
parents: 34558
diff changeset
    83
    if (p(this)) List(this set_children(filtered))
2adb23c3e5d1 implemented filter on markup-tree
immler@in.tum.de
parents: 34558
diff changeset
    84
    else filtered
2adb23c3e5d1 implemented filter on markup-tree
immler@in.tum.de
parents: 34558
diff changeset
    85
  }
2adb23c3e5d1 implemented filter on markup-tree
immler@in.tum.de
parents: 34558
diff changeset
    86
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34577
diff changeset
    87
  override def toString =
34705
cd2cdf3b33b9 MarkupNode: removed id;
wenzelm
parents: 34704
diff changeset
    88
    "([" + start + " - " + stop + "] ( " + content + "): " + info.toString
34393
f0e1608a774f basic tree structure for sidekick
immler@in.tum.de
parents:
diff changeset
    89
}