src/Pure/PIDE/editor.scala
author wenzelm
Wed, 21 Dec 2022 15:34:33 +0100
changeset 76732 0ba6f360d38a
parent 76725 c8d5cc19270a
child 76739 cb72b5996520
permissions -rw-r--r--
actually build document; clarified signature;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
52971
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/PIDE/editor.scala
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     3
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     4
General editor operations.
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     5
*/
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     6
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     7
package isabelle
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     8
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
     9
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73340
diff changeset
    10
abstract class Editor[Context] {
66082
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    11
  /* session */
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    12
52971
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
    13
  def session: Session
66084
7f8eeff20f7a tuned signature;
wenzelm
parents: 66082
diff changeset
    14
  def flush(): Unit
54461
6c360a6ade0e centralized management of pending buffer edits;
wenzelm
parents: 53844
diff changeset
    15
  def invoke(): Unit
66101
0f0f294e314f maintain overlays within main state of document models;
wenzelm
parents: 66094
diff changeset
    16
0f0f294e314f maintain overlays within main state of document models;
wenzelm
parents: 66094
diff changeset
    17
76609
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    18
  /* document editor */
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    19
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    20
  protected val document_editor: Synchronized[Document_Editor.State] =
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    21
    Synchronized(Document_Editor.State())
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    22
76715
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    23
  protected def document_state(): Document_Editor.State = document_editor.value
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    24
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    25
  protected def document_state_changed(): Unit = {}
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    26
  private def document_state_change(f: Document_Editor.State => Document_Editor.State): Unit = {
76705
ddf5764684dd proper state change, e.g. on open/close of "Document" panel;
wenzelm
parents: 76701
diff changeset
    27
    val changed =
ddf5764684dd proper state change, e.g. on open/close of "Document" panel;
wenzelm
parents: 76701
diff changeset
    28
      document_editor.change_result { st =>
ddf5764684dd proper state change, e.g. on open/close of "Document" panel;
wenzelm
parents: 76701
diff changeset
    29
        val st1 = f(st)
76725
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
    30
        val changed =
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
    31
          st.active_document_theories != st1.active_document_theories ||
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
    32
          st.required != st1.required
c8d5cc19270a more thorough GUI updates, notably for multiple Document dockables;
wenzelm
parents: 76720
diff changeset
    33
        (changed, st1)
76705
ddf5764684dd proper state change, e.g. on open/close of "Document" panel;
wenzelm
parents: 76701
diff changeset
    34
      }
76715
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    35
    if (changed) document_state_changed()
76705
ddf5764684dd proper state change, e.g. on open/close of "Document" panel;
wenzelm
parents: 76701
diff changeset
    36
  }
76715
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    37
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    38
  def document_session(): Option[Sessions.Background] = document_state().session_background
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    39
  def document_required(): List[Document.Node.Name] = document_state().required
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    40
  def document_node_required(name: Document.Node.Name): Boolean = document_state().is_required(name)
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    41
76716
a7602257a825 clarified state document nodes for Theories_Status / Document_Dockable;
wenzelm
parents: 76715
diff changeset
    42
  def document_theories(): List[Document.Node.Name] = document_state().active_document_theories
76732
0ba6f360d38a actually build document;
wenzelm
parents: 76725
diff changeset
    43
  def document_selection(): Set[Document.Node.Name] = document_state().selection
76716
a7602257a825 clarified state document nodes for Theories_Status / Document_Dockable;
wenzelm
parents: 76715
diff changeset
    44
76701
3543ecb4c97d tuned signature;
wenzelm
parents: 76678
diff changeset
    45
  def document_setup(background: Option[Sessions.Background]): Unit =
76715
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    46
    document_state_change(_.copy(session_background = background))
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    47
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    48
  def document_select(
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    49
    names: Iterable[Document.Node.Name],
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    50
    set: Boolean = false,
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    51
    toggle: Boolean = false
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    52
  ): Unit = document_state_change(_.select(names, set = set, toggle = toggle))
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    53
76720
37f7b2965e02 more GUI operations;
wenzelm
parents: 76716
diff changeset
    54
  def document_select_all(set: Boolean = false): Unit =
37f7b2965e02 more GUI operations;
wenzelm
parents: 76716
diff changeset
    55
    document_state_change(st => st.select(st.active_document_theories, set = set))
37f7b2965e02 more GUI operations;
wenzelm
parents: 76716
diff changeset
    56
76715
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    57
  def document_init(id: AnyRef): Unit = document_state_change(_.register_view(id))
bf5ff407f32f clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
wenzelm
parents: 76705
diff changeset
    58
  def document_exit(id: AnyRef): Unit = document_state_change(_.unregister_view(id))
76609
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    59
cc9ddf373bd2 maintain global state of document editor views, notably for is_active operation;
wenzelm
parents: 75393
diff changeset
    60
66101
0f0f294e314f maintain overlays within main state of document models;
wenzelm
parents: 66094
diff changeset
    61
  /* current situation */
0f0f294e314f maintain overlays within main state of document models;
wenzelm
parents: 66094
diff changeset
    62
52971
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
    63
  def current_node(context: Context): Option[Document.Node.Name]
52978
37fbb3fde380 prefer PIDE editor operations;
wenzelm
parents: 52977
diff changeset
    64
  def current_node_snapshot(context: Context): Option[Document.Snapshot]
52974
908e8a36e975 tuned signature;
wenzelm
parents: 52971
diff changeset
    65
  def node_snapshot(name: Document.Node.Name): Document.Snapshot
53844
71f103629327 skip ignored commands, similar to former proper_command_at (see d68ea01d5084) -- relevant to Output, Query_Operation etc.;
wenzelm
parents: 52980
diff changeset
    66
  def current_command(context: Context, snapshot: Document.Snapshot): Option[Command]
52977
15254e32d299 central management of Document.Overlays, independent of Document_Model;
wenzelm
parents: 52974
diff changeset
    67
66082
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    68
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    69
  /* overlays */
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    70
66101
0f0f294e314f maintain overlays within main state of document models;
wenzelm
parents: 66094
diff changeset
    71
  def node_overlays(name: Document.Node.Name): Document.Node.Overlays
73340
0ffcad1f6130 tuned --- fewer warnings;
wenzelm
parents: 66101
diff changeset
    72
  def insert_overlay(command: Command, fn: String, args: List[String]): Unit
0ffcad1f6130 tuned --- fewer warnings;
wenzelm
parents: 66101
diff changeset
    73
  def remove_overlay(command: Command, fn: String, args: List[String]): Unit
66082
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    74
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    75
2d12a730a380 clarified modules;
wenzelm
parents: 64867
diff changeset
    76
  /* hyperlinks */
52980
28f59ca8ce78 manage hyperlinks via PIDE editor interface;
wenzelm
parents: 52978
diff changeset
    77
75393
87ebf5a50283 clarified formatting, for the sake of scala3;
wenzelm
parents: 73340
diff changeset
    78
  abstract class Hyperlink {
64663
wenzelm
parents: 64524
diff changeset
    79
    def external: Boolean = false
56494
1b74abf064e1 avoid confusion about pointless cursor movement with external links;
wenzelm
parents: 55884
diff changeset
    80
    def follow(context: Context): Unit
1b74abf064e1 avoid confusion about pointless cursor movement with external links;
wenzelm
parents: 55884
diff changeset
    81
  }
66084
7f8eeff20f7a tuned signature;
wenzelm
parents: 66082
diff changeset
    82
52980
28f59ca8ce78 manage hyperlinks via PIDE editor interface;
wenzelm
parents: 52978
diff changeset
    83
  def hyperlink_command(
64664
wenzelm
parents: 64663
diff changeset
    84
    focus: Boolean, snapshot: Document.Snapshot, id: Document_ID.Generic, offset: Symbol.Offset = 0)
60893
3c8b9b4b577c support hyperlinks with optional focus change;
wenzelm
parents: 56494
diff changeset
    85
      : Option[Hyperlink]
66094
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    86
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    87
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    88
  /* dispatcher thread */
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    89
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    90
  def assert_dispatcher[A](body: => A): A
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    91
  def require_dispatcher[A](body: => A): A
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    92
  def send_dispatcher(body: => Unit): Unit
24658c9d7c78 more general dispatcher operations;
wenzelm
parents: 66084
diff changeset
    93
  def send_wait_dispatcher(body: => Unit): Unit
52971
31926d2c04ee tuned signature -- more abstract PIDE editor operations;
wenzelm
parents:
diff changeset
    94
}