src/Tools/jEdit/src/jedit/TheoryView.scala
author immler@in.tum.de
Fri, 07 Aug 2009 13:04:59 +0200
changeset 34660 e0561943bfc9
parent 34654 30f588245884
child 34669 73727c7eec64
permissions -rw-r--r--
Change consisting of a list of Edits
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     1
/*
34408
ad7b6c4813c8 added some headers and comments;
wenzelm
parents: 34407
diff changeset
     2
 * jEdit text area as document text source
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     3
 *
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     4
 * @author Fabian Immler, TU Munich
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     5
 * @author Johannes Hölzl, TU Munich
34447
wenzelm
parents: 34446
diff changeset
     6
 * @author Makarius
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     7
 */
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     8
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
     9
package isabelle.jedit
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    10
34532
aaafe9c4180b ProofDocument without state
immler@in.tum.de
parents: 34526
diff changeset
    11
import scala.actors.Actor
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
    12
import scala.actors.Actor._
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    13
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
    14
import isabelle.proofdocument.{ProofDocument, Change, Edit, Insert, Remove}
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    15
import isabelle.prover.{Prover, ProverEvents, Command}
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    16
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    17
import java.awt.Graphics2D
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    18
import java.awt.event.{ActionEvent, ActionListener}
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    19
import java.awt.Color
34447
wenzelm
parents: 34446
diff changeset
    20
import javax.swing.Timer
wenzelm
parents: 34446
diff changeset
    21
import javax.swing.event.{CaretListener, CaretEvent}
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    22
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    23
import org.gjt.sp.jedit.buffer.{BufferListener, JEditBuffer}
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    24
import org.gjt.sp.jedit.textarea.{JEditTextArea, TextAreaExtension, TextAreaPainter}
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    25
import org.gjt.sp.jedit.syntax.{ModeProvider, SyntaxStyle}
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    26
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    27
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
    28
