src/Tools/jEdit/src/jedit/document_model.scala
author wenzelm
Thu, 11 Nov 2010 19:58:07 +0100
changeset 40481 da2c56aaaa68
parent 40478 4bae781b8f7c
child 40851 58d25beedcea
permissions -rw-r--r--
more precise treatment of deleted nodes;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
36760
b82a698ef6c9 tuned headers;
wenzelm
parents: 36015
diff changeset
     1
/*  Title:      Tools/jEdit/src/jedit/document_model.scala
b82a698ef6c9 tuned headers;
wenzelm
parents: 36015
diff changeset
     2
    Author:     Fabian Immler, TU Munich
b82a698ef6c9 tuned headers;
wenzelm
parents: 36015
diff changeset
     3
    Author:     Makarius
b82a698ef6c9 tuned headers;
wenzelm
parents: 36015
diff changeset
     4
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
     5
Document model connected to jEdit buffer -- single node in theory graph.
36760
b82a698ef6c9 tuned headers;
wenzelm
parents: 36015
diff changeset
     6
*/
34407
aad6834ba380 added some headers and comments;
wenzelm
parents: 34406
diff changeset
     7
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
     8
package isabelle.jedit
34760
dc7f5e0d9d27 misc modernization of names;
wenzelm
parents: 34759
diff changeset
     9
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    10
36015
6111de7c916a adapted to Scala 2.8.0 Beta 1;
wenzelm
parents: 34871
diff changeset
    11
import isabelle._
6111de7c916a adapted to Scala 2.8.0 Beta 1;
wenzelm
parents: 34871
diff changeset
    12
34693
3e995f100ad2 sealed Edit;
wenzelm
parents: 34685
diff changeset
    13
import scala.collection.mutable
34446
5c79f97ec1d1 superficial tuning;
wenzelm
parents: 34445
diff changeset
    14
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    15
import org.gjt.sp.jedit.Buffer
34783
cb95d6bbf5f1 clarified BufferListener: use adapter, listen to contentInserted instead of preContentInserted;
wenzelm
parents: 34778
diff changeset
    16
import org.gjt.sp.jedit.buffer.{BufferAdapter, BufferListener, JEditBuffer}
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    17
import org.gjt.sp.jedit.syntax.{SyntaxStyle, Token, TokenMarker, TokenHandler, ParserRuleSet}
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    18
import org.gjt.sp.jedit.textarea.TextArea
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    19
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    20
import java.awt.font.TextAttribute
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    21
import javax.swing.text.Segment;
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
    22
