merged
authorwenzelm
Thu, 09 May 2019 16:48:25 +0200
changeset 70259 42f73412fa06
parent 70250 20d819b0a29d (current diff)
parent 70258 b4534d72dd22 (diff)
child 70260 22cfcfcadd8b
merged
--- a/NEWS	Thu May 09 12:32:47 2019 +0200
+++ b/NEWS	Thu May 09 16:48:25 2019 +0200
@@ -111,6 +111,12 @@
 might be *worse* than Oracle Java 8, though -- a proper HiDPI / UHD
 display is recommended.
 
+* OpenJDK 11 supports GTK version 2.2 and 3 (according to system
+property jdk.gtk.version). The factory default is version 3, but
+ISABELLE_JAVA_SYSTEM_OPTIONS includes "-Djdk.gtk.version=2.2" to make
+this more conservative (as in Java 8). Depending on the GTK theme
+configuration, "-Djdk.gtk.version=3" might work better or worse.
+
 
 *** Document preparation ***
 
--- a/src/Doc/JEdit/JEdit.thy	Thu May 09 12:32:47 2019 +0200
+++ b/src/Doc/JEdit/JEdit.thy	Thu May 09 16:48:25 2019 +0200
@@ -14,8 +14,9 @@
   interaction\<close> @{cite "Wenzel:2010" and "Wenzel:2012:UITP-EPTCS" and
   "Wenzel:2014:ITP-PIDE" and "Wenzel:2014:UITP"}, based on a document-oriented
   approach to \<^emph>\<open>continuous proof processing\<close> @{cite "Wenzel:2011:CICM" and
-  "Wenzel:2012"}. Many concepts and system components are fit together in
-  order to make this work. The main building blocks are as follows.
+  "Wenzel:2012" and "Wenzel:2018:FIDE" and "Wenzel:2019:MKM"}. Many concepts
+  and system components are fit together in order to make this work. The main
+  building blocks are as follows.
 
     \<^descr>[Isabelle/ML] is the implementation and extension language of Isabelle,
     see also @{cite "isabelle-implementation"}. It is integrated into the
@@ -38,9 +39,10 @@
     rich formal markup for GUI rendering.
 
     \<^descr>[jEdit] is a sophisticated text editor\<^footnote>\<open>\<^url>\<open>http://www.jedit.org\<close>\<close>
-    implemented in Java\<^footnote>\<open>\<^url>\<open>https://www.java.com\<close>\<close>. It is easily extensible by
-    plugins written in any language that works on the JVM. In the context of
-    Isabelle this is always Scala\<^footnote>\<open>\<^url>\<open>https://www.scala-lang.org\<close>\<close>.
+    implemented in Java\<^footnote>\<open>\<^url>\<open>https://adoptopenjdk.net\<close>\<close>. It is easily
+    extensible by plugins written in any language that works on the JVM. In
+    the context of Isabelle this is always
+    Scala\<^footnote>\<open>\<^url>\<open>https://www.scala-lang.org\<close>\<close>.
 
     \<^descr>[Isabelle/jEdit] is the main application of the PIDE framework and the
     default user-interface for Isabelle. It targets both beginners and
@@ -64,7 +66,7 @@
 text \<open>
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.3]{isabelle-jedit}
+  \includegraphics[width=\textwidth]{isabelle-jedit}
   \end{center}
   \caption{The Isabelle/jEdit Prover IDE}
   \label{fig:isabelle-jedit}
@@ -85,17 +87,15 @@
   the running text editor. Prover IDE functionality is fully activated after
   successful termination of the build process. A failure may require changing
   some options and restart of the Isabelle plugin or application. Changing the
-  logic session, or the underlying ML system platform (32\,bit versus 64\,bit)
-  requires a restart of the whole application to take effect.
-
-  \<^medskip>
-  The main job of the Prover IDE is to manage sources and their changes,
+  logic session requires a restart of the whole application to take effect.
+
+  \<^medskip> The main job of the Prover IDE is to manage sources and their changes,
   taking the logical structure as a formal document into account (see also
   \secref{sec:document-model}). The editor and the prover are connected
-  asynchronously in a lock-free manner. The prover is free to organize the
-  checking of the formal text in parallel on multiple cores, and provides
-  feedback via markup, which is rendered in the editor via colors, boxes,
-  squiggly underlines, hyperlinks, popup windows, icons, clickable output etc.
+  asynchronously without locking. The prover is free to organize the checking
+  of the formal text in parallel on multiple cores, and provides feedback via
+  markup, which is rendered in the editor via colors, boxes, squiggly
+  underlines, hyperlinks, popup windows, icons, clickable output etc.
 
   Using the mouse together with the modifier key \<^verbatim>\<open>CONTROL\<close> (Linux, Windows)
   or \<^verbatim>\<open>COMMAND\<close> (Mac OS X) exposes formal content via tooltips and/or
@@ -140,7 +140,7 @@
   to update bundled plugins or to add further functionality. This needs to be
   done with the usual care for such an open bazaar of contributions. Arbitrary
   combinations of add-on features are apt to cause problems. It is advisable
