diff --git a/src/Pure/Tools/main.scala b/src/Pure/Tools/main.scala
--- a/src/Pure/Tools/main.scala
+++ b/src/Pure/Tools/main.scala
@@ -1,144 +1,159 @@
/* Title: Pure/Tools/main.scala
Author: Makarius
Main Isabelle application entry point.
*/
package isabelle
import java.lang.{Class, ClassLoader}
object Main
{
/* main entry point */
def main(args: Array[String])
{
val start =
{
try {
Isabelle_System.init()
GUI.install_fonts()
+ /* ROOTS template */
+
+ {
+ val roots = Path.explode("$ISABELLE_HOME_USER/ROOTS")
+ if (!roots.is_file) File.write(roots, """# Additional session root directories
+#
+# * each line contains one directory entry in Isabelle path notation
+# * lines starting with "#" are stripped
+# * changes require application restart
+#
+#:mode=text:encoding=UTF-8:
+""")
+ }
+
+
/* settings directory */
val settings_dir = Path.explode("$JEDIT_SETTINGS")
val properties = settings_dir + Path.explode("properties")
if (properties.is_file) {
val props1 = split_lines(File.read(properties))
val props2 = props1.filterNot(_.startsWith("plugin-blacklist.Isabelle-jEdit"))
if (props1 != props2) File.write(properties, cat_lines(props2))
}
Isabelle_System.mkdirs(settings_dir + Path.explode("DockableWindowManager"))
if (!(settings_dir + Path.explode("perspective.xml")).is_file) {
File.write(settings_dir + Path.explode("DockableWindowManager/perspective-view0.xml"),
"""""")
File.write(settings_dir + Path.explode("perspective.xml"),
"""
""")
}
/* args */
val jedit_settings =
"-settings=" + File.platform_path(Path.explode("$JEDIT_SETTINGS"))
val jedit_server =
System.getProperty("isabelle.jedit_server") match {
case null | "" => "-noserver"
case name => "-server=" + name
}
val jedit_options =
Isabelle_System.getenv_strict("JEDIT_OPTIONS").split(" +")
val more_args =
{
args.toList.dropWhile(arg => arg.startsWith("-") && arg != "--") match {
case Nil | List("--") =>
args ++ Array(File.platform_path(Path.explode("$USER_HOME/Scratch.thy")))
case List(":") => args.slice(0, args.size - 1)
case _ => args
}
}
/* main startup */
update_environment()
System.setProperty("jedit.home", File.platform_path(Path.explode("$JEDIT_HOME/dist")))
System.setProperty("scala.home", File.platform_path(Path.explode("$SCALA_HOME")))
System.setProperty("scala.color", "false")
val jedit =
Class.forName("org.gjt.sp.jedit.jEdit", true, ClassLoader.getSystemClassLoader)
val jedit_main = jedit.getMethod("main", classOf[Array[String]])
() => jedit_main.invoke(
null, Array(jedit_settings, jedit_server) ++ jedit_options ++ more_args)
}
catch {
case exn: Throwable =>
GUI.init_laf()
GUI.dialog(null, "Isabelle", GUI.scrollable_text(Exn.message(exn)))
sys.exit(2)
}
}
start()
}
/* adhoc update of JVM environment variables */
def update_environment()
{
val update =
{
val isabelle_home = Isabelle_System.getenv("ISABELLE_HOME")
val isabelle_home_user = Isabelle_System.getenv("ISABELLE_HOME_USER")
val jedit_home = Isabelle_System.getenv("JEDIT_HOME")
val jedit_settings = Isabelle_System.getenv("JEDIT_SETTINGS")
(env0: Any) => {
val env = env0.asInstanceOf[java.util.Map[String, String]]
env.put("ISABELLE_HOME", File.platform_path(isabelle_home))
env.put("ISABELLE_HOME_USER", File.platform_path(isabelle_home_user))
env.put("JEDIT_HOME", File.platform_path(jedit_home))
env.put("JEDIT_SETTINGS", File.platform_path(jedit_settings))
env.remove("ISABELLE_ROOT")
}
}
classOf[java.util.Collections].getDeclaredClasses
.find(c => c.getName == "java.util.Collections$UnmodifiableMap") match
{
case Some(c) =>
val m = c.getDeclaredField("m")
m.setAccessible(true)
update(m.get(System.getenv()))
if (Platform.is_windows) {
val ProcessEnvironment = Class.forName("java.lang.ProcessEnvironment")
val field = ProcessEnvironment.getDeclaredField("theCaseInsensitiveEnvironment")
field.setAccessible(true)
update(field.get(null))
}
case None =>
error("Failed to update JVM environment -- platform incompatibility")
}
}
}