| author | wenzelm | 
| Fri, 17 Jan 2025 19:46:36 +0100 | |
| changeset 81864 | 17831ae5224d | 
| parent 77197 | a541da01ba67 | 
| child 82925 | f4d263dc4442 | 
| permissions | -rw-r--r-- | 
| 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 | 10 | abstract class Editor[Context] {
 | 
| 76794 | 11 | /* PIDE session and document model */ | 
| 66082 | 12 | |
| 52971 
31926d2c04ee
tuned signature -- more abstract PIDE editor operations;
 wenzelm parents: diff
changeset | 13 | def session: Session | 
| 66084 | 14 | def flush(): Unit | 
| 54461 | 15 | def invoke(): Unit | 
| 66101 
0f0f294e314f
maintain overlays within main state of document models;
 wenzelm parents: 
66094diff
changeset | 16 | |
| 76794 | 17 | def get_models(): Iterable[Document.Model] | 
| 18 | ||
| 19 | ||
| 76609 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 20 | /* document editor */ | 
| 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 21 | |
| 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 22 | protected val document_editor: Synchronized[Document_Editor.State] = | 
| 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 23 | Synchronized(Document_Editor.State()) | 
| 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 24 | |
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 25 | 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: 
76705diff
changeset | 26 | |
| 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 27 |   protected def document_state_changed(): Unit = {}
 | 
| 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 28 |   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: 
76701diff
changeset | 29 | val changed = | 
| 
ddf5764684dd
proper state change, e.g. on open/close of "Document" panel;
 wenzelm parents: 
76701diff
changeset | 30 |       document_editor.change_result { st =>
 | 
| 
ddf5764684dd
proper state change, e.g. on open/close of "Document" panel;
 wenzelm parents: 
76701diff
changeset | 31 | val st1 = f(st) | 
| 76725 
c8d5cc19270a
more thorough GUI updates, notably for multiple Document dockables;
 wenzelm parents: 
76720diff
changeset | 32 | val changed = | 
| 
c8d5cc19270a
more thorough GUI updates, notably for multiple Document dockables;
 wenzelm parents: 
76720diff
changeset | 33 | st.active_document_theories != st1.active_document_theories || | 
| 76739 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 34 | st.selection != st1.selection | 
| 76725 
c8d5cc19270a
more thorough GUI updates, notably for multiple Document dockables;
 wenzelm parents: 
76720diff
changeset | 35 | (changed, st1) | 
| 76705 
ddf5764684dd
proper state change, e.g. on open/close of "Document" panel;
 wenzelm parents: 
76701diff
changeset | 36 | } | 
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 37 | if (changed) document_state_changed() | 
| 76705 
ddf5764684dd
proper state change, e.g. on open/close of "Document" panel;
 wenzelm parents: 
76701diff
changeset | 38 | } | 
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 39 | |
| 77144 
42c3970e1ac1
clarified Document_Editor.Session: more explicit types, more robust operations;
 wenzelm parents: 
77142diff
changeset | 40 | def document_session(): Document_Editor.Session = | 
| 77161 
913c781ff6ba
support document preparation from already loaded theories;
 wenzelm parents: 
77144diff
changeset | 41 | document_state().session(session) | 
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 42 | |
| 76739 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 43 |   def document_required(): List[Document.Node.Name] = {
 | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 44 | val st = document_state() | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 45 |     if (st.is_active) {
 | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 46 |       for {
 | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 47 | a <- st.all_document_theories | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 48 | b = session.resources.migrate_name(a) | 
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 49 | if st.selection(b.theory) | 
| 76739 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 50 | } yield b | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 51 | } | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 52 | else Nil | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 53 | } | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 54 | |
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 55 |   def document_node_required(name: Document.Node.Name): Boolean = {
 | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 56 | val st = document_state() | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 57 | st.is_active && | 
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 58 | st.selection.contains(name.theory) && | 
| 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 59 | st.all_document_theories.exists(a => a.theory == name.theory) | 
| 76739 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 60 | } | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 61 | |
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 62 | def document_theories(): List[Document.Node.Name] = | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 63 | document_state().active_document_theories.map(session.resources.migrate_name) | 
| 
cb72b5996520
proper migrate_name between different kinds of Resources, notably for Windows;
 wenzelm parents: 