-  to start with the default configuration of Isabelle/jEdit and develop some
+  to start with the default configuration of Isabelle/jEdit and develop a
   sense how it is meant to work, before loading too many other plugins.
 
   \<^medskip>
@@ -192,7 +192,7 @@
   Options are usually loaded on startup and saved on shutdown of
   Isabelle/jEdit. Editing the generated \<^path>\<open>$JEDIT_SETTINGS/properties\<close>
   or \<^path>\<open>$ISABELLE_HOME_USER/etc/preferences\<close> manually while the
-  application is running may cause surprise due to lost updates!
+  application is running may cause lost updates!
 \<close>
 
 
@@ -205,13 +205,13 @@
   first start of the editor; afterwards the keymap file takes precedence and
   is no longer affected by change of default properties.
 
-  Users may change their keymap later, but this may lead to conflicts with
+  Users may modify their keymap later, but this can lead to conflicts with
   \<^verbatim>\<open>shortcut\<close> properties in \<^file>\<open>$JEDIT_HOME/src/jEdit.props\<close>.
 
   The action @{action_def "isabelle.keymap-merge"} helps to resolve pending
-  Isabelle keymap changes that are in conflict with the current jEdit keymap;
-  while non-conflicting changes are applied implicitly. This action is
-  automatically invoked on Isabelle/jEdit startup.
+  Isabelle keymap changes wrt. the current jEdit keymap; non-conflicting
+  changes are applied implicitly. This action is automatically invoked on
+  Isabelle/jEdit startup.
 \<close>
 
 
@@ -280,7 +280,7 @@
   The \<^verbatim>\<open>-J\<close> and \<^verbatim>\<open>-j\<close> options pass additional low-level options to the JVM or
   jEdit, respectively. The defaults are provided by the Isabelle settings
   environment @{cite "isabelle-system"}, but note that these only work for the
-  command-line tool described here, and not the regular application.
+  command-line tool described here, and not the desktop application.
 
   The \<^verbatim>\<open>-D\<close> option allows to define JVM system properties; this is passed
   directly to the underlying \<^verbatim>\<open>java\<close> process.
@@ -305,11 +305,11 @@
   Connect to already running Isabelle/jEdit instance and open FILES\<close>}
 
   The \<^verbatim>\<open>-c\<close> option merely checks the presence of the server, producing a
-  process return code accordingly.
+  process return-code.
 
   The \<^verbatim>\<open>-n\<close> option reports the server name, and the \<^verbatim>\<open>-s\<close> option provides a
   different server name. The default server name is the official distribution
-  name (e.g.\ \<^verbatim>\<open>Isabelle2018\<close>). Thus @{tool jedit_client} can connect to the
+  name (e.g.\ \<^verbatim>\<open>Isabelle2019\<close>). Thus @{tool jedit_client} can connect to the
   Isabelle desktop application without further options.
 
   The \<^verbatim>\<open>-p\<close> option allows to override the implicit default of the system
@@ -328,17 +328,16 @@
 
 text \<open>
   jEdit is a Java/AWT/Swing application with the ambition to support
-  ``native'' look-and-feel on all platforms, within the limits of what Oracle
-  as Java provider and major operating system distributors allow (see also
-  \secref{sec:problems}).
+  ``native'' look-and-feel on all platforms, within the limits of what Java
+  provider and major operating systems allow (see also \secref{sec:problems}).
 
   Isabelle/jEdit enables platform-specific look-and-feel by default as
   follows.
 
     \<^descr>[Linux:] The platform-independent \<^emph>\<open>Metal\<close> is used by default.
 
-    The Linux-specific \<^emph>\<open>GTK+\<close> often works as well, but the overall GTK theme
-    and options need to be selected to suite Java/AWT/Swing. Note that Java
+    The Linux-specific \<^emph>\<open>GTK+\<close> often works, but the overall GTK theme and
+    options need to be selected to suite Java/AWT/Swing. Note that the Java
     Virtual Machine has no direct influence of GTK rendering.
 
     \<^descr>[Windows:] Regular \<^emph>\<open>Windows\<close> is used by default.
@@ -358,32 +357,31 @@
   historic \<^emph>\<open>CDE/Motif\<close> should be ignored.
 
   Changing the look-and-feel in \<^emph>\<open>Global Options~/ Appearance\<close> may update the
-  GUI only partially: proper restart of Isabelle/jEdit is usually required.
+  GUI only partially: a proper restart of Isabelle/jEdit is usually required.
 \<close>
 
 
-subsection \<open>Displays with very high resolution \label{sec:hdpi}\<close>
+subsection \<open>Displays with high resolution \label{sec:hdpi}\<close>
 
 text \<open>
