merged
authorwenzelm
Tue, 03 Mar 2020 20:14:48 +0100
changeset 71515 ce1222e9451e
parent 71512 fe93a863d946 (current diff)
parent 71514 61882acca79b (diff)
child 71516 a57413dd2909
merged
--- a/src/Pure/Tools/jedit.ML	Mon Mar 02 14:58:37 2020 +0000
+++ b/src/Pure/Tools/jedit.ML	Tue Mar 03 20:14:48 2020 +0100
@@ -1,20 +1,19 @@
 (*  Title:      Pure/Tools/jedit.ML
     Author:     Makarius
 
-jEdit support.
+Support for Isabelle/jEdit.
 *)
 
 signature JEDIT =
 sig
+  val get_actions: unit -> string list
   val check_action: string * Position.T -> string
 end;
 
 structure JEdit: JEDIT =
 struct
 
-(* jEdit actions *)
-
-local
+(* parse XML *)
 
 fun parse_named a (XML.Elem ((b, props), _)) =
       (case Properties.get props "NAME" of
@@ -22,39 +21,41 @@
       | NONE => [])
   | parse_named _ _ = [];
 
-val isabelle_jedit_actions =
-  Lazy.lazy (fn () =>
-    (case XML.parse (File.read \<^file>\<open>~~/src/Tools/jEdit/src/actions.xml\<close>) of
-      XML.Elem (("ACTIONS", _), body) => maps (parse_named "ACTION") body
-    | _ => []));
+fun parse_actions (XML.Elem (("ACTIONS", _), body)) = maps (parse_named "ACTION") body
+  | parse_actions _ = [];
+
+fun parse_dockables (XML.Elem (("DOCKABLES", _), body)) =
+      maps (parse_named "DOCKABLE") body
+      |> maps (fn a => [a, a ^ "-toggle", a ^ "-float"])
+  | parse_dockables _ = [];
+
+
+(* XML resources *)
 
-val isabelle_jedit_dockables =
-  Lazy.lazy (fn () =>
-    (case XML.parse (File.read \<^file>\<open>~~/src/Tools/jEdit/src/dockables.xml\<close>) of
-      XML.Elem (("DOCKABLES", _), body) => maps (parse_named "DOCKABLE") body
-    | _ => [])
-    |> maps (fn a => [a, a ^ "-toggle", a ^ "-float"]));
+val xml_file = XML.parse o File.read;
 
-val jedit_actions =
+fun xml_resource name =
+  let val script = "unzip -p \"$JEDIT_HOME/dist/jedit.jar\" " ^ Bash.string name in
+    (case Isabelle_System.bash_output script of
+      (txt, 0) => XML.parse txt
+    | (_, rc) => error ("Cannot unzip jedit.jar\nreturn code = " ^ string_of_int rc))
+  end;
+
+
+(* actions *)
+
+val lazy_actions =
   Lazy.lazy (fn () =>
-    (case Isabelle_System.bash_output
-      "unzip -p \"$JEDIT_HOME/dist/jedit.jar\" org/gjt/sp/jedit/actions.xml" of
-      (txt, 0) =>
-        (case XML.parse txt of
-          XML.Elem (("ACTIONS", _), body) => maps (parse_named "ACTION") body
-        | _ => [])
-    | (_, rc) => error ("Cannot unzip jedit.jar\nreturn code = " ^ string_of_int rc)));
+    (parse_actions (xml_file \<^file>\<open>~~/src/Tools/jEdit/src/actions.xml\<close>) @
+      parse_dockables (xml_file \<^file>\<open>~~/src/Tools/jEdit/src/dockables.xml\<close>) @
+      parse_actions (xml_resource "org/gjt/sp/jedit/actions.xml") @
+      parse_dockables (xml_resource "org/gjt/sp/jedit/dockables.xml"))
+    |> sort_strings);
 
-val all_actions =
-  Lazy.lazy (fn () =>
-    Lazy.force isabelle_jedit_actions @
-    Lazy.force isabelle_jedit_dockables @
-    Lazy.force jedit_actions);
-
-in
+fun get_actions () = Lazy.force lazy_actions;
 
 fun check_action (name, pos) =
-  if member (op =) (Lazy.force all_actions) name then
+  if member (op =) (get_actions ()) name then
     let
       val ((bg1, bg2), en) =
         YXML.output_markup_elem
@@ -66,11 +67,11 @@
       val completion_report =
         Completion.make_report (name, pos)
           (fn completed =>
-            Lazy.force all_actions
+            get_actions ()
             |> filter completed
             |> sort_strings
             |> map (fn a => (a, ("action", a))));
-    in error ("Bad jEdit action " ^ quote name ^ Position.here pos ^ completion_report) end
+    in error ("Bad jEdit action " ^ quote name ^ Position.here pos ^ completion_report) end;
 
 val _ =
   Theory.setup
@@ -84,5 +85,3 @@
         in name end));
 
 end;
-
-end;