| author | wenzelm | 
| Wed, 19 May 2021 15:53:55 +0200 | |
| changeset 73746 | b2d47981c8dc | 
| parent 73649 | 029de1598940 | 
| child 74419 | ff0ca375457c | 
| permissions | -rw-r--r-- | 
| 65071 | 1 | /* Title: Pure/Admin/build_cygwin.scala | 
| 2 | Author: Makarius | |
| 3 | ||
| 4 | Produce pre-canned Cygwin distribution for Isabelle. | |
| 5 | */ | |
| 6 | ||
| 7 | package isabelle | |
| 8 | ||
| 9 | ||
| 10 | object Build_Cygwin | |
| 11 | {
 | |
| 72361 | 12 | val default_mirror: String = "https://isabelle.sketis.net/cygwin_2021" | 
| 65071 | 13 | |
| 14 | val packages: List[String] = | |
| 73436 
e92f2e44e4d8
removed spurious references to perl / libwww-perl;
 wenzelm parents: 
73340diff
changeset | 15 |     List("curl", "libgmp-devel", "nano", "perl", "rlwrap", "unzip")
 | 
| 65071 | 16 | |
| 17 | def build_cygwin(progress: Progress, | |
| 18 | mirror: String = default_mirror, | |
| 73340 | 19 | more_packages: List[String] = Nil): Unit = | 
| 65071 | 20 |   {
 | 
| 73120 
c3589f2dff31
more informative errors: simplify diagnosis of spurious failures reported by users;
 wenzelm parents: 
72763diff
changeset | 21 | require(Platform.is_windows, "Windows platform expected") | 
| 65071 | 22 | |
| 23 |     Isabelle_System.with_tmp_dir("cygwin")(tmp_dir =>
 | |
| 24 |       {
 | |
| 25 |         val cygwin = tmp_dir + Path.explode("cygwin")
 | |
| 26 |         val cygwin_etc = cygwin + Path.explode("etc")
 | |
| 72376 | 27 |         val cygwin_isabelle = Isabelle_System.make_directory(cygwin + Path.explode("isabelle"))
 | 
| 65071 | 28 | |
| 66727 | 29 | val cygwin_exe_name = mirror + "/setup-x86_64.exe" | 
| 65071 | 30 |         val cygwin_exe = cygwin_isabelle + Path.explode("cygwin.exe")
 | 
| 31 | Bytes.write(cygwin_exe, | |
| 32 |           try { Bytes.read(Url(cygwin_exe_name)) }
 | |
| 33 |           catch { case ERROR(_) => error("Failed to download " + quote(cygwin_exe_name)) })
 | |
| 34 | ||
| 68374 
8740e1241555
updated to current Cygwin, after 2.10.0-1 from 02-Feb-2018;
 wenzelm parents: 
66727diff
changeset | 35 |         File.write(cygwin_isabelle + Path.explode("cygwin_mirror"), mirror)
 | 
| 
8740e1241555
updated to current Cygwin, after 2.10.0-1 from 02-Feb-2018;
 wenzelm parents: 
66727diff
changeset | 36 | |
| 69789 
2c3e5e58d93f
more thorough File.set_executable, notably for Windows;
 wenzelm parents: 
69425diff
changeset | 37 | File.set_executable(cygwin_exe, true) | 
| 69405 
22428643351f
more direct File.executable operation: avoid external process (on Unix);
 wenzelm parents: 
69277diff
changeset | 38 | Isabelle_System.bash(File.bash_path(cygwin_exe) + " -h </dev/null >/dev/null").check | 
| 65071 | 39 | |
| 40 | val res = | |
| 41 | progress.bash( | |
| 42 | File.bash_path(cygwin_exe) + " --site " + Bash.string(mirror) + " --no-verify" + | |
| 43 | " --local-package-dir 'C:\\temp'" + | |
| 72036 | 44 | " --root " + File.bash_platform_path(cygwin) + | 
| 65071 | 45 |               " --packages " + quote((packages ::: more_packages).mkString(",")) +
 | 
| 46 | " --no-shortcuts --no-startmenu --no-desktop --quiet-mode", | |
| 47 | echo = true) | |
| 48 |         if (!res.ok || !cygwin_etc.is_dir) error("Failed")
 | |
| 49 | ||
| 50 |         for (name <- List("hosts", "protocols", "services", "networks", "passwd", "group"))
 | |
| 51 | (cygwin_etc + Path.explode(name)).file.delete | |
| 52 | ||
| 53 |         (cygwin + Path.explode("Cygwin.bat")).file.delete
 | |
| 54 | ||
| 73649 | 55 | val archive = "cygwin-" + Date.Format.alt_date(Date.now()) + ".tar.gz" | 
| 69425 | 56 |         Isabelle_System.gnutar("-czf " + Bash.string(archive) + " cygwin", dir = tmp_dir).check
 | 
| 65071 | 57 | }) | 
| 58 | } | |
| 59 | ||
| 60 | ||
| 61 | /* Isabelle tool wrapper */ | |
| 62 | ||
| 63 | val isabelle_tool = | |
| 72763 | 64 |     Isabelle_Tool("build_cygwin", "produce pre-canned Cygwin distribution for Isabelle",
 | 
| 65 | Scala_Project.here, args => | |
| 65071 | 66 |     {
 | 
| 67 | var mirror = default_mirror | |
| 68 | var more_packages: List[String] = Nil | |
| 69 | ||
| 70 | val getopts = | |
| 71 |         Getopts("""
 | |
| 72 | Usage: isabelle build_cygwin [OPTIONS] | |
| 73 | ||
| 74 | Options are: | |
| 75 | -R MIRROR Cygwin mirror site (default """ + quote(default_mirror) + """) | |
| 76 | -p NAME additional Cygwin package | |
| 77 | ||
| 78 | Produce pre-canned Cygwin distribution for Isabelle: this requires | |
| 79 | Windows administrator mode. | |
| 80 | """, | |
| 81 | "R:" -> (arg => mirror = arg), | |
| 82 | "p:" -> (arg => more_packages ::= arg)) | |
| 83 | ||
| 84 | val more_args = getopts(args) | |
| 85 | if (more_args.nonEmpty) getopts.usage() | |
| 86 | ||
| 87 | build_cygwin(new Console_Progress(), mirror = mirror, more_packages = more_packages) | |
| 69277 
258bef08b31e
support for user-defined Isabelle/Scala command-line tools;
 wenzelm parents: 
68374diff
changeset | 88 | }) | 
| 65071 | 89 | } |