-  In distant past, displays with $1024 \times 768$ or $1280 \times 1024$
-  pixels were considered ``high resolution'' and bitmap fonts with 12 or 14
-  pixels as adequate for text rendering. After 2016, we have routinely seen
-  much higher resolutions, e.g. ``Full HD'' at $1920 \times 1080$ pixels or
-  ``Ultra HD'' / ``4K'' at $3840 \times 2160$.
-
-  GUI frameworks are usually lagging behind, with hard-wired icon sizes and
-  tiny fonts. Java and jEdit do provide reasonable support for very high
-  resolution, but this requires manual adjustments as described below.
-
-  \<^medskip>
-  The \<^bold>\<open>operating-system\<close> usually provides some configuration for global
-  scaling of text fonts, e.g.\ $120\%$--$250\%$ on Windows. This impacts
-  regular GUI elements, when used with native look-and-feel: Linux \<^emph>\<open>GTK+\<close>,
-  \<^emph>\<open>Windows\<close>, \<^emph>\<open>Mac OS X\<close>, respectively. Alternatively, it is possible to use
-  the platform-independent \<^emph>\<open>Metal\<close> look-and-feel and readjust its main font
-  sizes via jEdit options explained below. The Isabelle/jEdit \<^bold>\<open>application\<close>
-  provides further options to adjust font sizes in particular GUI elements.
-  Here is a summary of all relevant font properties:
+  In 2019, we usually see displays with high resolution like ``Ultra HD'' /
+  ``4K'' at $3840 \times 2160$, or more. Old ``Full HD'' displays at $1920
+  \times 1080$ pixels are still being used, but Java 11 font-rendering might
+  look bad on it (see \secref{sec:problems}) --- this is a good opportunity to
+  upgrade to current 4K or 5K technology. GUI layouts are lagging behind the
+  high resolution trends, and implicitly assume very old-fashioned $1024
+  \times 768$ or $1280 \times 1024$ screens and fonts with 12 or 14 pixels.
+  Java and jEdit do provide reasonable support for high resolution, but this
+  requires manual adjustments as described below.
+
+  \<^medskip> The \<^bold>\<open>operating-system\<close> often provides some configuration for global
+  scaling of text fonts, e.g.\ to enlarge it uniformly by $200\%$. This
+  impacts regular GUI elements, when used with native look-and-feel: Linux
+  \<^emph>\<open>GTK+\<close>, \<^emph>\<open>Windows\<close>, \<^emph>\<open>Mac OS X\<close>, respectively. Alternatively, it is
+  possible to use the platform-independent \<^emph>\<open>Metal\<close> look-and-feel and change
+  its main font sizes via jEdit options explained below. The Isabelle/jEdit
+  \<^bold>\<open>application\<close> provides further options to adjust font sizes in particular
+  GUI elements. Here is a summary of all relevant font properties:
 
     \<^item> \<^emph>\<open>Global Options / Text Area / Text font\<close>: the main text area font,
     which is also used as reference point for various derived font sizes,
@@ -406,15 +404,15 @@
     e.g.\ relevant for Isabelle/Scala command-line.
 
   In \figref{fig:isabelle-jedit-hdpi} the \<^emph>\<open>Metal\<close> look-and-feel is configured
-  with custom fonts at 30 pixels, and the main text area and console at 36
-  pixels. This leads to decent rendering quality, despite the old-fashioned
-  appearance of \<^emph>\<open>Metal\<close>.
+  with custom fonts at 36 pixels, and the main text area and console at 40
+  pixels. This leads to fairly good rendering quality, despite the
+  old-fashioned appearance of \<^emph>\<open>Metal\<close>.
 
   \begin{sidewaysfigure}[!htb]
   \begin{center}
   \includegraphics[width=\textwidth]{isabelle-jedit-hdpi}
   \end{center}
-  \caption{Metal look-and-feel with custom fonts for very high resolution}
+  \caption{Metal look-and-feel with custom fonts for high resolution}
   \label{fig:isabelle-jedit-hdpi}
   \end{sidewaysfigure}
 \<close>
@@ -478,7 +476,7 @@
   Isabelle sources consist of \<^emph>\<open>symbols\<close> that extend plain ASCII to allow
   infinitely many mathematical symbols within the formal sources. This works
   without depending on particular encodings and varying Unicode
-  standards.\<^footnote>\<open>Raw Unicode characters within formal sources would compromise
+  standards.\<^footnote>\<open>Raw Unicode characters within formal sources compromise
   portability and reliability in the face of changing interpretation of
   special features of Unicode, such as Combining Characters or Bi-directional
   Text.\<close> See @{cite "Wenzel:2011:CICM"}.
@@ -486,10 +484,10 @@
   For the prover back-end, formal text consists of ASCII characters that are
   grouped according to some simple rules, e.g.\ as plain ``\<^verbatim>\<open>a\<close>'' or symbolic
   ``\<^verbatim>\<open>\<alpha>\<close>''. For the editor front-end, a certain subset of symbols is rendered
-  physically via Unicode glyphs, in order to show ``\<^verbatim>\<open>\<alpha>\<close>'' as ``\<open>\<alpha>\<close>'', for
-  example. This symbol interpretation is specified by the Isabelle system
-  distribution in \<^file>\<open>$ISABELLE_HOME/etc/symbols\<close> and may be augmented by the
-  user in \<^path>\<open>$ISABELLE_HOME_USER/etc/symbols\<close>.
+  physically via Unicode glyphs, to show ``\<^verbatim>\<open>\<alpha>\<close>'' as ``\<open>\<alpha>\<close>'', for example.
+  This symbol interpretation is specified by the Isabelle system distribution
+  in \<^file>\<open>$ISABELLE_HOME/etc/symbols\<close> and may be augmented by the user in
+  \<^path>\<open>$ISABELLE_HOME_USER/etc/symbols\<close>.
 
   The appendix of @{cite "isabelle-isar-ref"} gives an overview of the
   standard interpretation of finitely many symbols from the infinite