76732diff
changeset | 64 | |
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 65 | def document_selection(): Set[String] = document_state().selection | 
| 76716 
a7602257a825
clarified state document nodes for Theories_Status / Document_Dockable;
 wenzelm parents: 
76715diff
changeset | 66 | |
| 76701 | 67 | 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: 
76705diff
changeset | 68 | document_state_change(_.copy(session_background = background)) | 
| 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 69 | |
| 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 70 | def document_select( | 
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 71 | theories: Iterable[String], | 
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 72 | set: Boolean = false, | 
| 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 73 | toggle: Boolean = false | 
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 74 | ): Unit = document_state_change(_.select(theories, set = set, toggle = toggle)) | 
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 75 | |
| 76720 | 76 | def document_select_all(set: Boolean = false): Unit = | 
| 77197 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 77 | document_state_change(st => | 
| 
a541da01ba67
clarified signature selection: SortedSet[String], which fits better to stored json and works properly on Windows (NB: document theories have an authentic session-theory name);
 wenzelm parents: 
77161diff
changeset | 78 | st.select(st.active_document_theories.map(_.theory), set = set)) | 
| 76720 | 79 | |
| 76715 
bf5ff407f32f
clarified state of document model vs. document editor selection (again, see also a9d52d02bd83);
 wenzelm parents: 
76705diff
changeset | 80 | 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: 
76705diff
changeset | 81 | 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: 
75393diff
changeset | 82 | |
| 
cc9ddf373bd2
maintain global state of document editor views, notably for is_active operation;
 wenzelm parents: 
75393diff
changeset | 83 | |
| 66101 
0f0f294e314f
maintain overlays within main state of document models;
 wenzelm parents: 
66094diff
changeset | 84 | /* current situation */ | 
| 
0f0f294e314f
maintain overlays within main state of document models;
 wenzelm parents: 
66094diff
changeset | 85 | |
| 52971 
31926d2c04ee
tuned signature -- more abstract PIDE editor operations;
 wenzelm parents: diff
changeset | 86 | def current_node(context: Context): Option[Document.Node.Name] | 
| 52978 | 87 | def current_node_snapshot(context: Context): Option[Document.Snapshot] | 
| 52974 | 88 | 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: 
52980diff
changeset | 89 | def current_command(context: Context, snapshot: Document.Snapshot): Option[Command] | 
| 52977 
15254e32d299
central management of Document.Overlays, independent of Document_Model;
 wenzelm parents: 
52974diff
changeset | 90 | |
| 66082 | 91 | |
| 92 | /* overlays */ | |
| 93 | ||
| 66101 
0f0f294e314f
maintain overlays within main state of document models;
 wenzelm parents: 
66094diff
changeset | 94 | def node_overlays(name: Document.Node.Name): Document.Node.Overlays | 
| 73340 | 95 | def insert_overlay(command: Command, fn: String, args: List[String]): Unit | 
| 96 | def remove_overlay(command: Command, fn: String, args: List[String]): Unit | |
| 66082 | 97 | |
| 98 | ||
| 99 | /* hyperlinks */ | |
| 52980 | 100 | |
| 75393 | 101 |   abstract class Hyperlink {
 | 
| 64663 | 102 | def external: Boolean = false | 
| 56494 
1b74abf064e1
avoid confusion about pointless cursor movement with external links;
 wenzelm parents: 
55884diff
changeset | 103 | def follow(context: Context): Unit | 
| 
1b74abf064e1
avoid confusion about pointless cursor movement with external links;
 wenzelm parents: 
55884diff
changeset | 104 | } | 
| 66084 | 105 | |
| 52980 | 106 | def hyperlink_command( | 
| 64664 | 107 | focus: Boolean, snapshot: Document.Snapshot, id: Document_ID.Generic, offset: Symbol.Offset = 0) | 
| 60893 | 108 | : Option[Hyperlink] | 
| 66094 | 109 | |
| 110 | ||
| 111 | /* dispatcher thread */ | |
| 112 | ||
| 113 | def assert_dispatcher[A](body: => A): A | |
| 114 | def require_dispatcher[A](body: => A): A | |
| 115 | def send_dispatcher(body: => Unit): Unit | |
| 116 | def send_wait_dispatcher(body: => Unit): Unit | |
| 52971 
31926d2c04ee
tuned signature -- more abstract PIDE editor operations;
 wenzelm parents: diff
changeset | 117 | } |