| author | wenzelm | 
| Wed, 17 Jan 2018 14:40:18 +0100 | |
| changeset 67460 | dfc93f2b01ea | 
| parent 66577 | 6e35cf3ce869 | 
| child 69188 | 2fd73a1a0937 | 
| permissions | -rw-r--r-- | 
| 50687 | 1 | /* Title: Pure/Tools/main.scala | 
| 47663 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 2 | Author: Makarius | 
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 3 | |
| 53419 
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
 wenzelm parents: 
52675diff
changeset | 4 | Main Isabelle application entry point. | 
| 47663 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 5 | */ | 
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 6 | |
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 7 | package isabelle | 
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 8 | |
| 53419 
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
 wenzelm parents: 
52675diff
changeset | 9 | |
| 55618 | 10 | import java.lang.{Class, ClassLoader}
 | 
| 47663 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 11 | |
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 12 | |
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 13 | object Main | 
| 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 14 | {
 | 
| 61282 | 15 | /* main entry point */ | 
| 53461 | 16 | |
| 53456 | 17 | def main(args: Array[String]) | 
| 53449 | 18 |   {
 | 
| 61282 | 19 | val start = | 
| 61277 | 20 |     {
 | 
| 21 |       try {
 | |
| 61282 | 22 | Isabelle_System.init() | 
| 61307 
be3a5fee11e3
clarified init (again): isabelle.Main is responsible to provide basic JVM setup, jedit.jar picks this up (e.g. list of known fonts), plugin cannot be loaded in isolation without isabelle.Main;
 wenzelm parents: 
61291diff
changeset | 23 | GUI.install_fonts() | 
| 61282 | 24 | |
| 25 | ||
| 66577 | 26 | /* ROOTS template */ | 
| 27 | ||
| 28 |         {
 | |
| 29 |           val roots = Path.explode("$ISABELLE_HOME_USER/ROOTS")
 | |
| 30 | if (!roots.is_file) File.write(roots, """# Additional session root directories | |
| 31 | # | |
| 32 | # * each line contains one directory entry in Isabelle path notation | |
| 33 | # * lines starting with "#" are stripped | |
| 34 | # * changes require application restart | |
| 35 | # | |
| 36 | #:mode=text:encoding=UTF-8: | |
| 37 | """) | |
| 38 | } | |
| 39 | ||
| 40 | ||
| 61277 | 41 | /* settings directory */ | 
| 42 | ||
| 43 |         val settings_dir = Path.explode("$JEDIT_SETTINGS")
 | |
| 66463 | 44 | |
| 45 |         val properties = settings_dir + Path.explode("properties")
 | |
| 46 |         if (properties.is_file) {
 | |
| 47 | val props1 = split_lines(File.read(properties)) | |
| 48 |           val props2 = props1.filterNot(_.startsWith("plugin-blacklist.Isabelle-jEdit"))
 | |
| 49 | if (props1 != props2) File.write(properties, cat_lines(props2)) | |
| 50 | } | |
| 51 | ||
| 61277 | 52 |         Isabelle_System.mkdirs(settings_dir + Path.explode("DockableWindowManager"))
 | 
| 53 | ||
| 54 |         if (!(settings_dir + Path.explode("perspective.xml")).is_file) {
 | |
| 55 |           File.write(settings_dir + Path.explode("DockableWindowManager/perspective-view0.xml"),
 | |
| 56 | """<DOCKING LEFT="" TOP="" RIGHT="isabelle-documentation" BOTTOM="" LEFT_POS="0" TOP_POS="0" RIGHT_POS="250" BOTTOM_POS="250" />""") | |
| 57 |           File.write(settings_dir + Path.explode("perspective.xml"),
 | |
| 58 | """<?xml version="1.0" encoding="UTF-8" ?> | |
| 59 | <!DOCTYPE PERSPECTIVE SYSTEM "perspective.dtd"> | |
| 60 | <PERSPECTIVE> | |
| 61 | <VIEW PLAIN="FALSE"> | |
| 62 | <GEOMETRY X="0" Y="35" WIDTH="1072" HEIGHT="787" EXT_STATE="0" /> | |
| 63 | </VIEW> | |
| 64 | </PERSPECTIVE>""") | |
| 65 | } | |
| 66 | ||
| 67 | ||
| 68 | /* args */ | |
| 69 | ||
| 62036 | 70 | val jedit_settings = | 
| 71 |           "-settings=" + File.platform_path(Path.explode("$JEDIT_SETTINGS"))
 | |
| 72 | ||
| 73 | val jedit_server = | |
| 74 |           System.getProperty("isabelle.jedit_server") match {
 | |
| 75 | case null | "" => "-noserver" | |
| 76 | case name => "-server=" + name | |
| 77 | } | |
| 78 | ||
| 61277 | 79 | val jedit_options = | 
| 80 |           Isabelle_System.getenv_strict("JEDIT_OPTIONS").split(" +")
 | |
| 81 | ||
| 82 | val more_args = | |
| 61512 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 83 |         {
 | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 84 |           args.toList.dropWhile(arg => arg.startsWith("-") && arg != "--") match {
 | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 85 |             case Nil | List("--") =>
 | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 86 |               args ++ Array(File.platform_path(Path.explode("$USER_HOME/Scratch.thy")))
 | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 87 |             case List(":") => args.slice(0, args.size - 1)
 | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 88 | case _ => args | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 89 | } | 
| 
933463440449
more uniform command-line for "isabelle jedit" and the isabelle.Main app wrapper;
 wenzelm parents: 
61307diff
changeset | 90 | } | 
| 61277 | 91 | |
| 92 | ||
| 93 | /* main startup */ | |
| 94 | ||
| 95 | update_environment() | |
| 96 | ||
| 97 |         System.setProperty("jedit.home", File.platform_path(Path.explode("$JEDIT_HOME/dist")))
 | |
| 98 |         System.setProperty("scala.home", File.platform_path(Path.explode("$SCALA_HOME")))
 | |
| 65875 
12c90c0c4b32
suppress ANSI control sequences in Scala console;
 wenzelm parents: 
63749diff
changeset | 99 |         System.setProperty("scala.color", "false")
 | 
| 61277 | 100 | |
| 101 | val jedit = | |
| 102 |           Class.forName("org.gjt.sp.jedit.jEdit", true, ClassLoader.getSystemClassLoader)
 | |
| 103 |         val jedit_main = jedit.getMethod("main", classOf[Array[String]])
 | |
| 104 | ||
| 62036 | 105 | () => jedit_main.invoke( | 
| 106 | null, Array(jedit_settings, jedit_server) ++ jedit_options ++ more_args) | |
| 61277 | 107 | } | 
| 61282 | 108 |       catch {
 | 
| 109 | case exn: Throwable => | |
| 110 | GUI.init_laf() | |
| 111 | GUI.dialog(null, "Isabelle", GUI.scrollable_text(Exn.message(exn))) | |
| 112 | sys.exit(2) | |
| 113 | } | |
| 61277 | 114 | } | 
| 61282 | 115 | start() | 
| 53445 
811db2b751ed
warm start of Isabelle/jEdit from Isabelle/Scala;
 wenzelm parents: 
53423diff
changeset | 116 | } | 
| 53461 | 117 | |
| 118 | ||
| 61282 | 119 | /* adhoc update of JVM environment variables */ | 
| 53965 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 120 | |
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 121 | def update_environment() | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 122 |   {
 | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 123 | val update = | 
| 53966 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 124 |     {
 | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 125 |       val isabelle_home = Isabelle_System.getenv("ISABELLE_HOME")
 | 
| 54351 | 126 |       val isabelle_home_user = Isabelle_System.getenv("ISABELLE_HOME_USER")
 | 
| 63749 | 127 |       val jedit_home = Isabelle_System.getenv("JEDIT_HOME")
 | 
| 128 |       val jedit_settings = Isabelle_System.getenv("JEDIT_SETTINGS")
 | |
| 53965 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 129 | |
| 53966 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 130 |       (env0: Any) => {
 | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 131 | val env = env0.asInstanceOf[java.util.Map[String, String]] | 
| 60997 | 132 |         env.put("ISABELLE_HOME", File.platform_path(isabelle_home))
 | 
| 133 |         env.put("ISABELLE_HOME_USER", File.platform_path(isabelle_home_user))
 | |
| 63749 | 134 |         env.put("JEDIT_HOME", File.platform_path(jedit_home))
 | 
| 135 |         env.put("JEDIT_SETTINGS", File.platform_path(jedit_settings))
 | |
| 62261 
74dc98bd9f51
suppress ISABELLE_ROOT after init, to avoid conflict with ISABELLE_HOME when folding file names in "isabelle jedit" command-line tool;
 wenzelm parents: 
62036diff
changeset | 136 |         env.remove("ISABELLE_ROOT")
 | 
| 53966 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 137 | } | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 138 | } | 
| 53965 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 139 | |
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 140 | classOf[java.util.Collections].getDeclaredClasses | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 141 | .find(c => c.getName == "java.util.Collections$UnmodifiableMap") match | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 142 |     {
 | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 143 | case Some(c) => | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 144 |         val m = c.getDeclaredField("m")
 | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 145 | m.setAccessible(true) | 
| 53966 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 146 | update(m.get(System.getenv())) | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 147 | |
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 148 |         if (Platform.is_windows) {
 | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 149 |           val ProcessEnvironment = Class.forName("java.lang.ProcessEnvironment")
 | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 150 |           val field = ProcessEnvironment.getDeclaredField("theCaseInsensitiveEnvironment")
 | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 151 | field.setAccessible(true) | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 152 | update(field.get(null)) | 
| 53965 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 153 | } | 
| 53966 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 154 | |
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 155 | case None => | 
| 
5a546a881f90
update second environment that is used for System.getenv(String);
 wenzelm parents: 
53965diff
changeset | 156 |         error("Failed to update JVM environment -- platform incompatibility")
 | 
| 53965 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 157 | } | 
| 
cca95e9055ba
adhoc update of JVM environment variables, which is relevant for cold start of jEdit;
 wenzelm parents: 
53912diff
changeset | 158 | } | 
| 47663 
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
 wenzelm parents: diff
changeset | 159 | } |