@@ -519,17 +517,18 @@
   with the Isabelle symbol encoding, the fallback-encoding UTF-8 is used and
   Isabelle symbols remain in literal \<^verbatim>\<open>\<symbol>\<close> form. The jEdit menu
   operation \<^emph>\<open>Utilities~/ Buffer Options~/ Character encoding\<close> allows to
-  enforce the UTF-8-Isabelle, but this will also change original Unicode
-  text into Isabelle symbols when saving the file!
+  enforce \<^verbatim>\<open>UTF-8-Isabelle\<close>, but this will also change original Unicode text
+  into Isabelle symbols when saving the file!
 \<close>
 
 paragraph \<open>Font.\<close>
 text \<open>Correct rendering via Unicode requires a font that contains glyphs for
   the corresponding codepoints. There are also various unusual symbols with
   particular purpose in Isabelle, e.g.\ control symbols and very long arrows.
-  Isabelle/jEdit prefers its own font collection \<^verbatim>\<open>Isabelle DejaVu\<close>, which
-  ensures that all standard Isabelle symbols are shown on the screen (or
-  printer) as expected.
+  Isabelle/jEdit prefers its own font collection \<^verbatim>\<open>Isabelle DejaVu\<close>, with
+  families \<^verbatim>\<open>Serif\<close> (default for help texts), \<^verbatim>\<open>Sans\<close> (default for GUI
+  elements), \<^verbatim>\<open>Mono Sans\<close> (default for text area). This ensures that all
+  standard Isabelle symbols are shown on the screen (or printer) as expected.
 
   Note that a Java/AWT/Swing application can load additional fonts only if
   they are not installed on the operating system already! Outdated versions of
@@ -537,7 +536,7 @@
   Isabelle/jEdit to use its bundled version. This could lead to missing glyphs
   (black rectangles), when the system version of a font is older than the
   application version. This problem can be avoided by refraining to
-  ``install'' any version of \<^verbatim>\<open>IsabelleText\<close> in the first place, although it
+  ``install'' a copy of the Isabelle fonts in the first place, although it
   might be tempting to use the same font in other applications.
 
   HTML pages generated by Isabelle refer to the same Isabelle fonts as a
@@ -562,11 +561,10 @@
   representation with some additional information about \<^emph>\<open>symbol
   abbreviations\<close> (see below).
 
-  \<^enum> Copy/paste from decoded source files: text that is rendered as Unicode
-  already can be re-used to produce further text. This also works between
-  different applications, e.g.\ Isabelle/jEdit and some web browser or mail
-  client, as long as the same Unicode interpretation of Isabelle symbols is
-  used.
+  \<^enum> Copy/paste from decoded source files: text that is already rendered as
+  Unicode can be re-used for other text. This also works between different
+  applications, e.g.\ Isabelle/jEdit and some web browser or mail client, as
+  long as the same Unicode interpretation of Isabelle symbols is used.
 
   \<^enum> Copy/paste from prover output within Isabelle/jEdit. The same principles
   as for text buffers apply, but note that \<^emph>\<open>copy\<close> in secondary Isabelle/jEdit
@@ -658,7 +656,8 @@
   For example, \<^verbatim>\<open>PIDE\<close> refers to the Isabelle/jEdit plugin object, and \<^verbatim>\<open>view\<close>
   to the current editor view of jEdit. The Scala expression
   \<^verbatim>\<open>PIDE.snapshot(view)\<close> makes a PIDE document snapshot of the current buffer
-  within the current editor view.
+  within the current editor view: it allows to retrieve document markup in a
+  timeless~/ stateless manner, while the prover continues its processing.
 
   This helps to explore Isabelle/Scala functionality interactively. Some care
   is required to avoid interference with the internals of the running
@@ -666,54 +665,57 @@
 \<close>
 
 
-section \<open>File-system access\<close>
+section \<open>Physical and logical files \label{sec:files}\<close>
 
 text \<open>
   File specifications in jEdit follow various formats and conventions