34760
dc7f5e0d9d27 misc modernization of names;
wenzelm
parents: 34759
diff changeset
    23
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    24
object Document_Model
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
    25
{
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    26
  object Token_Markup
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    27
  {
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    28
    /* extended token styles */
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    29
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    30
    private val plain_range: Int = Token.ID_COUNT
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    31
    private val full_range: Int = 3 * plain_range
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    32
    private def check_range(i: Int) { require(0 <= i && i < plain_range) }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    33
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    34
    def subscript(i: Byte): Byte = { check_range(i); (i + plain_range).toByte }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    35
    def superscript(i: Byte): Byte = { check_range(i); (i + 2 * plain_range).toByte }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    36
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    37
    private def script_style(style: SyntaxStyle, i: Int): SyntaxStyle =
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    38
    {
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    39
      import scala.collection.JavaConversions._
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    40
      val script_font =
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    41
        style.getFont.deriveFont(Map(TextAttribute.SUPERSCRIPT -> new java.lang.Integer(i)))
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    42
      new SyntaxStyle(style.getForegroundColor, style.getBackgroundColor, script_font)
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    43
    }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    44
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    45
    def extend_styles(styles: Array[SyntaxStyle]): Array[SyntaxStyle] =
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    46
    {
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    47
      val new_styles = new Array[SyntaxStyle](full_range)
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    48
      for (i <- 0 until plain_range) {
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    49
        val style = styles(i)
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    50
        new_styles(i) = style
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    51
        new_styles(subscript(i.toByte)) = script_style(style, -1)
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    52
        new_styles(superscript(i.toByte)) = script_style(style, 1)
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    53
      }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    54
      new_styles
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    55
    }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    56
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    57
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    58
    /* line context */
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    59
38852
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    60
    private val dummy_rules = new ParserRuleSet("isabelle", "MAIN")
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    61
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    62
    class Line_Context(val line: Int, prev: Line_Context)
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    63
      extends TokenMarker.LineContext(dummy_rules, prev)
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    64
    {
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    65
      override def hashCode: Int = line
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    66
      override def equals(that: Any) =
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    67
        that match {
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    68
          case other: Line_Context => line == other.line
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    69
          case _ => false
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    70
        }
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
    71
    }
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    72
  }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    73
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
    74
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    75
  /* document model of buffer */
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    76
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    77
  private val key = "isabelle.document_model"
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    78
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
    79
  def init(session: Session, buffer: Buffer, thy_name: String): Document_Model =
34716
b8f2b44529fd tuned color (PG 4.0);
wenzelm
parents: 34712
diff changeset
    80
  {
38223
2a368e8e0a80 more explicit treatment of Swing thread context;
wenzelm
parents: 38222
diff changeset
    81
    Swing_Thread.require()
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
    82
    val model = new Document_Model(session, buffer, thy_name)
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    83
    buffer.setProperty(key, model)
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    84
    model.activate()
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    85
    model
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    86
  }
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    87
34788
3779c54a2d21 direct apply for Document_Model and Document_View;
wenzelm
parents: 34784
diff changeset
    88
  def apply(buffer: Buffer): Option[Document_Model] =
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    89
  {
38223
2a368e8e0a80 more explicit treatment of Swing thread context;
wenzelm
parents: 38222
diff changeset
    90
    Swing_Thread.require()
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    91
    buffer.getProperty(key) match {
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    92
      case model: Document_Model => Some(model)
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    93
      case _ => None
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    94
    }
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    95
  }
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    96
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    97
  def exit(buffer: Buffer)
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
    98
  {
38223
2a368e8e0a80 more explicit treatment of Swing thread context;
wenzelm
parents: 38222
diff changeset
    99
    Swing_Thread.require()
34788
3779c54a2d21 direct apply for Document_Model and Document_View;
wenzelm
parents: 34784
diff changeset
   100
    apply(buffer) match {
39636
610dc743932c permissive exit;
wenzelm
parents: 39179
diff changeset
   101
      case None =>
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   102
      case Some(model) =>
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   103
        model.deactivate()
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   104
        buffer.unsetProperty(key)
34653
2e033aaf128e commands carrying state-information
immler@in.tum.de
parents: 34652
diff changeset
   105
    }
34318
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   106
  }
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   107
}
c13e168a8ae6 original sources from Johannes Hölzl a48e0c6ab1aea77c52d596f7efc007a543d3d10c with minor modifications of directory layout;
wenzelm
parents:
diff changeset
   108
38151
2837c952ca31 explicit Change.Snapshot and Document.Node;
wenzelm
parents: 38150
diff changeset
   109
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
   110
