ML status widget similar to org.gjt.sp.jedit.gui.statusbar.MemoryStatusWidgetFactory;
authorwenzelm
Wed, 12 Aug 2020 19:34:38 +0200
changeset 72369 f5c085dfa02f
parent 72368 fa57d299b46b
child 72370 ae6544cf1c8c
ML status widget similar to org.gjt.sp.jedit.gui.statusbar.MemoryStatusWidgetFactory;
src/Tools/jEdit/lib/Tools/jedit
src/Tools/jEdit/src/jEdit.props
src/Tools/jEdit/src/ml_status.scala
src/Tools/jEdit/src/services.xml
--- a/src/Tools/jEdit/lib/Tools/jedit	Wed Aug 12 19:32:45 2020 +0200
+++ b/src/Tools/jEdit/lib/Tools/jedit	Wed Aug 12 19:34:38 2020 +0200
@@ -49,6 +49,7 @@
   "src/Tools/jEdit/src/jedit_sessions.scala"
   "src/Tools/jEdit/src/jedit_spell_checker.scala"
   "src/Tools/jEdit/src/keymap_merge.scala"
+  "src/Tools/jEdit/src/ml_status.scala"
   "src/Tools/jEdit/src/monitor_dockable.scala"
   "src/Tools/jEdit/src/output_dockable.scala"
   "src/Tools/jEdit/src/plugin.scala"
--- a/src/Tools/jEdit/src/jEdit.props	Wed Aug 12 19:32:45 2020 +0200
+++ b/src/Tools/jEdit/src/jEdit.props	Wed Aug 12 19:34:38 2020 +0200
@@ -337,6 +337,7 @@
 view.height=850
 view.middleMousePaste=true
 view.showToolbar=true
+view.status=( mode , fold , encoding ) locked wrap multiSelect rectSelect overwrite lineSep buffersets task-monitor memory-status ml-status errors clock
 view.thickCaret=true
 view.width=1200
 xml-insert-closing-tag.shortcut=
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/src/Tools/jEdit/src/ml_status.scala	Wed Aug 12 19:34:38 2020 +0200
@@ -0,0 +1,124 @@
+/*  Title:      Tools/jEdit/src/ml_status.scala
+    Author:     Makarius
+
+ML status bar: heap and garbage collection.
+*/
+
+package isabelle.jedit
+
+
+import isabelle._
+
+import java.awt.{Color, Dimension, Graphics, Graphics2D, Insets, RenderingHints}
+import java.awt.font.FontRenderContext
+import javax.swing.{JComponent, JLabel}
+
+import org.gjt.sp.jedit.{View, jEdit}
+import org.gjt.sp.jedit.gui.statusbar.{StatusWidgetFactory, Widget}
+
+
+object ML_Status
+{
+  private val template = "99999/99999MB"
+
+  private class GUI extends JComponent
+  {
+    /* component state -- owned by GUI thread */
+
+    private var status = ML_Statistics.memory_status(Nil)
+
+
+    /* init */
+
+    setFont(new JLabel().getFont)
+    setToolTipText("ML heap memory")
+
+    private val font_render_context = new FontRenderContext(null, true, false)
+    private val line_metrics = getFont.getLineMetrics(template, font_render_context)
+
+    {
+      val bounds = getFont.getStringBounds(template, font_render_context)
+      val dim = new Dimension(bounds.getWidth.toInt, bounds.getHeight.toInt)
+      setPreferredSize(dim)
+      setMaximumSize(dim)
+    }
+
+    setForeground(jEdit.getColorProperty("view.status.foreground"))
+    setBackground(jEdit.getColorProperty("view.status.background"))
+
+    def progress_foreground: Color = jEdit.getColorProperty("view.status.memory.foreground")
+    def progress_background: Color = jEdit.getColorProperty("view.status.memory.background")
+
+
+    /* paint */
+
+    private def update(new_status: ML_Statistics.Memory_Status)
+    {
+      if (status != new_status) {
+        status = new_status
+        repaint()
+      }
+    }
+
+    override def paintComponent(gfx: Graphics)
+    {
+      super.paintComponent(gfx)
+
+      val insets = new Insets(0, 0, 0, 0)
+
+      val width = getWidth - insets.left - insets.right
+      val height = getHeight - insets.top - insets.bottom - 1
+
+      val width_used = (width * status.heap_used_fraction).toInt
+
+      val text = (status.heap_used / 1024 / 1024) + "/" + (status.heap_size / 1024 / 1024) + "MB"
+      val text_bounds = gfx.getFont.getStringBounds(text, font_render_context)
+      val text_x = insets.left + ((width - text_bounds.getWidth).toInt / 2)
+      val text_y = (insets.top + line_metrics.getAscent).toInt
+
+      gfx.asInstanceOf[Graphics2D].
+        setRenderingHint(
+          RenderingHints.KEY_TEXT_ANTIALIASING,
+          RenderingHints.VALUE_TEXT_ANTIALIAS_ON)
+
+      gfx.setColor(progress_background)
+      gfx.fillRect(insets.left, insets.top, width_used, height)
+
+      gfx.setColor(progress_foreground)
+      gfx.setClip(insets.left, insets.top, width_used, height)
+      gfx.drawString(text, text_x, text_y)
+
+      gfx.setColor(getForeground)
+      gfx.setClip(insets.left + width_used, insets.top, getWidth - insets.left - width_used, height)
+      gfx.drawString(text, text_x, text_y)
+    }
+
+
+    /* main */
+
+    private val main =
+      Session.Consumer[Session.Runtime_Statistics](getClass.getName) {
+        case stats =>
+          val status = ML_Statistics.memory_status(stats.props)
+          GUI_Thread.later { update(status) }
+      }
+
+    override def addNotify()
+    {
+      super.addNotify()
+      PIDE.session.runtime_statistics += main
+    }
+
+    override def removeNotify()
+    {
+      super.removeNotify()
+      PIDE.session.runtime_statistics -= main
+    }
+  }
+
+  class Widget_Factory extends StatusWidgetFactory
+  {
+    override def getWidget(view: View): Widget =
+      new Widget { override def getComponent: JComponent = new GUI }
+  }
+}
--- a/src/Tools/jEdit/src/services.xml	Wed Aug 12 19:32:45 2020 +0200
+++ b/src/Tools/jEdit/src/services.xml	Wed Aug 12 19:34:38 2020 +0200
@@ -50,4 +50,7 @@
   <SERVICE CLASS="isabelle.jedit.Active$Handler" NAME="graphview">
     new isabelle.jedit.Graphview_Dockable$Handler()
   </SERVICE>
+	<SERVICE CLASS="org.gjt.sp.jedit.gui.statusbar.StatusWidgetFactory" NAME="ml-status">
+		new isabelle.jedit.ML_Status$Widget_Factory();
+	</SERVICE>
 </SERVICES>