-  according to \<^emph>\<open>Virtual File Systems\<close>, which may be also provided by
-  additional plugins. This allows to access remote files via the \<^verbatim>\<open>http:\<close>
-  protocol prefix, for example. Isabelle/jEdit attempts to work with the
-  file-system model of jEdit as far as possible. In particular, theory sources
-  are passed directly from the editor to the prover, without indirection via
-  physical files.
-
-  Despite the flexibility of URLs in jEdit, local files are particularly
-  important and are accessible without protocol prefix. The file path notation
-  is that of the Java Virtual Machine on the underlying platform. On Windows
-  the preferred form uses backslashes, but happens to accept forward slashes
-  like Unix/POSIX as well. Further differences arise due to Windows drive
-  letters and network shares.
-
-  The Java notation for files needs to be distinguished from the one of
-  Isabelle, which uses POSIX notation with forward slashes on \<^emph>\<open>all\<close>
-  platforms. Isabelle/ML on Windows uses Unix-style path notation, too, and
-  driver letter representation as in Cygwin (e.g.\ \<^verbatim>\<open>/cygdrive/c\<close>). Moreover,
-  environment variables from the Isabelle process may be used freely, e.g.\
-  \<^file>\<open>$ISABELLE_HOME/etc/symbols\<close> or \<^file>\<open>$POLYML_HOME/README\<close>. There are special
-  shortcuts: \<^dir>\<open>~\<close> for \<^dir>\<open>$USER_HOME\<close> and \<^dir>\<open>~~\<close> for \<^dir>\<open>$ISABELLE_HOME\<close>.
-
-  \<^medskip>
-  Since jEdit happens to support environment variables within file
+  according to \<^emph>\<open>Virtual File Systems\<close>, which may be also provided by plugins.
+  This allows to access remote files via the \<^verbatim>\<open>https:\<close> protocol prefix, for
+  example. Isabelle/jEdit attempts to work with the file-system model of jEdit
+  as far as possible. In particular, theory sources are passed from the editor
+  to the prover, without indirection via the file-system. Thus files don't
+  need to be saved: the editor buffer content is used directly.
+\<close>
+
+
+subsection \<open>Local files and environment variables \label{sec:local-files}\<close>
+
+text \<open>
+  Local files (without URL notation) are particularly important. The file path
+  notation is that of the Java Virtual Machine on the underlying platform. On
+  Windows the preferred form uses backslashes, but happens to accept forward
+  slashes like Unix/POSIX as well. Further differences arise due to Windows
+  drive letters and network shares: thus relative paths (with forward slashes)
+  are portable, but absolute paths are not.
+
+  File paths in Java are distinct from Isabelle; the latter uses POSIX
+  notation with forward slashes on \<^emph>\<open>all\<close> platforms. Isabelle/ML on Windows
+  uses Unix-style path notation, with drive letters according to Cygwin (e.g.\
+  \<^verbatim>\<open>/cygdrive/c\<close>). Environment variables from the Isabelle process may be used
+  freely, e.g.\ \<^file>\<open>$ISABELLE_HOME/etc/symbols\<close> or \<^file>\<open>$POLYML_HOME/README\<close>.
+  There are special shortcuts: \<^dir>\<open>~\<close> for \<^dir>\<open>$USER_HOME\<close> and \<^dir>\<open>~~\<close> for
+  \<^dir>\<open>$ISABELLE_HOME\<close>.
+
+  \<^medskip> Since jEdit happens to support environment variables within file
   specifications as well, it is natural to use similar notation within the
   editor, e.g.\ in the file-browser. This does not work in full generality,
   though, due to the bias of jEdit towards platform-specific notation and of
   Isabelle towards POSIX. Moreover, the Isabelle settings environment is not
-  yet active when starting Isabelle/jEdit via its standard application
-  wrapper, in contrast to @{tool jedit} run from the command line
+  accessible when starting Isabelle/jEdit via the desktop application wrapper,
+  in contrast to @{tool jedit} run from the command line
   (\secref{sec:command-line}).
 
   Isabelle/jEdit imitates important system settings within the Java process
   environment, in order to allow easy access to these important places from
   the editor: \<^verbatim>\<open>$ISABELLE_HOME\<close>, \<^verbatim>\<open>$ISABELLE_HOME_USER\<close>, \<^verbatim>\<open>$JEDIT_HOME\<close>,
   \<^verbatim>\<open>$JEDIT_SETTINGS\<close>. The file browser of jEdit also includes \<^emph>\<open>Favorites\<close> for
-  these two important locations.
-
-  \<^medskip>
-  Path specifications in prover input or output usually include formal markup
-  that turns it into a hyperlink (see also \secref{sec:tooltips-hyperlinks}).
-  This allows to open the corresponding file in the text editor, independently
-  of the path notation. If the path refers to a directory, the jEdit file
-  browser is opened on it.
+  these locations.
+
+  \<^medskip> Path specifications in prover input or output usually include formal
+  markup that turns it into a hyperlink (see also
+  \secref{sec:tooltips-hyperlinks}). This allows to open the corresponding
+  file in the text editor, independently of the path notation. If the path
+  refers to a directory, it is opened in the jEdit file browser.
 
   Formally checked paths in prover input are subject to completion
   (\secref{sec:completion}): partial specifications are resolved via directory
@@ -721,12 +723,44 @@
 \<close>
 
 
