src/Tools/jEdit/src/jedit/TheoryView.scala
author wenzelm
Mon, 29 Dec 2008 20:50:38 +0100
changeset 34457 19bd801975a3
parent 34456 14367c0715e8
child 34458 e2aa32bb73c0
permissions -rw-r--r--
tuned;
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
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    11
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    12
import isabelle.proofdocument.Text
34452
eea0eae5f773 removed redundant CommandChangeInfo;
wenzelm
parents: 34450
diff changeset
    13
import isabelle.prover.{Prover, Command}
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    14
import isabelle.prover.Command.Phase
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    15
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    16
import java.awt.Graphics2D
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    17
import java.awt.event.{ActionEvent, ActionListener}
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    18
import java.awt.Color
34447
wenzelm
parents: 34446
diff changeset
    19
import javax.swing.Timer
wenzelm
parents: 34446
diff changeset
    20
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
    21
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    22
import org.gjt.sp.jedit.buffer.{BufferListener, JEditBuffer}
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    23
import org.gjt.sp.jedit.textarea.{JEditTextArea, TextAreaExtension, TextAreaPainter}
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    24
import org.gjt.sp.jedit.syntax.SyntaxStyle
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    25
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    26
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    27
object TheoryView {
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    28
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    29
  def choose_color(state: Command): Color = {
34448
39cb4ed5183b command state color: use PG 4.0 values;
wenzelm
parents: 34447
diff changeset
    30
    if (state == null) Color.red
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    31
    else
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    32
      state.phase match {
34448
39cb4ed5183b command state color: use PG 4.0 values;
wenzelm
parents: 34447
diff changeset
    33
        case Phase.UNPROCESSED => new Color(255, 228, 225)
39cb4ed5183b command state color: use PG 4.0 values;
wenzelm
parents: 34447
diff changeset
    34
        case Phase.FINISHED => new Color(234, 248, 255)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    35
        case Phase.FAILED => new Color(255, 192, 192)
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    36
        case _ => Color.red
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    37
      }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    38
  }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
    39
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    40
  def choose_color(markup: String): Color = {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    41
    // TODO: as properties
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    42
    markup match {
34445
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    43
      // logical entities
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    44
      case Markup.TCLASS | Markup.TYCON | Markup.FIXED_DECL | Markup.FIXED | Markup.CONST_DECL
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    45
        | Markup.CONST | Markup.FACT_DECL | Markup.FACT | Markup.DYNAMIC_FACT
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    46
        | Markup.LOCAL_FACT_DECL | Markup.LOCAL_FACT => new Color(255, 0, 255)
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    47
      // inner syntax
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    48
      case Markup.TFREE | Markup.FREE => Color.blue
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    49
      case Markup.TVAR | Markup.SKOLEM | Markup.BOUND | Markup.VAR => Color.green
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    50
      case Markup.NUM | Markup.FLOAT | Markup.XNUM | Markup.XSTR | Markup.LITERAL
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    51
        | Markup.INNER_COMMENT => new Color(255, 128, 128)
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    52
      case Markup.SORT | Markup.TYP | Markup.TERM | Markup.PROP
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    53
        | Markup.ATTRIBUTE | Markup.METHOD => Color.yellow
34445
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    54
      // embedded source text
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    55
      case Markup.ML_SOURCE | Markup.DOC_SOURCE | Markup.ANTIQ | Markup.ML_ANTIQ
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    56
        | Markup.DOC_ANTIQ => new Color(0, 192, 0)
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    57
      // outer syntax
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    58
      case Markup.IDENT | Markup.COMMAND | Markup.KEYWORD => Color.blue
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    59
      case Markup.VERBATIM => Color.green
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    60
      case Markup.COMMENT => Color.gray
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    61
      case Markup.CONTROL => Color.white
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    62
      case Markup.MALFORMED => Color.red
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    63
      case Markup.STRING | Markup.ALTSTRING => Color.orange
61ffe9a35f1d use symbolic Markup elements instead of literal strings;
wenzelm
parents: 34440
diff changeset
    64
      // other
34399
5b8b89b7e597 interpretation of STATUS messages in one place, deleting inner syntax
immler@in.tum.de
parents: 34393
diff changeset
    65
      case _ => Color.white
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
    66
    }
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
    67
  }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    68
}
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    69
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    70
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    71
class TheoryView (text_area: JEditTextArea)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    72
    extends TextAreaExtension with Text with BufferListener {
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    73
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    74
  private val buffer = text_area.getBuffer
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    75
  buffer.addBufferListener(this)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    76
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    77
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    78
  private var col: Text.Changed = null
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    79
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    80
  private val col_timer = new Timer(300, new ActionListener() {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    81
    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
    82
  })
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    83
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    84
  col_timer.stop
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    85
  col_timer.setRepeats(true)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    86
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    87
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    88
  private val phase_overview = new PhaseOverviewPanel(Isabelle.prover(buffer))
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    89
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    90
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    91
  /* activation */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    92
34456
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
    93
  Isabelle.plugin.font_changed += (_ => update_font())
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    94
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    95
  private def update_font() = {
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
    96
    if (text_area != null) {
34440
561a6d19bd95 renamed object Plugin to Isabelle;
wenzelm
parents: 34434
diff changeset
    97
      if (Isabelle.plugin.font != null) {
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    98
        val painter = text_area.getPainter
34434
ba08fc74f98a renamed Plugin.plugin to Plugin.self;
wenzelm
parents: 34408
diff changeset
    99
        painter.setStyles(painter.getStyles.map(style =>
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   100
          new SyntaxStyle(style.getForegroundColor, style.getBackgroundColor, Isabelle.plugin.font)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   101
        ))
34440
561a6d19bd95 renamed object Plugin to Isabelle;
wenzelm
parents: 34434
diff changeset
   102
        painter.setFont(Isabelle.plugin.font)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   103
        repaint_all()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   104
      }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   105
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   106
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   107
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   108
  private val selected_state_controller = new CaretListener {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   109
    override def caretUpdate(e: CaretEvent) = {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   110
      val cmd = Isabelle.prover(buffer).document.getNextCommandContaining(e.getDot)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   111
      if (cmd != null && cmd.start <= e.getDot &&
34456
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   112
          Isabelle.prover_setup(buffer).selected_state != cmd)
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   113
        Isabelle.prover_setup(buffer).selected_state = cmd
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   114
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   115
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   116
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   117
  def activate() = {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   118
    text_area.addCaretListener(selected_state_controller)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   119
    phase_overview.textarea = text_area
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   120
    text_area.addLeftOfScrollBar(phase_overview)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   121
    text_area.getPainter.addExtension(TextAreaPainter.LINE_BACKGROUND_LAYER + 1, this)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   122
    update_font()
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   123
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   124
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   125
  def deactivate() = {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   126
    text_area.getPainter.removeExtension(this)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   127
    text_area.removeLeftOfScrollBar(phase_overview)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   128
    text_area.removeCaretListener(selected_state_controller)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   129
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   130
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   131
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   132
  /* painting */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   133
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   134
  val repaint_delay = new isabelle.utils.Delay(100, () => repaint_all())
34456
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   135
  Isabelle.prover(buffer).command_info += (_ => repaint_delay.delay_or_ignore())
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   136
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   137
  private def from_current(pos: Int) =
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   138
    if (col != null && col.start <= pos)
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   139
      if (pos < col.start + col.added) col.start
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   140
      else pos - col.added + col.removed
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   141
    else pos
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   142
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   143
  private def to_current(pos : Int) =
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   144
    if (col != null && col.start <= pos)
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   145
      if (pos < col.start + col.removed) col.start
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   146
      else pos + col.added - col.removed
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   147
    else pos
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   148
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   149
  def repaint(cmd: Command) =
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   150
  {
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   151
    val phase = cmd.phase
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   152
    if (text_area != null && phase != Phase.REMOVE && phase != Phase.REMOVED) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   153
      val start = text_area.getLineOfOffset(to_current(cmd.start))
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   154
      val stop = text_area.getLineOfOffset(to_current(cmd.stop) - 1)
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
   155
      text_area.invalidateLineRange(start, stop)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   156
34456
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   157
      if (Isabelle.prover_setup(buffer).selected_state == cmd)
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   158
        Isabelle.prover_setup(buffer).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
   159
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   160
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   161
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   162
  def repaint_all() =
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   163
  {
34406
f81cd75ae331 restructured: independent provers in different buffers
immler@in.tum.de
parents: 34405
diff changeset
   164
    if (text_area != null)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   165
      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
   166
  }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   167
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   168
  def encolor(gfx: Graphics2D,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   169
    y: Int, height: Int, begin: Int, finish: Int, color: Color, fill: Boolean) =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   170
  {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   171
    val start = text_area.offsetToXY(begin)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   172
    val stop =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   173
      if (finish < buffer.getLength) text_area.offsetToXY(finish)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   174
      else {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   175
        val p = text_area.offsetToXY(finish - 1)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   176
        p.x = p.x + text_area.getPainter.getFontMetrics.charWidth(' ')
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   177
        p
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   178
      }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   179
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   180
    if (start != null && stop != null) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   181
      gfx.setColor(color)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   182
      if (fill) gfx.fillRect(start.x, y, stop.x - start.x, height)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   183
      else gfx.drawRect(start.x, y, stop.x - start.x, height)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   184
    }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   185
  }
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
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   188
  /* TextAreaExtension methods */
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   189
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   190
  override def paintValidLine(gfx: Graphics2D,
34450
wenzelm
parents: 34448
diff changeset
   191
    screen_line: Int, physical_line: Int, start: Int, end: Int, y: Int) =
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   192
  {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   193
    val saved_color = gfx.getColor
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   194
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   195
    val metrics = text_area.getPainter.getFontMetrics
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   196
    var e = Isabelle.prover(buffer).document.getNextCommandContaining(from_current(start))
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   197
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   198
    // encolor phase
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   199
    while (e != null && to_current(e.start) < end) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   200
      val begin = start max to_current(e.start)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   201
      val finish = end - 1 min to_current(e.stop)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   202
      encolor(gfx, y, metrics.getHeight, begin, finish, TheoryView.choose_color(e), true)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   203
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   204
      // paint details of command
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   205
      for (node <- e.root_node.dfs) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   206
        val begin = to_current(node.start + e.start)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   207
        val finish = to_current(node.end + e.start)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   208
        if (finish > start && begin < end) {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   209
          encolor(gfx, y + metrics.getHeight - 4, 2, begin max start, finish min end,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   210
            TheoryView.choose_color(node.short), true)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   211
        }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   212
      }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   213
      e = e.next
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   214
    }
34391
7b5f44553aaf ugly fine-grained buffer markup
immler@in.tum.de
parents: 34387
diff changeset
   215
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   216
    gfx.setColor(saved_color)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   217
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   218
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   219
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   220
  /* Text methods */
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   221
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   222
  def content(start: Int, stop: Int) = buffer.getText(start, stop - start)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   223
  def length = buffer.getLength
34457
wenzelm
parents: 34456
diff changeset
   224
  val changes = new EventBus[Text.Changed]
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   225
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   226
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   227
  /* BufferListener methods */
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   228
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   229
  private def commit() {
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   230
    if (col != null)
34456
14367c0715e8 replaced EventSource by EventBus;
wenzelm
parents: 34452
diff changeset
   231
      changes.event(col)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   232
    col = null
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   233
    if (col_timer.isRunning())
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   234
      col_timer.stop()
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   235
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   236
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   237
  private def delay_commit() {
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   238
    if (col_timer.isRunning())
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   239
      col_timer.restart()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   240
    else
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   241
      col_timer.start()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   242
  }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   243
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   244
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   245
  override def contentInserted(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   246
    start_line: Int, offset: Int, num_lines: Int, length: Int) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   247
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   248
  override def contentRemoved(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   249
    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
   250
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   251
  override def preContentInserted(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   252
    start_line: Int, offset: Int, num_lines: Int, length: Int) =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   253
  {
34364
8df6519599ef playing with xsymbols
immler@in.tum.de
parents: 34318
diff changeset
   254
    if (col == null)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   255
      col = new Text.Changed(offset, length, 0)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   256
    else if (col.start <= offset && offset <= col.start + col.added)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   257
      col = new Text.Changed(col.start, col.added + length, col.removed)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   258
    else {
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   259
      commit()
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   260
      col = new Text.Changed(offset, length, 0)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   261
    }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   262
    delay_commit()
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   263
  }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   264
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   265
  override def preContentRemoved(buffer: JEditBuffer,
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   266
    start_line: Int, start: Int, num_lines: Int, removed: Int) =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   267
  {
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   268
    if (col == null)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   269
      col = new Text.Changed(start, 0, removed)
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   270
    else if (col.start > start + removed || start > col.start + col.added) {
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   271
      commit()
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   272
      col = new Text.Changed(start, 0, removed)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   273
    }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   274
    else {
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   275
      val offset = start - col.start
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   276
      val diff = col.added - removed
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   277
      val (added, add_removed) =
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   278
        if (diff < offset)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   279
          (offset max 0, diff - (offset max 0))
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   280
        else
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   281
          (diff - (offset min 0), offset min 0)
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   282
      col = new Text.Changed(start min col.start, added, col.removed - add_removed)
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   283
    }
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   284
    delay_commit()
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   285
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   286
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   287
  override def bufferLoaded(buffer: JEditBuffer) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   288
  override def foldHandlerChanged(buffer: JEditBuffer) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   289
  override def foldLevelChanged(buffer: JEditBuffer, start_line: Int, end_line: Int) { }
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
   290
  override def transactionComplete(buffer: JEditBuffer) { }
34447
wenzelm
parents: 34446
diff changeset
   291
}