src/Tools/jEdit/src/jedit/html_panel.scala
author wenzelm
Fri, 07 May 2010 22:00:23 +0200
changeset 36735 42b7f881f5fc
parent 36015 6111de7c916a
child 36760 b82a698ef6c9
permissions -rw-r--r--
output symbolic pretty printing markup and format in the front end;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     1
/*
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     2
 * HTML panel based on Lobo/Cobra
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     3
 *
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     4
 * @author Makarius
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     5
 */
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     6
34871
e596a0b71f3c incorporate "proofdocument" part into main Isabelle/Pure.jar -- except for html_panel.scala, which depends on external library (Lobo/Cobra browser);
wenzelm
parents: 34823
diff changeset
     7
package isabelle.jedit
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     8
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
     9
36015
6111de7c916a adapted to Scala 2.8.0 Beta 1;
wenzelm
parents: 34871
diff changeset
    10
import isabelle._
6111de7c916a adapted to Scala 2.8.0 Beta 1;
wenzelm
parents: 34871
diff changeset
    11
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    12
import java.io.StringReader
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    13
import java.awt.{BorderLayout, Dimension}
34775
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    14
import java.awt.event.MouseEvent
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    15
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    16
import javax.swing.{JButton, JPanel, JScrollPane}
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    17
import java.util.logging.{Logger, Level}
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    18
34775
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    19
import org.w3c.dom.html2.HTMLElement
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    20
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    21
import org.lobobrowser.html.parser.{DocumentBuilderImpl, InputSourceImpl}
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    22
import org.lobobrowser.html.gui.HtmlPanel
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    23
import org.lobobrowser.html.domimpl.{HTMLDocumentImpl, HTMLStyleElementImpl, NodeImpl}
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    24
import org.lobobrowser.html.test.{SimpleHtmlRendererContext, SimpleUserAgentContext}
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    25
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    26
import scala.io.Source
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    27
import scala.actors.Actor._
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    28
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    29
34775
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    30
object HTML_Panel
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    31
{
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    32
  sealed abstract class Event { val element: HTMLElement; val mouse: MouseEvent }
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    33
  case class Context_Menu(val element: HTMLElement, mouse: MouseEvent) extends Event
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    34
  case class Mouse_Click(val element: HTMLElement, mouse: MouseEvent) extends Event
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    35
  case class Double_Click(val element: HTMLElement, mouse: MouseEvent) extends Event
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    36
  case class Mouse_Over(val element: HTMLElement, mouse: MouseEvent) extends Event
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    37
  case class Mouse_Out(val element: HTMLElement, mouse: MouseEvent) extends Event
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    38
}
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    39
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    40
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    41
class HTML_Panel(
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    42
  sys: Isabelle_System,
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    43
  initial_font_size: Int,
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    44
  handler: PartialFunction[HTML_Panel.Event, Unit]) extends HtmlPanel
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    45
{
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    46
  // global logging
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    47
  Logger.getLogger("org.lobobrowser").setLevel(Level.WARNING)
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    48
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    49
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    50
  /* document template */
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    51
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    52
  private def try_file(name: String): String =
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    53
  {
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    54
    val file = sys.platform_file(name)
34776
wenzelm
parents: 34775
diff changeset
    55
    if (file.isFile) Source.fromFile(file).mkString else ""
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    56
  }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    57
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    58
  private def template(font_size: Int): String =
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    59
    """<?xml version="1.0" encoding="utf-8"?>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    60
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    61
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    62
<html xmlns="http://www.w3.org/1999/xhtml">
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    63
<head>
34770
0c630c52fc74 prefer options from running application;
wenzelm
parents: 34769
diff changeset
    64
<style media="all" type="text/css">
0c630c52fc74 prefer options from running application;
wenzelm
parents: 34769
diff changeset
    65
""" +
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    66
  try_file("$ISABELLE_HOME/lib/html/isabelle.css") + "\n" +
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    67
  try_file("$ISABELLE_HOME_USER/etc/isabelle.css") + "\n" +
34770
0c630c52fc74 prefer options from running application;
wenzelm
parents: 34769
diff changeset
    68
  "body { font-family: " + sys.font_family + "; font-size: " + font_size + "px }" +
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    69
"""
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    70
</style>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    71
</head>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    72
<body/>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    73
</html>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    74
"""
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    75
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    76
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    77
  /* actor with local state */
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    78
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    79
  private val ucontext = new SimpleUserAgentContext
34775
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    80
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    81
  private val rcontext = new SimpleHtmlRendererContext(this, ucontext)
34775
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    82
  {
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    83
    private def handle(event: HTML_Panel.Event): Boolean =
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    84
      if (handler != null && handler.isDefinedAt(event)) { handler(event); true }
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    85
      else false
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    86
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    87
    override def onContextMenu(elem: HTMLElement, event: MouseEvent): Boolean =
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    88
      handle(HTML_Panel.Context_Menu(elem, event))
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    89
    override def onMouseClick(elem: HTMLElement, event: MouseEvent): Boolean =
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    90
      handle(HTML_Panel.Mouse_Click(elem, event))
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    91
    override def onDoubleClick(elem: HTMLElement, event: MouseEvent): Boolean =
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    92
      handle(HTML_Panel.Double_Click(elem, event))
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    93
    override def onMouseOver(elem: HTMLElement, event: MouseEvent)
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    94
      { handle(HTML_Panel.Mouse_Over(elem, event)) }
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    95
    override def onMouseOut(elem: HTMLElement, event: MouseEvent)
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    96
      { handle(HTML_Panel.Mouse_Out(elem, event)) }
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    97
  }
49245d68f7e4 basic setup for HTML_Panel event handling;
wenzelm
parents: 34770
diff changeset
    98
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
    99
  private val builder = new DocumentBuilderImpl(ucontext, rcontext)
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   100
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   101
  private case class Init(font_size: Int)
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   102
  private case class Render(body: List[XML.Tree])
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   103
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   104
  private val main_actor = actor {
34791
b97d5b38dea4 explicit object Session.Global_Settings;
wenzelm
parents: 34776
diff changeset
   105
    // crude double buffering
34823
2f3ea37c5958 renamed Proof_Document to Document;
wenzelm
parents: 34791
diff changeset
   106
    var doc1: org.w3c.dom.Document = null
2f3ea37c5958 renamed Proof_Document to Document;
wenzelm
parents: 34791
diff changeset
   107
    var doc2: org.w3c.dom.Document = null
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   108
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   109
    loop {
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   110
      react {
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   111
        case Init(font_size) =>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   112
          val src = template(font_size)
34766
4f9bcd4b5bd1 provide dummy URL;
wenzelm
parents: 34765
diff changeset
   113
          def parse() =
4f9bcd4b5bd1 provide dummy URL;
wenzelm
parents: 34765
diff changeset
   114
            builder.parse(new InputSourceImpl(new StringReader(src), "http://localhost"))
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   115
          doc1 = parse()
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   116
          doc2 = parse()
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   117
          Swing_Thread.now { setDocument(doc1, rcontext) }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   118
          
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   119
        case Render(body) =>
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   120
          val doc = doc2
36735
42b7f881f5fc output symbolic pretty printing markup and format in the front end;
wenzelm
parents: 36015
diff changeset
   121
          val html_body = Pretty.formatted(body).map(t => XML.elem(HTML.PRE, HTML.spans(t)))
42b7f881f5fc output symbolic pretty printing markup and format in the front end;
wenzelm
parents: 36015
diff changeset
   122
          val node = XML.document_node(doc, XML.elem(HTML.BODY, html_body))
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   123
          doc.removeChild(doc.getLastChild())
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   124
          doc.appendChild(node)
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   125
          doc2 = doc1
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   126
          doc1 = doc
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   127
          Swing_Thread.now { setDocument(doc1, rcontext) }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   128
34769
826525fc5285 more precise messages;
wenzelm
parents: 34766
diff changeset
   129
        case bad => System.err.println("main_actor: ignoring bad message " + bad)
34765
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   130
      }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   131
    }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   132
  }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   133
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   134
  main_actor ! Init(initial_font_size)
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   135
  
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   136
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   137
  /* main method wrappers */
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   138
  
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   139
  def init(font_size: Int) { main_actor ! Init(font_size) }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   140
  def render(body: List[XML.Tree]) { main_actor ! Render(body) }
63ba7f0931e2 generic HTML_Panel -- specific Results_Dockable;
wenzelm
parents:
diff changeset
   141
}