+subsection \<open>PIDE resources via virtual file-systems\<close>
+
+text \<open>
+  The jEdit file browser is docked by default, e.g. see
+  \figref{fig:isabelle-jedit-hdpi} (left docking area). It provides immediate
+  access to the local file-system, as well as important Isabelle resources via
+  the \<^emph>\<open>Favorites\<close> menu. Environment variables like \<^verbatim>\<open>$ISABELLE_HOME\<close> are
+  discussed in \secref{sec:local-files}. Virtual file-systems are more
+  special: the idea is to present structured information like a directory
+  tree. The following URLs are offered in the \<^emph>\<open>Favorites\<close> menu, or by
+  corresponding jEdit actions.
+
+    \<^item> URL \<^verbatim>\<open>isabelle-export:\<close> or action @{action_def
+    "isabelle-export-browser"} shows a toplevel directory with theory names:
+    each may provide its own tree structure of session exports. Exports are
+    like a logical file-system for the current prover session, maintained as
+    Isabelle/Scala data structures and written to the session database
+    eventually. The \<^verbatim>\<open>isabelle-export:\<close> URL exposes the current content
+    according to a snapshot of the document model. The file browser is \<^emph>\<open>not\<close>
+    updated continuously when the PIDE document changes: the reload operation
+    needs to be used explicitly. A notable example for exports is the command
+    @{command_ref export_code} @{cite "isabelle-isar-ref"}.
+
+    \<^item> URL \<^verbatim>\<open>isabelle-session:\<close> or action @{action_def
+    "isabelle-session-browser"} show the structure of session chapters and
+    sessions within them. What looks like a file-entry is actually a reference
+    to the session definition in its corresponding \<^verbatim>\<open>ROOT\<close> file. The latter is
+    subject to Prover IDE markup, so the session theories and other files may
+    be browsed quickly by following hyperlinks in the text.
+\<close>
+
+
 section \<open>Indentation\<close>
 
 text \<open>
   Isabelle/jEdit augments the existing indentation facilities of jEdit to take
   the structure of theory and proof texts into account. There is also special
-  support for unstructured proof scripts.
+  support for unstructured proof scripts (\<^theory_text>\<open>apply\<close> etc.).
 
     \<^descr>[Syntactic indentation] follows the outer syntax of Isabelle/Isar.
 
@@ -735,7 +769,7 @@
     approximation may need further manual tuning.
 
     Action @{action "isabelle.newline"} (shortcut \<^verbatim>\<open>ENTER\<close>) indents the old
-    and the new line according to command keywords only: this leads to precise
+    and the new line according to command keywords only: leading to precise
     alignment of the main Isar language elements. This depends on option
     @{system_option_def "jedit_indent_newline"} (enabled by default).
 
@@ -744,11 +778,10 @@
     on option @{system_option_def "jedit_indent_input"} (enabled by default).
 
     \<^descr>[Semantic indentation] adds additional white space to unstructured proof
-    scripts (\<^theory_text>\<open>apply\<close> etc.) via number of subgoals. This requires information
-    of ongoing document processing and may thus lag behind, when the user is
-    editing too quickly; see also option @{system_option_def
-    "jedit_script_indent"} and @{system_option_def
-    "jedit_script_indent_limit"}.
+    scripts via the number of subgoals. This requires information of ongoing
+    document processing and may thus lag behind when the user is editing too
+    quickly; see also option @{system_option_def "jedit_script_indent"} and
+    @{system_option_def "jedit_script_indent_limit"}.
 
   The above options are accessible in the menu \<^emph>\<open>Plugins / Plugin Options /
   Isabelle / General\<close>. A prerequisite for advanced indentation is \<^emph>\<open>Utilities
@@ -1132,7 +1165,7 @@
 
     \<^item> The \<^emph>\<open>Search\<close> field allows to highlight query output according to some
     regular expression, in the notation that is commonly used on the Java
-    platform.\<^footnote>\<open>\<^url>\<open>https://docs.oracle.com/javase/8/docs/api/java/util/regex/Pattern.html\<close>\<close>
+    platform.\<^footnote>\<open>\<^url>\<open>https://docs.oracle.com/en/java/javase/11/docs/api/java.base/java/util/regex/Pattern.html\<close>\<close>
     This may serve as an additional visual filter of the result.
 
     \<^item> The \<^emph>\<open>Zoom\<close> box controls the font size of the output area.
@@ -1203,7 +1236,7 @@
 
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.5]{popup1}
+  \includegraphics[scale=0.333]{popup1}
   \end{center}
   \caption{Tooltip and hyperlink for some formal entity}
   \label{fig:tooltip}
@@ -1215,7 +1248,7 @@
 
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.5]{popup2}
+  \includegraphics[scale=0.333]{popup2}
   \end{center}
   \caption{Nested tooltips over formal entities}
   \label{fig:nested-tooltips}
@@ -1253,7 +1286,7 @@
 
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.5]{scope1}
+  \includegraphics[scale=0.333]{scope1}
   \end{center}
   \caption{Scope of formal entity: defining vs.\ referencing positions}
   \label{fig:scope1}
@@ -1266,7 +1299,7 @@
 
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.5]{scope2}
+  \includegraphics[scale=0.333]{scope2}
   \end{center}
   \caption{The result of semantic selection and systematic renaming}
   \label{fig:scope2}
@@ -1331,7 +1364,7 @@
     completion of name-space entries propose antiquotation names.
 
   With some practice, input of quoted sub-languages and antiquotations of