class Document_Model(val session: Session, val buffer: Buffer, val thy_name: String)
34588
e8ac8794971f superficial tuning;
wenzelm
parents: 34583
diff changeset
   111
{
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   112
  /* pending text edits */
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
   113
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   114
  object pending_edits  // owned by Swing thread
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   115
  {
38425
e467db701d78 moved Text_Edit to Text.Edit;
wenzelm
parents: 38417
diff changeset
   116
    private val pending = new mutable.ListBuffer[Text.Edit]
e467db701d78 moved Text_Edit to Text.Edit;
wenzelm
parents: 38417
diff changeset
   117
    def snapshot(): List[Text.Edit] = pending.toList
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   118
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   119
    def flush(more_edits: Option[List[Text.Edit]]*)
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   120
    {
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   121
      Swing_Thread.require()
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   122
      val edits = snapshot()
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   123
      pending.clear
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   124
40481
da2c56aaaa68 more precise treatment of deleted nodes;
wenzelm
parents: 40478
diff changeset
   125
      val all_edits =
da2c56aaaa68 more precise treatment of deleted nodes;
wenzelm
parents: 40478
diff changeset
   126
        if (edits.isEmpty) more_edits.toList
da2c56aaaa68 more precise treatment of deleted nodes;
wenzelm
parents: 40478
diff changeset
   127
        else Some(edits) :: more_edits.toList
da2c56aaaa68 more precise treatment of deleted nodes;
wenzelm
parents: 40478
diff changeset
   128
      if (!all_edits.isEmpty) session.edit_version(all_edits.map((thy_name, _)))
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   129
    }
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   130
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   131
    def init()
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   132
    {
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   133
      Swing_Thread.require()
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   134
      flush(None, Some(List(Text.Edit.insert(0, Isabelle.buffer_text(buffer)))))
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   135
    }
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   136
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   137
    private val delay_flush =
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   138
      Swing_Thread.delay_last(session.input_delay) { flush() }
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   139
38425
e467db701d78 moved Text_Edit to Text.Edit;
wenzelm
parents: 38417
diff changeset
   140
    def +=(edit: Text.Edit)
38224
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   141
    {
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   142
      Swing_Thread.require()
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   143
      pending += edit
809578d7f6af more explicit model of pending text edits;
wenzelm
parents: 38223
diff changeset
   144
      delay_flush()
38222
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
   145
    }
dac5fa0ac971 replaced individual Document_Model history by all-inclusive one in Session;
wenzelm
parents: 38158
diff changeset
   146
  }
38152
eab0d1c2e46e Change.Snapshot: include from_current/to_current here, with precomputed changes;
wenzelm
parents: 38151
diff changeset
   147
eab0d1c2e46e Change.Snapshot: include from_current/to_current here, with precomputed changes;
wenzelm
parents: 38151
diff changeset
   148
eab0d1c2e46e Change.Snapshot: include from_current/to_current here, with precomputed changes;
wenzelm
parents: 38151
diff changeset
   149
  /* snapshot */
34731
c0cb6bd10eec keep BufferListener and TextAreaExtension private;
wenzelm
parents: 34724
diff changeset
   150
38417
b8922ae21111 renamed class Document to Document.Version etc.;
wenzelm
parents: 38359
diff changeset
   151
  def snapshot(): Document.Snapshot =
b8922ae21111 renamed class Document to Document.Version etc.;
wenzelm
parents: 38359
diff changeset
   152
  {
38223
2a368e8e0a80 more explicit treatment of Swing thread context;
wenzelm
parents: 38222
diff changeset
   153
    Swing_Thread.require()
38359
96b22dfeb56a consider snapshot as service of Session, not Document.Change;
wenzelm
parents: 38356
diff changeset
   154
    session.snapshot(thy_name, pending_edits.snapshot())
38223
2a368e8e0a80 more explicit treatment of Swing thread context;
wenzelm
parents: 38222
diff changeset
   155
  }
34828
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   156
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   157
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   158
  /* buffer listener */
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   159
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   160
  private val buffer_listener: BufferListener = new BufferAdapter
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   161
  {
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   162
    override def bufferLoaded(buffer: JEditBuffer)
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   163
    {
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   164
      pending_edits.init()
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   165
    }
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   166
34828
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   167
    override def contentInserted(buffer: JEditBuffer,
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   168
      start_line: Int, offset: Int, num_lines: Int, length: Int)
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   169
    {
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   170
      if (!buffer.isLoading)
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   171
        pending_edits += Text.Edit.insert(offset, buffer.getText(offset, length))
34828
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   172
    }
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   173
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   174
    override def preContentRemoved(buffer: JEditBuffer,
38426
2858ec7b6dd8 specific types Text.Offset and Text.Range;
wenzelm
parents: 38425
diff changeset
   175
      start_line: Int, offset: Int, num_lines: Int, removed_length: Int)
34828
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   176
    {
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   177
      if (!buffer.isLoading)
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   178
        pending_edits += Text.Edit.remove(offset, buffer.getText(offset, removed_length))
34828
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   179
    }
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   180
  }
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   181
c2308b317244 misc tuning;
wenzelm
parents: 34827
diff changeset
   182
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   183
  /* semantic token marker */
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   184
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   185
  private val token_marker = new TokenMarker
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   186
  {
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   187
    override def markTokens(prev: TokenMarker.LineContext,
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   188
        handler: TokenHandler, line_segment: Segment): TokenMarker.LineContext =
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   189
    {
38843
d95522496593 more careful locking of jEdit buffer;
wenzelm
parents: 38641
diff changeset
   190
      Isabelle.swing_buffer_lock(buffer) {
d95522496593 more careful locking of jEdit buffer;
wenzelm
parents: 38641
diff changeset
   191
        val snapshot = Document_Model.this.snapshot()
38572
0fe2c01ef7da Command.State: accumulate markup reports uniformly;
wenzelm
parents: 38569
diff changeset
   192
38852
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
   193
        val previous = prev.asInstanceOf[Document_Model.Token_Markup.Line_Context]
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   194
        val line = if (prev == null) 0 else previous.line + 1
38852
23513fb32e7b Document_Mode.Line_Context: proper semantic equality/hash code avoids memory leak due to interning in org.gjt.sp.jedit.syntax.TokenMarker;
wenzelm
parents: 38846
diff changeset
   195
        val context = new Document_Model.Token_Markup.Line_Context(line, previous)
38572
0fe2c01ef7da Command.State: accumulate markup reports uniformly;
wenzelm
parents: 38569
diff changeset
   196
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   197
        val start = buffer.getLineStartOffset(line)
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   198
        val stop = start + line_segment.count
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   199
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   200
        /* FIXME
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   201
        for (text_area <- Isabelle.jedit_text_areas(buffer)
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   202
              if Document_View(text_area).isDefined)
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   203
          Document_View(text_area).get.set_styles()
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   204
        */
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   205
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   206
        def handle_token(style: Byte, offset: Text.Offset, length: Int) =
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   207
          handler.handleToken(line_segment, style, offset, length, context)
34680
1f1f6c95de64 clarified structure of TheoryView
immler@in.tum.de
parents: 34679
diff changeset
   208
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   209
        val syntax = session.current_syntax()
39179
591bbab9ef59 moved token markup tables to isabelle_markup.scala;
wenzelm
parents: 39178
diff changeset
   210
        val tokens = snapshot.select_markup(Text.Range(start, stop))(Isabelle_Markup.tokens(syntax))
38572
0fe2c01ef7da Command.State: accumulate markup reports uniformly;
wenzelm
parents: 38569
diff changeset
   211
38846
e54c33dbe77c Document_Model.token_marker: misc tuning and simplification;
wenzelm
parents: 38845
diff changeset
   212
        var last = start
39179
591bbab9ef59 moved token markup tables to isabelle_markup.scala;
wenzelm
parents: 39178
diff changeset
   213
        for (token <- tokens.iterator) {
38846
e54c33dbe77c Document_Model.token_marker: misc tuning and simplification;
wenzelm
parents: 38845
diff changeset
   214
          val Text.Range(token_start, token_stop) = token.range
e54c33dbe77c Document_Model.token_marker: misc tuning and simplification;
wenzelm
parents: 38845
diff changeset
   215
          if (last < token_start)
e54c33dbe77c Document_Model.token_marker: misc tuning and simplification;
wenzelm
parents: 38845
diff changeset
   216
            handle_token(Token.COMMENT1, last - start, token_start - last)
39177
0468964aec11 simplified Markup_Tree.select: Stream instead of Iterator (again), explicit Option instead of default;
wenzelm
parents: 38880
diff changeset
   217
          handle_token(token.info getOrElse Token.NULL,
0468964aec11 simplified Markup_Tree.select: Stream instead of Iterator (again), explicit Option instead of default;
wenzelm
parents: 38880
diff changeset
   218
            token_start - start, token_stop - token_start)
38846
e54c33dbe77c Document_Model.token_marker: misc tuning and simplification;
wenzelm
parents: 38845
diff changeset
   219
          last = token_stop
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   220
        }
39179
591bbab9ef59 moved token markup tables to isabelle_markup.scala;
wenzelm
parents: 39178
diff changeset
   221
        if (last < stop) handle_token(Token.COMMENT1, last - start, stop - last)
38641
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   222
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   223
        handle_token(Token.END, line_segment.count, 0)
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   224
        handler.setLineContext(context)
7ab0ae836f74 Document_Model.token_marker: lock jEdit buffer here, which is presumably a critical spot (the model is not necessarily accessed from the Swing thread);
wenzelm
parents: 38637
diff changeset
   225
        context
38572
0fe2c01ef7da Command.State: accumulate markup reports uniformly;
wenzelm
parents: 38569
diff changeset
   226
      }
38158
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   227
    }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   228
  }
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   229
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   230
8aaa21db41f3 Document_Model: include token marker here;
wenzelm
parents: 38152
diff changeset
   231
  /* activation */
37557
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   232
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   233
  def activate()
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   234
  {
37557
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   235
    buffer.setTokenMarker(token_marker)
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   236
    buffer.addBufferListener(buffer_listener)
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   237
    buffer.propertiesChanged()
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   238
    pending_edits.init()
34680
1f1f6c95de64 clarified structure of TheoryView
immler@in.tum.de
parents: 34679
diff changeset
   239
  }
1f1f6c95de64 clarified structure of TheoryView
immler@in.tum.de
parents: 34679
diff changeset
   240
37557
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   241
  def refresh()
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   242
  {
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   243
    buffer.setTokenMarker(token_marker)
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   244
  }
1ae272fd4082 refresh Isabelle token marker after buffer properties changed, e.g. when fold mode is switched;
wenzelm
parents: 37555
diff changeset
   245
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   246
  def deactivate()
34680
1f1f6c95de64 clarified structure of TheoryView
immler@in.tum.de
parents: 34679
diff changeset
   247
  {
40478
4bae781b8f7c replaced Document.Node_Text_Edit by Document.Text_Edit, with treatment of deleted nodes;
wenzelm
parents: 40474
diff changeset
   248
    pending_edits.flush()
34784
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   249
    buffer.setTokenMarker(buffer.getMode.getTokenMarker)
02959dcea756 split Theory_View into Document_Model (connected to Buffer) and Document_View (connected to JEditTextArea);
wenzelm
parents: 34783
diff changeset
   250
    buffer.removeBufferListener(buffer_listener)
34680
1f1f6c95de64 clarified structure of TheoryView
immler@in.tum.de
parents: 34679
diff changeset
   251
  }
34447
wenzelm
parents: 34446
diff changeset
   252
}