object TheoryView
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
    29
{
34574
d68352286c91 split large changes for faster responses of prover
immler@in.tum.de
parents: 34568
diff changeset
    30
  
34653
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    31
  def choose_color(cmd: Command, doc: ProofDocument): Color = {
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    32
    cmd.status(doc) match {
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    33
      case Command.Status.UNPROCESSED => new Color(255, 228, 225)
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    34
      case Command.Status.FINISHED => new Color(234, 248, 255)
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    35
      case Command.Status.FAILED => new Color(255, 192, 192)
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    36
      case _ => Color.red
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
    37
    }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    38
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    39
}
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    40
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    41
34532
aaafe9c4180b ProofDocument without state
immler@in.tum.de
parents: 34526
diff changeset
    42
class TheoryView (text_area: JEditTextArea, document_actor: Actor)
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
    43
    extends TextAreaExtension with BufferListener
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
    44
{
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    45
34603
83a37e3b8c9c produce ids via Isabelle.system (http://isabelle.in.tum.de/repos/isabelle/rev/c23663825e23);
wenzelm
parents: 34598
diff changeset
    46
  def id() = Isabelle.system.id()
34541
e3ca0658fb6a changes of text with unique id
immler@in.tum.de
parents: 34539
diff changeset
    47
  
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    48
  private val buffer = text_area.getBuffer
34475
f963335dbc6b implemented IsabelleSideKickParser.complete
immler@in.tum.de
parents: 34458
diff changeset
    49
  private val prover = Isabelle.prover_setup(buffer).get.prover
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    50
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    51
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
    52
  private var edits: List[Edit] = Nil
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    53
  private val col_timer = new Timer(300, new ActionListener() {
34515
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
    54
    override def actionPerformed(e: ActionEvent) = commit
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    55
  })
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    56
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    57
  col_timer.stop
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    58
  col_timer.setRepeats(true)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    59
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    60
34566
28fa2f219f01 fixed duplicate activation
immler@in.tum.de
parents: 34565
diff changeset
    61
  private val phase_overview = new PhaseOverviewPanel(prover, text_area, to_current)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    62
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    63
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    64
  /* activation */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    65
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    66
  private val selected_state_controller = new CaretListener {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    67
    override def caretUpdate(e: CaretEvent) = {
34650
d7ba607bf684 current version in theoryview/buffer
immler@in.tum.de
parents: 34649
diff changeset
    68
      val doc = current_document()
34554
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34549
diff changeset
    69
      val cmd = doc.find_command_at(e.getDot)
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34549
diff changeset
    70
      if (cmd != null && doc.token_start(cmd.tokens.first) <= e.getDot &&
34475
f963335dbc6b implemented IsabelleSideKickParser.complete
immler@in.tum.de
parents: 34458
diff changeset
    71
          Isabelle.prover_setup(buffer).get.selected_state != cmd)
f963335dbc6b implemented IsabelleSideKickParser.complete
immler@in.tum.de
parents: 34458
diff changeset
    72
        Isabelle.prover_setup(buffer).get.selected_state = cmd
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    73
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    74
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    75
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
    76
  def activate() {
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    77
    text_area.addCaretListener(selected_state_controller)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    78
    text_area.addLeftOfScrollBar(phase_overview)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    79
    text_area.getPainter.addExtension(TextAreaPainter.LINE_BACKGROUND_LAYER + 1, this)
34538
20bfcca24658 Prover as actor managing ProofDocument-versions (removed EventBus structural_changes);
immler@in.tum.de
parents: 34532
diff changeset
    80
    buffer.setTokenMarker(new DynamicTokenMarker(buffer, prover))
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    81
    buffer.addBufferListener(this)
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    82
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
    83
    edits = List(Insert(0, buffer.getText(0, buffer.getLength)))
34650
d7ba607bf684 current version in theoryview/buffer
immler@in.tum.de
parents: 34649
diff changeset
    84
    commit
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    85
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    86
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
    87
  def deactivate() {
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    88
    buffer.setTokenMarker(buffer.getMode.getTokenMarker)
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
    89
    buffer.removeBufferListener(this)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    90
    text_area.getPainter.removeExtension(this)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    91
    text_area.removeLeftOfScrollBar(phase_overview)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    92
    text_area.removeCaretListener(selected_state_controller)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    93
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    94
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    95
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    96
  /* painting */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    97
34643
3896caeedf82 renamed Delay to clarified version Swing_Thread.delay;
wenzelm
parents: 34642
diff changeset
    98
  val update_delay = Swing_Thread.delay(500){ buffer.propertiesChanged() }
3896caeedf82 renamed Delay to clarified version Swing_Thread.delay;
wenzelm
parents: 34642
diff changeset
    99
  val repaint_delay = Swing_Thread.delay(100){ repaint_all() }
34538
20bfcca24658 Prover as actor managing ProofDocument-versions (removed EventBus structural_changes);
immler@in.tum.de
parents: 34532
diff changeset
   100
  
34582
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
   101
  val change_receiver = actor {
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
   102
    loop {
5d5d253c7c29 superficial tuning;
wenzelm
parents: 34574
diff changeset
   103
      react {
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
   104
        case ProverEvents.Activate =>
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
   105
          activate()
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
   106
        case c: Command =>
34643
3896caeedf82 renamed Delay to clarified version Swing_Thread.delay;
wenzelm
parents: 34642
diff changeset
   107
          update_delay()
3896caeedf82 renamed Delay to clarified version Swing_Thread.delay;
wenzelm
parents: 34642
diff changeset
   108
          repaint_delay()
3896caeedf82 renamed Delay to clarified version Swing_Thread.delay;
wenzelm
parents: 34642
diff changeset
   109
          phase_overview.repaint_delay()
34649
70759ca6bb87 activation
immler@in.tum.de
parents: 34648
diff changeset
   110
        case x => System.err.println("warning: change_receiver ignored " + x)
34538
20bfcca24658 Prover as actor managing ProofDocument-versions (removed EventBus structural_changes);
immler@in.tum.de
parents: 34532
diff changeset
   111
      }
20bfcca24658 Prover as actor managing ProofDocument-versions (removed EventBus structural_changes);
immler@in.tum.de
parents: 34532
diff changeset
   112
    }
34583
17c83413b7fe change_receiver: start only once (already done in actor function);
wenzelm
parents: 34582
diff changeset
   113
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   114
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   115
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   116
  def changes_to(doc: ProofDocument) =
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   117
    edits ::: current_change.ancestors(_.id == doc.id).flatten(_.toList)
34545
b928628742ed implemented to_current and from_current in dependancy of document-versions
immler@in.tum.de
parents: 34544
diff changeset
   118
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   119
  def from_current(doc: ProofDocument, pos: Int) =
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   120
    (pos /: changes_to(doc)) ((p, c) => c from_where p)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   121
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   122
  def to_current(doc: ProofDocument, pos: Int) =
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   123
    (pos /: changes_to(doc).reverse) ((p, c) => c where_to p)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   124
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   125
  def repaint(cmd: Command) =
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   126
  {
34650
d7ba607bf684 current version in theoryview/buffer
immler@in.tum.de
parents: 34649
diff changeset
   127
    val document = current_document()
34507
018bad916757 eliminated Command.Status.REMOVE/REMOVED;
wenzelm
parents: 34496
diff changeset
   128
    if (text_area != null) {
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   129
      val start = text_area.getLineOfOffset(to_current(document, cmd.start(document)))
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   130
      val stop = text_area.getLineOfOffset(to_current(document, cmd.stop(document)) - 1)
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
   131
      text_area.invalidateLineRange(start, stop)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   132
34475
f963335dbc6b implemented IsabelleSideKickParser.complete
immler@in.tum.de
parents: 34458
diff changeset
   133
      if (Isabelle.prover_setup(buffer).get.selected_state == cmd)
f963335dbc6b implemented IsabelleSideKickParser.complete
immler@in.tum.de
parents: 34458
diff changeset
   134
        Isabelle.prover_setup(buffer).get.selected_state = cmd  // update State view
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   135
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   136
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   137
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   138
  def repaint_all()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   139
  {
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
   140
    if (text_area != null)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   141
      text_area.invalidateLineRange(text_area.getFirstPhysicalLine, text_area.getLastPhysicalLine)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   142
  }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   143
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   144
  def encolor(gfx: Graphics2D,
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   145
    y: Int, height: Int, begin: Int, finish: Int, color: Color, fill: Boolean)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   146
  {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   147
    val start = text_area.offsetToXY(begin)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   148
    val stop =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   149
      if (finish < buffer.getLength) text_area.offsetToXY(finish)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   150
      else {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   151
        val p = text_area.offsetToXY(finish - 1)
34515
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
   152
        val metrics = text_area.getPainter.getFontMetrics
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
   153
        p.x = p.x + (metrics.charWidth(' ') max metrics.getMaxAdvance)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   154
        p
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   155
      }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   156
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   157
    if (start != null && stop != null) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   158
      gfx.setColor(color)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   159
      if (fill) gfx.fillRect(start.x, y, stop.x - start.x, height)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   160
      else gfx.drawRect(start.x, y, stop.x - start.x, height)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   161
    }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   162
  }
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   163
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   164
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   165
  /* TextAreaExtension methods */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   166
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   167
  override def paintValidLine(gfx: Graphics2D,
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   168
    screen_line: Int, physical_line: Int, start: Int, end: Int, y: Int)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   169
  {
34650
d7ba607bf684 current version in theoryview/buffer
immler@in.tum.de
parents: 34649
diff changeset
   170
    val document = current_document()
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   171
    def from_current(pos: Int) = this.from_current(document, pos)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   172
    def to_current(pos: Int) = this.to_current(document, pos)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   173
    val saved_color = gfx.getColor
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   174
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   175
    val metrics = text_area.getPainter.getFontMetrics
34596
2b46d92e4642 linearset works faster here
immler@in.tum.de
parents: 34574
diff changeset
   176
2b46d92e4642 linearset works faster here
immler@in.tum.de
parents: 34574
diff changeset
   177
    // encolor phase
34545
b928628742ed implemented to_current and from_current in dependancy of document-versions
immler@in.tum.de
parents: 34544
diff changeset
   178
    var e = document.find_command_at(from_current(start))
34596
2b46d92e4642 linearset works faster here
immler@in.tum.de
parents: 34574
diff changeset
   179
    while (e != null && e.start(document) < end) {
34554
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34549
diff changeset
   180
      val begin = start max to_current(e.start(document))
7dc6c231da40 abs. stops, markup nodes depend on doc-version;
immler@in.tum.de
parents: 34549
diff changeset
   181
      val finish = end - 1 min to_current(e.stop(document))
34653
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
   182
      encolor(gfx, y, metrics.getHeight, begin, finish,
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
   183
        TheoryView.choose_color(e, document), true)
34596
2b46d92e4642 linearset works faster here
immler@in.tum.de
parents: 34574
diff changeset
   184
      e = document.commands.next(e).getOrElse(null)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   185
    }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   186
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   187
    gfx.setColor(saved_color)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   188
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   189
34562
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   190
  override def getToolTipText(x: Int, y: Int) = {
34650
d7ba607bf684 current version in theoryview/buffer
immler@in.tum.de
parents: 34649
diff changeset
   191
    val document = current_document()
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   192
    val offset = from_current(document, text_area.xyToOffset(x, y))
34562
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   193
    val cmd = document.find_command_at(offset)
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   194
    if (cmd != null) {
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   195
      document.token_start(cmd.tokens.first)
34653
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
   196
      cmd.type_at(document, offset - cmd.start(document))
34562
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   197
    } else null
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   198
  }
cdf914c78ff2 ML types in tooltip
immler@in.tum.de
parents: 34556
diff changeset
   199
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   200
  /* history of changes - TODO: seperate class?*/
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   201
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   202
  val change_0 = new Change(prover.document_0.id, None, Nil)
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   203
  private var changes = List(change_0)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   204
  private var current_change = change_0
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   205
  def get_changes = changes
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   206
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   207
  private def doc_or_pred(c: Change): ProofDocument =
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   208
    prover.document(c.id).getOrElse(doc_or_pred(c.parent.get))
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   209
  def current_document() = doc_or_pred(current_change)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   210
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   211
  /* update to desired version */
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   212
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   213
  def set_version(goal: Change) {
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   214
    // changes in buffer must be ignored
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   215
    buffer.removeBufferListener(this)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   216
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   217
    def apply(c: Change) = c.map {
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   218
      case Insert(start, added) => buffer.insert(start, added)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   219
      case Remove(start, removed) => buffer.remove(start, removed.length)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   220
    }
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   221
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   222
    def unapply(c: Change) = c.map {
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   223
      case Insert(start, added) => buffer.remove(start, added.length)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   224
      case Remove(start, removed) => buffer.insert(start, removed)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   225
    }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   226
34654
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   227
    // undo/redo changes
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   228
    val ancs_current = current_change.ancestors
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   229
    val ancs_goal = goal.ancestors
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   230
    val paired = ancs_current.reverse zip ancs_goal.reverse
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   231
    def last_common[A](xs: List[(A, A)]): Option[A] = {
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   232
      xs match {
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   233
        case (x, y) :: xs =>
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   234
          if (x == y)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   235
            xs match {
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   236
              case (a, b) :: ys =>
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   237
                if (a == b) last_common(xs)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   238
                else Some(x)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   239
              case _ => Some(x)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   240
            }
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   241
          else None
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   242
        case _ => None
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   243
      }
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   244
    }
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   245
    val common_anc = last_common(paired).get
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   246
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   247
    ancs_current.takeWhile(_ != common_anc) map unapply
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   248
    ancs_goal.takeWhile(_ != common_anc).reverse map apply
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   249
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   250
    current_change = goal
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   251
    // invoke repaint
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   252
    update_delay()
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   253
    repaint_delay()
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   254
    phase_overview.repaint_delay()
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   255
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   256
    //track changes in buffer
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   257
    buffer.addBufferListener(this)
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   258
  }
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   259
30f588245884 arbitrary history
immler@in.tum.de
parents: 34653
diff changeset
   260
  /* BufferListener methods */
34545
b928628742ed implemented to_current and from_current in dependancy of document-versions
immler@in.tum.de
parents: 34544
diff changeset
   261
34547
68a5e91ac3a3 fixed shifting;
immler@in.tum.de
parents: 34546
diff changeset
   262
  private def commit: Unit = synchronized {
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   263
    if (!edits.isEmpty) {
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   264
      val change = new Change(Isabelle.system.id(), Some(current_change), edits)
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   265
      changes ::= change
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   266
      document_actor ! change
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   267
      current_change = change
34545
b928628742ed implemented to_current and from_current in dependancy of document-versions
immler@in.tum.de
parents: 34544
diff changeset
   268
    }
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   269
    edits = Nil
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   270
    if (col_timer.isRunning())
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   271
      col_timer.stop()
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   272
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   273
34515
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
   274
  private def delay_commit {
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   275
    if (col_timer.isRunning())
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   276
      col_timer.restart()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   277
    else
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   278
      col_timer.start()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   279
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   280
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   281
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   282
  override def contentInserted(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   283
    start_line: Int, offset: Int, num_lines: Int, length: Int) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   284
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   285
  override def contentRemoved(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   286
    start_line: Int, offset: Int, num_lines: Int, length: Int) { }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   287
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   288
  override def preContentInserted(buffer: JEditBuffer,
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   289
    start_line: Int, offset: Int, num_lines: Int, length: Int)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   290
  {
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   291
    edits ::= Insert(offset, buffer.getText(offset, length))
34515
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
   292
    delay_commit
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   293
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   294
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   295
  override def preContentRemoved(buffer: JEditBuffer,
34648
8213a350fd45 remember removed text
immler@in.tum.de
parents: 34643
diff changeset
   296
    start_line: Int, start: Int, num_lines: Int, removed_length: Int)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   297
  {
34660
e0561943bfc9 Change consisting of a list of Edits
immler@in.tum.de
parents: 34654
diff changeset
   298
    edits ::= Remove(start, buffer.getText(start, removed_length))
34515
3be515f1379d use FontMetrics.getMaxAdvance if available; tuned
immler@in.tum.de
parents: 34514
diff changeset
   299
    delay_commit
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   300
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   301
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   302
  override def bufferLoaded(buffer: JEditBuffer) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   303
  override def foldHandlerChanged(buffer: JEditBuffer) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   304
  override def foldLevelChanged(buffer: JEditBuffer, start_line: Int, end_line: Int) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   305
  override def transactionComplete(buffer: JEditBuffer) { }
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   306
34447
wenzelm
parents: 34446
diff changeset
   307
}