-  embedded languages should work fluently. Note that national keyboard layouts
+  embedded languages should work smoothly. Note that national keyboard layouts
   might cause problems with back-quote as dead key, but double quote can be
   used instead.
 \<close>
@@ -1426,7 +1459,7 @@
 
   Already recognized names are \<^emph>\<open>not\<close> completed further, but completion may be
   extended by appending a suffix of underscores. This provokes a failed
-  lookup, and another completion attempt while ignoring the underscores. For
+  lookup, and another completion attempt (ignoring the underscores). For
   example, in a name space where \<^verbatim>\<open>foo\<close> and \<^verbatim>\<open>foobar\<close> are known, the input
   \<^verbatim>\<open>foo\<close> remains unchanged, but \<^verbatim>\<open>foo_\<close> may be completed to \<^verbatim>\<open>foo\<close> or
   \<^verbatim>\<open>foobar\<close>.
@@ -1711,7 +1744,7 @@
 
   \begin{figure}[!htb]
   \begin{center}
-  \includegraphics[scale=0.4]{auto-tools}
+  \includegraphics[scale=0.333]{auto-tools}
   \end{center}
   \caption{Result of automatically tried tools}
   \label{fig:auto-tools}
@@ -1854,7 +1887,7 @@
 
 text \<open>
   Document text is internally structured in paragraphs and nested lists, using
-  notation that is similar to Markdown\<^footnote>\<open>\<^url>\<open>http://commonmark.org\<close>\<close>. There are
+  notation that is similar to Markdown\<^footnote>\<open>\<^url>\<open>https://commonmark.org\<close>\<close>. There are
   special control symbols for items of different kinds of lists, corresponding
   to \<^verbatim>\<open>itemize\<close>, \<^verbatim>\<open>enumerate\<close>, \<^verbatim>\<open>description\<close> in {\LaTeX}. This is illustrated
   in for \<^verbatim>\<open>itemize\<close> in \figref{fig:markdown-document}.
@@ -1869,8 +1902,8 @@
 
   Items take colour according to the depth of nested lists. This helps to
   explore the implicit rules for list structure interactively. There is also
-  markup for individual paragraphs in the text: it may be explored via mouse
-  hovering with \<^verbatim>\<open>CONTROL\<close> / \<^verbatim>\<open>COMMAND\<close> as usual
+  markup for individual items and paragraphs in the text: it may be explored
+  via mouse hovering with \<^verbatim>\<open>CONTROL\<close> / \<^verbatim>\<open>COMMAND\<close> as usual
   (\secref{sec:tooltips-hyperlinks}).
 \<close>
 
@@ -2078,7 +2111,7 @@
   messages starts with the first activation of the corresponding dockable
   window; earlier messages are lost.
 
-  Actual display of protocol messages causes considerable slowdown, so it is
+  Display of protocol messages causes considerable slowdown, so it is
   important to undock all \<^emph>\<open>Protocol\<close> panels for production work.
 
   \<^item> \<^emph>\<open>Raw Output\<close> shows chunks of text from the \<^verbatim>\<open>stdout\<close> and \<^verbatim>\<open>stderr\<close>
@@ -2124,7 +2157,8 @@
   \<^path>\<open>$ISABELLE_HOME_USER/etc/settings\<close>. Also add
   \<^verbatim>\<open>isabelle_fonts_hinted=false\<close> to
   \<^path>\<open>$ISABELLE_HOME_USER/etc/preferences\<close> to avoid problems of the old
-  font renderer with hinting.
+  font renderer with hinting. Run the application from the command-line as
+  @{tool jedit}.
 
   \<^item> \<^bold>\<open>Problem:\<close> Keyboard shortcuts \<^verbatim>\<open>C+PLUS\<close> and \<^verbatim>\<open>C+MINUS\<close> for adjusting the
   editor font size depend on platform details and national keyboards.
@@ -2135,8 +2169,8 @@
   \<^emph>\<open>Preferences\<close> is in conflict with the jEdit default keyboard shortcut for
   \<^emph>\<open>Incremental Search Bar\<close> (action @{action_ref "quick-search"}).
 
-  \<^bold>\<open>Workaround:\<close> Rebind key via \<^emph>\<open>Global Options~/ Shortcuts\<close> according to
-  national keyboard, e.g.\ \<^verbatim>\<open>COMMAND+SLASH\<close> on English ones.
+  \<^bold>\<open>Workaround:\<close> Rebind key via \<^emph>\<open>Global Options~/ Shortcuts\<close> according to the
+  national keyboard layout, e.g.\ \<^verbatim>\<open>COMMAND+SLASH\<close> on English ones.
 
   \<^item> \<^bold>\<open>Problem:\<close> On Mac OS X with native Apple look-and-feel, some exotic
   national keyboards may cause a conflict of menu accelerator keys with
--- a/src/Doc/JEdit/document/root.tex	Thu May 09 12:32:47 2019 +0200
+++ b/src/Doc/JEdit/document/root.tex	Thu May 09 16:48:25 2019 +0200
@@ -63,11 +63,11 @@
 Research and implementation of concepts around PIDE and Isabelle/jEdit has
 started in 2008 and was kindly supported by:
 \begin{itemize}
