author | wenzelm |
Sat, 07 Sep 2013 19:18:05 +0200 | |
changeset 53465 | 3a944e1d20be |
parent 53462 | c531db093680 |
child 53466 | 19e7d5044617 |
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:
52675
diff
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:
52675
diff
changeset
|
9 |
|
53449 | 10 |
import javax.swing.SwingUtilities |
53445
811db2b751ed
warm start of Isabelle/jEdit from Isabelle/Scala;
wenzelm
parents:
53423
diff
changeset
|
11 |
import java.lang.{System, ClassLoader} |
53461 | 12 |
import java.io.{File => JFile, BufferedReader, InputStreamReader} |
13 |
import java.nio.file.Files |
|
14 |
||
15 |
import scala.annotation.tailrec |
|
47663
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
16 |
|
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
17 |
|
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
18 |
object Main |
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
19 |
{ |
53461 | 20 |
/** main entry point **/ |
21 |
||
53456 | 22 |
def main(args: Array[String]) |
53449 | 23 |
{ |
53456 | 24 |
val system_dialog = new System_Dialog |
25 |
||
26 |
def exit_error(exn: Throwable): Nothing = |
|
27 |
{ |
|
28 |
GUI.dialog(null, "Isabelle", GUI.scrollable_text(Exn.message(exn))) |
|
29 |
system_dialog.return_code(2) |
|
53460 | 30 |
system_dialog.join_exit |
53456 | 31 |
} |
32 |
||
33 |
def build |
|
34 |
{ |
|
35 |
try { |
|
36 |
GUI.init_laf() |
|
37 |
Isabelle_System.init() |
|
53449 | 38 |
|
53456 | 39 |
val mode = Isabelle_System.getenv("JEDIT_BUILD_MODE") |
40 |
if (mode == "none") |
|
41 |
system_dialog.return_code(0) |
|
42 |
else { |
|
43 |
val system_mode = mode == "" || mode == "system" |
|
44 |
val dirs = Path.split(Isabelle_System.getenv("JEDIT_SESSION_DIRS")) |
|
45 |
val options = Options.init() |
|
46 |
val session = Isabelle_System.default_logic( |
|
47 |
Isabelle_System.getenv("JEDIT_LOGIC"), |
|
48 |
options.string("jedit_logic")) |
|
49 |
Build_Dialog.dialog(options, system_dialog, system_mode, dirs, session) |
|
50 |
} |
|
51 |
} |
|
52 |
catch { case exn: Throwable => exit_error(exn) } |
|
53 |
} |
|
53449 | 54 |
|
53456 | 55 |
def start |
56 |
{ |
|
57 |
val do_start = |
|
58 |
{ |
|
59 |
try { |
|
60 |
/* settings directory */ |
|
61 |
||
62 |
val settings_dir = Path.explode("$JEDIT_SETTINGS") |
|
63 |
Isabelle_System.mkdirs(settings_dir + Path.explode("DockableWindowManager")) |
|
64 |
||
65 |
if (!(settings_dir + Path.explode("perspective.xml")).is_file) { |
|
66 |
File.write(settings_dir + Path.explode("DockableWindowManager/perspective-view0.xml"), |
|
67 |
"""<DOCKING LEFT="" TOP="" RIGHT="" BOTTOM="isabelle-readme" LEFT_POS="0" TOP_POS="0" RIGHT_POS="250" BOTTOM_POS="250" />""") |
|
68 |
File.write(settings_dir + Path.explode("perspective.xml"), |
|
69 |
"""<?xml version="1.0" encoding="UTF-8" ?> |
|
70 |
<!DOCTYPE PERSPECTIVE SYSTEM "perspective.dtd"> |
|
71 |
<PERSPECTIVE> |
|
72 |
<VIEW PLAIN="FALSE"> |
|
73 |
<GEOMETRY X="0" Y="35" WIDTH="1072" HEIGHT="787" EXT_STATE="0" /> |
|
74 |
</VIEW> |
|
75 |
</PERSPECTIVE>""") |
|
76 |
} |
|
53449 | 77 |
|
78 |
||
53456 | 79 |
/* args */ |
80 |
||
81 |
val jedit_options = |
|
82 |
Isabelle_System.getenv_strict("JEDIT_OPTIONS").split(" +") |
|
83 |
||
84 |
val jedit_settings = |
|
85 |
Array("-settings=" + Isabelle_System.platform_path(Path.explode("$JEDIT_SETTINGS"))) |
|
86 |
||
87 |
val more_args = |
|
88 |
if (args.isEmpty) |
|
89 |
Array(Isabelle_System.platform_path(Path.explode("$USER_HOME/Scratch.thy"))) |
|
90 |
else args |
|
91 |
||
92 |
||
93 |
/* startup */ |
|
53445
811db2b751ed
warm start of Isabelle/jEdit from Isabelle/Scala;
wenzelm
parents:
53423
diff
changeset
|
94 |
|
53456 | 95 |
System.setProperty("jedit.home", |
96 |
Isabelle_System.platform_path(Path.explode("$JEDIT_HOME/dist"))) |
|
97 |
||
98 |
System.setProperty("scala.home", |
|
99 |
Isabelle_System.platform_path(Path.explode("$SCALA_HOME"))) |
|
100 |
||
101 |
val jedit = ClassLoader.getSystemClassLoader.loadClass("org.gjt.sp.jedit.jEdit") |
|
102 |
val jedit_main = jedit.getDeclaredMethod("main", classOf[Array[String]]) |
|
103 |
||
104 |
() => jedit_main.invoke(null, jedit_options ++ jedit_settings ++ more_args) |
|
105 |
} |
|
106 |
catch { case exn: Throwable => exit_error(exn) } |
|
107 |
} |
|
108 |
do_start() |
|
109 |
} |
|
53419
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
110 |
|
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
111 |
if (Platform.is_windows) { |
53459 | 112 |
try { |
113 |
GUI.init_laf() |
|
53419
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
114 |
|
53459 | 115 |
val isabelle_home0 = System.getenv("ISABELLE_HOME_WINDOWS") |
116 |
val isabelle_home = System.getProperty("isabelle.home") |
|
47663
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
117 |
|
53459 | 118 |
if (isabelle_home0 == null || isabelle_home0 == "") { |
119 |
if (isabelle_home == null || isabelle_home == "") |
|
120 |
error("Unknown Isabelle home directory") |
|
121 |
if (!(new JFile(isabelle_home)).isDirectory) |
|
122 |
error("Bad Isabelle home directory: " + quote(isabelle_home)) |
|
53419
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
123 |
|
53459 | 124 |
val cygwin_root = isabelle_home + "\\contrib\\cygwin" |
125 |
if ((new JFile(cygwin_root)).isDirectory) |
|
126 |
System.setProperty("cygwin.root", cygwin_root) |
|
53422 | 127 |
|
53459 | 128 |
val uninitialized_file = new JFile(cygwin_root, "isabelle\\uninitialized") |
129 |
val uninitialized = uninitialized_file.isFile && uninitialized_file.delete |
|
53419
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
130 |
|
53461 | 131 |
if (uninitialized) cygwin_init(system_dialog, isabelle_home, cygwin_root) |
53419
1c87e79bb838
main application entry point involves implicit Cygwin init, depending on "uninitialized" file indicator;
wenzelm
parents:
52675
diff
changeset
|
132 |
} |
53459 | 133 |
} |
134 |
catch { case exn: Throwable => exit_error(exn) } |
|
53462
c531db093680
observe "stopped" after Cygwin init (which is itself uninterruptible);
wenzelm
parents:
53461
diff
changeset
|
135 |
|
c531db093680
observe "stopped" after Cygwin init (which is itself uninterruptible);
wenzelm
parents:
53461
diff
changeset
|
136 |
if (system_dialog.stopped) { |
c531db093680
observe "stopped" after Cygwin init (which is itself uninterruptible);
wenzelm
parents:
53461
diff
changeset
|
137 |
system_dialog.return_code(130) |
c531db093680
observe "stopped" after Cygwin init (which is itself uninterruptible);
wenzelm
parents:
53461
diff
changeset
|
138 |
system_dialog.join_exit |
c531db093680
observe "stopped" after Cygwin init (which is itself uninterruptible);
wenzelm
parents:
53461
diff
changeset
|
139 |
} |
53459 | 140 |
} |
53445
811db2b751ed
warm start of Isabelle/jEdit from Isabelle/Scala;
wenzelm
parents:
53423
diff
changeset
|
141 |
|
53459 | 142 |
build |
143 |
val rc = system_dialog.join |
|
144 |
if (rc == 0) start else sys.exit(rc) |
|
53445
811db2b751ed
warm start of Isabelle/jEdit from Isabelle/Scala;
wenzelm
parents:
53423
diff
changeset
|
145 |
} |
53461 | 146 |
|
147 |
||
148 |
||
149 |
/** Cygwin init (e.g. after extraction via 7zip) **/ |
|
150 |
||
151 |
private def cygwin_init(system_dialog: System_Dialog, isabelle_home: String, cygwin_root: String) |
|
152 |
{ |
|
153 |
system_dialog.title("Isabelle system initialization") |
|
154 |
system_dialog.echo("Initializing Cygwin:") |
|
155 |
||
156 |
def execute(args: String*): Int = |
|
157 |
{ |
|
158 |
val cwd = new JFile(isabelle_home) |
|
159 |
val env = Map("CYGWIN" -> "nodosfilewarning") |
|
160 |
system_dialog.execute(cwd, env, args: _*) |
|
161 |
} |
|
162 |
||
163 |
system_dialog.echo("symlinks ...") |
|
164 |
val symlinks = |
|
165 |
{ |
|
166 |
val path = (new JFile(cygwin_root + "\\isabelle\\symlinks")).toPath |
|
167 |
Files.readAllLines(path, UTF8.charset).toArray.toList.asInstanceOf[List[String]] |
|
168 |
} |
|
169 |
@tailrec def recover_symlinks(list: List[String]): Unit = |
|
170 |
{ |
|
171 |
list match { |
|
172 |
case Nil | List("") => |
|
173 |
case link :: content :: rest => |
|
174 |
val path = (new JFile(isabelle_home, link)).toPath |
|
175 |
||
176 |
val writer = Files.newBufferedWriter(path, UTF8.charset) |
|
177 |
try { writer.write("!<symlink>" + content + "\0") } |
|
178 |
finally { writer.close } |
|
179 |
||
180 |
Files.setAttribute(path, "dos:system", true) |
|
181 |
||
182 |
recover_symlinks(rest) |
|
183 |
case _ => error("Unbalanced symlinks list") |
|
184 |
} |
|
185 |
} |
|
186 |
recover_symlinks(symlinks) |
|
187 |
||
188 |
system_dialog.echo("rebaseall ...") |
|
189 |
execute(cygwin_root + "\\bin\\dash.exe", "/isabelle/rebaseall") |
|
190 |
||
191 |
system_dialog.echo("postinstall ...") |
|
192 |
execute(cygwin_root + "\\bin\\bash.exe", "/isabelle/postinstall") |
|
193 |
||
194 |
system_dialog.echo("init ...") |
|
195 |
Isabelle_System.init() |
|
196 |
} |
|
47663
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
197 |
} |
20e0865ae9e7
default Isabelle application wrapper -- JVM entry point for Isabelle.exe;
wenzelm
parents:
diff
changeset
|
198 |