-\item TU M\"unchen \url{http://www.in.tum.de}
-\item BMBF \url{http://www.bmbf.de}
-\item Universit\'e Paris-Sud \url{http://www.u-psud.fr}
-\item Digiteo \url{http://www.digiteo.fr}
-\item ANR \url{http://www.agence-nationale-recherche.fr}
+\item TU M\"unchen \url{https://www.in.tum.de}
+\item BMBF \url{https://www.bmbf.de}
+\item Universit\'e Paris-Sud \url{https://www.u-psud.fr}
+\item Digiteo \url{https://www.digiteo.fr}
+\item ANR \url{https://www.agence-nationale-recherche.fr}
 \end{itemize}
 
 
--- a/src/Doc/manual.bib	Thu May 09 12:32:47 2019 +0200
+++ b/src/Doc/manual.bib	Thu May 09 16:48:25 2019 +0200
@@ -2186,6 +2186,30 @@
   note = {\url{http://eptcs.web.cse.unsw.edu.au/paper.cgi?UITP2014:11}}
 }
 
+@InProceedings{Wenzel:2018:FIDE,
+  author = {Makarius Wenzel},
+  title = {{Isabelle/jEdit} as {IDE} for domain-specific formal
+    languages and informal text documents},
+  booktitle = {F-IDE Workshop 2018 (Oxford, UK)},
+  year = {2018},
+  editor = {Paolo Masci and Rosemary Monahan and Virgile Prevosto},
+  number = 284,
+  series = {EPTCS},
+  note = {\url{http://eptcs.web.cse.unsw.edu.au/paper.cgi?FIDE2018.6}},
+}
+
+@InProceedings{Wenzel:2019:MKM,
+  author = {Makarius Wenzel},
+  title = {Interaction with Formal Mathematical Documents in {Isabelle/PIDE}},
+  booktitle = {Intelligent Computer Mathematics (CICM 2019)},
+  year = {2019},
+  editor = {Cezary Kaliszyk and Edwin Brady and Andrea Kohlhase and Sacerdoti Coen, Claudio},
+  volume = {????},
+  series = LNAI,
+  publisher = {Springer},
+  note = {\url{https://arxiv.org/abs/1905.01735}}
+}
+
 @book{principia,
   author	= {A. N. Whitehead and B. Russell},
   title		= {Principia Mathematica},
--- a/src/Pure/Isar/proof_context.ML	Thu May 09 12:32:47 2019 +0200
+++ b/src/Pure/Isar/proof_context.ML	Thu May 09 16:48:25 2019 +0200
@@ -1503,14 +1503,15 @@
           [Pretty.block (Pretty.breaks (head ::
             flat (separate sep (map (single o prt) xs))))];
   in
-    Pretty.block (Pretty.fbreaks
-      (prt_name name :: Pretty.str ":" ::
-        prt_sect (Pretty.keyword1 "fix") [] (prt_name o Binding.name_of o fst) fixes @
-        prt_sect (Pretty.keyword1 "let") [Pretty.keyword2 "and"] prt_let
-          (map_filter (fn (xi, SOME t) => SOME (xi, t) | _ => NONE) lets) @
-        (if forall (null o #2) asms then []
-          else prt_sect (Pretty.keyword1 "assume") [Pretty.keyword2 "and"] prt_asm asms) @
-        prt_sect (Pretty.str "subcases:") [] (prt_name o fst) cs))
+    Pretty.block
+      (prt_name name :: Pretty.str ":" :: Pretty.fbrk ::
+        Pretty.fbreaks
+          (prt_sect (Pretty.keyword1 "fix") [] (prt_name o Binding.name_of o fst) fixes @
+           prt_sect (Pretty.keyword1 "let") [Pretty.keyword2 "and"] prt_let
+             (map_filter (fn (xi, SOME t) => SOME (xi, t) | _ => NONE) lets) @
+           (if forall (null o #2) asms then []
+            else prt_sect (Pretty.keyword1 "assume") [Pretty.keyword2 "and"] prt_asm asms) @
+           prt_sect (Pretty.str "subcases:") [] (prt_name o fst) cs))
   end;
 
 in
--- a/src/Tools/jEdit/src/isabelle_session.scala	Thu May 09 12:32:47 2019 +0200
+++ b/src/Tools/jEdit/src/isabelle_session.scala	Thu May 09 16:48:25 2019 +0200
@@ -88,8 +88,12 @@
         case Some(snapshot) =>
           val sessions = sessions_structure()
           val session = PIDE.resources.session_base.theory_qualifier(snapshot.node_name)
-          val chapter = sessions.get(session).getOrElse(Sessions.UNSORTED)
-          chapter + "/" + session
+          val chapter =
+            sessions.get(session) match {
+              case Some(info) => info.chapter
+              case None => Sessions.UNSORTED
+            }
+          chapter
       }
     VFSBrowser.browseDirectory(view, vfs_prefix + path)
   }