src/Pure/Admin/build_polyml.scala
author wenzelm
Tue, 07 Apr 2020 21:49:36 +0200
changeset 71726 a5fda30edae2
parent 71686 eb44cf7ae926
child 72351 68902f8a1ef0
permissions -rw-r--r--
clarified signature: more uniform treatment of stopped/interrupted state;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Admin/build_polyml.scala
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     3
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     4
Build Poly/ML from sources.
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     5
*/
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     6
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     7
package isabelle
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     8
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
     9
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    10
import scala.util.matching.Regex
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    11
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    12
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    13
object Build_PolyML
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    14
{
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
    15
  /** platform-specific build **/
64496
wenzelm
parents: 64495
diff changeset
    16
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    17
  sealed case class Platform_Info(
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    18
    options: List[String] = Nil,
64487
b843bcdd40f0 more precise environment (for Windows);
wenzelm
parents: 64486
diff changeset
    19
    setup: String = "",
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    20
    copy_files: List[String] = Nil,
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    21
    ldd_pattern: Option[(String, Regex)] = None)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    22
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    23
  private val platform_info = Map(
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    24
    "linux" ->
67580
eb64467e8bcf more robust access to shared libraries for poly executable: avoid global change of LD_LIBRARY_PATH (e.g. relevant for subprocesses);
wenzelm
parents: 66998
diff changeset
    25
      Platform_Info(
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    26
        options = List("LDFLAGS=-Wl,-rpath,_DUMMY_"),
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    27
        ldd_pattern = Some(("ldd", """\s*libgmp.*=>\s*(\S+).*""".r))),
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    28
    "darwin" ->
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    29
      Platform_Info(
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    30
        options =
64484
784e28e4dc57 proper options;
wenzelm
parents: 64483
diff changeset
    31
          List("--build=x86_64-darwin", "CFLAGS=-arch x86_64 -O3 -I../libffi/include",
784e28e4dc57 proper options;
wenzelm
parents: 64483
diff changeset
    32
            "CXXFLAGS=-arch x86_64 -O3 -I../libffi/include", "CCASFLAGS=-arch x86_64",
67600
d515b6140381 no --enable-shared for x86_64-darwin: does not work on some test machine;
wenzelm
parents: 67599
diff changeset
    33
            "LDFLAGS=-segprot POLY rwx rwx"),
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    34
        setup = "PATH=/usr/bin:/bin:/usr/sbin:/sbin",
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    35
        ldd_pattern = Some(("otool -L", """\s*(\S+lib(?:polyml|gmp).*dylib).*""".r))),
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    36
    "windows" ->
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    37
      Platform_Info(
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    38
        options =
67597
fe6dc6d8451a more robust options;
wenzelm
parents: 67596
diff changeset
    39
          List("--host=x86_64-w64-mingw32", "CPPFLAGS=-I/mingw64/include", "--disable-windows-gui"),
64494
979520c83f30 proper CONFIG_SITE for msys;
wenzelm
parents: 64493
diff changeset
    40
        setup =
979520c83f30 proper CONFIG_SITE for msys;
wenzelm
parents: 64493
diff changeset
    41
          """PATH=/usr/bin:/bin:/mingw64/bin
71117
2f6b092bbd25 updated MinGW installation: requires Cygwin from Isabelle2018 to avoid problems with address relocation;
wenzelm
parents: 70977
diff changeset
    42
            export CONFIG_SITE=/mingw64/etc/config.site""",
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    43
        copy_files =
64504
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    44
          List("$MSYS/mingw64/bin/libgcc_s_seh-1.dll",
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    45
            "$MSYS/mingw64/bin/libgmp-10.dll",
71117
2f6b092bbd25 updated MinGW installation: requires Cygwin from Isabelle2018 to avoid problems with address relocation;
wenzelm
parents: 70977
diff changeset
    46
            "$MSYS/mingw64/bin/libstdc++-6.dll",
2f6b092bbd25 updated MinGW installation: requires Cygwin from Isabelle2018 to avoid problems with address relocation;
wenzelm
parents: 70977
diff changeset
    47
            "$MSYS/mingw64/bin/libwinpthread-1.dll")))
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    48
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    49
  def build_polyml(
64489
db1bc2732554 clarified command-line;
wenzelm
parents: 64488
diff changeset
    50
    root: Path,
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
    51
    sha1_root: Option[Path] = None,
71726
a5fda30edae2 clarified signature: more uniform treatment of stopped/interrupted state;
wenzelm
parents: 71686
diff changeset
    52
    progress: Progress = new Progress,
64493
a2eebcc8bb69 clarified platform selection;
wenzelm
parents: 64492
diff changeset
    53
    arch_64: Boolean = false,
64485
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
    54
    options: List[String] = Nil,
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
    55
    msys_root: Option[Path] = None)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    56
  {
64489
db1bc2732554 clarified command-line;
wenzelm
parents: 64488
diff changeset
    57
    if (!((root + Path.explode("configure")).is_file && (root + Path.explode("PolyML")).is_dir))
db1bc2732554 clarified command-line;
wenzelm
parents: 64488
diff changeset
    58
      error("Bad Poly/ML root directory: " + root)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    59
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    60
    val platform_arch = if (arch_64) "x86_64" else "x86_64_32"
69726
461f0615faa3 clarified signature;
wenzelm
parents: 69704
diff changeset
    61
    val platform_os = Platform.os_name
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    62
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    63
    val platform = platform_arch + "-" + platform_os
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    64
    val platform_64 = "x86_64-" + platform_os
64493
a2eebcc8bb69 clarified platform selection;
wenzelm
parents: 64492
diff changeset
    65
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    66
    val info =
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    67
      platform_info.get(platform_os) getOrElse
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
    68
        error("Bad OS platform: " + quote(platform_os))
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
    69
64504
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    70
    val settings =
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    71
      msys_root match {
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    72
        case None if Platform.is_windows =>
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    73
          error("Windows requires specification of msys root directory")
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    74
        case None => Isabelle_System.settings()
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    75
        case Some(msys) => Isabelle_System.settings() + ("MSYS" -> msys.expand.implode)
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    76
      }
64492
98215fa4f8d1 more robust Windows platform;
wenzelm
parents: 64491
diff changeset
    77
70977
397533bf0c3f clarified error;
wenzelm
parents: 69726
diff changeset
    78
    if (Platform.is_linux && !Isabelle_System.bash("chrpath -v").ok) {
397533bf0c3f clarified error;
wenzelm
parents: 69726
diff changeset
    79
      error("""Missing "chrpath" executable on Linux""")
397533bf0c3f clarified error;
wenzelm
parents: 69726
diff changeset
    80
    }
397533bf0c3f clarified error;
wenzelm
parents: 69726
diff changeset
    81
64491
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
    82
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
    83
    /* bash */
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
    84
64504
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    85
    def bash(
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    86
      cwd: Path, script: String, redirect: Boolean = false, echo: Boolean = false): Process_Result =
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    87
    {
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    88
      val script1 =
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    89
        msys_root match {
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    90
          case None => script
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    91
          case Some(msys) =>
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    92
            File.bash_path(msys + Path.explode("usr/bin/bash")) + " -c " + Bash.string(script)
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    93
        }
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    94
      progress.bash(script1, cwd = cwd.file, redirect = redirect, echo = echo)
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
    95
    }
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
    96
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
    97
64491
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
    98
    /* configure and make */
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
    99
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   100
    val configure_options =
67783
839de121665c more robust build: prevent problems seen with Poly/ML eb94e2820013 on Mac OS X;
wenzelm
parents: 67609
diff changeset
   101
      List("--disable-shared", "--enable-intinf-as-int", "--with-gmp") :::
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
   102
        info.options ::: options ::: (if (arch_64) Nil else List("--enable-compact32bit"))
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   103
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   104
    bash(root,
64487
b843bcdd40f0 more precise environment (for Windows);
wenzelm
parents: 64486
diff changeset
   105
      info.setup + "\n" +
64485
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   106
      """
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   107
        [ -f Makefile ] && make distclean
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   108
        {
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   109
          ./configure --prefix="$PWD/target" """ + Bash.strings(configure_options) + """
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   110
          rm -rf target
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   111
          make compiler && make compiler && make install
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   112
        } || { echo "Build failed" >&2; exit 2; }
64501
234571db1b90 tuned output;
wenzelm
parents: 64500
diff changeset
   113
      """, redirect = true, echo = true).check
64485
e996c0a5eca9 support other bash executable (notably for msys on Windows);
wenzelm
parents: 64484
diff changeset
   114
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   115
    val ldd_files =
66998
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   116
    {
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
   117
      info.ldd_pattern match {
66998
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   118
        case Some((ldd, pattern)) =>
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   119
          val lines = bash(root, ldd + " target/bin/poly").check.out_lines
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   120
          for { line <- lines; List(lib) <- pattern.unapplySeq(line) } yield lib
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   121
        case None => Nil
64491
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
   122
      }
66998
8905114fd23b support for libgmp on x86_64-darwin;
wenzelm
parents: 65880
diff changeset
   123
    }
64491
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
   124
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
   125
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   126
    /* sha1 library */
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   127
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   128
    val sha1_files =
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   129
      if (sha1_root.isDefined) {
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   130
        val dir1 = sha1_root.get
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
   131
        bash(dir1, "./build " + platform_64, redirect = true, echo = true).check
64505
545a7ab3c35f optional component setup;
wenzelm
parents: 64504
diff changeset
   132
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
   133
        val dir2 = dir1 + Path.explode(platform_64)
64495
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   134
        File.read_dir(dir2).map(entry => dir2.implode + "/" + entry)
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   135
      }
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   136
      else Nil
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   137
754e1b4634c3 build sha1 library;
wenzelm
parents: 64494
diff changeset
   138
64491
6a1a1bbfcb93 copy libgmp on Linux;
wenzelm
parents: 64490
diff changeset
   139
    /* target */
64484
784e28e4dc57 proper options;
wenzelm
parents: 64483
diff changeset
   140
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   141
    val target = Path.explode(platform)
64488
bc77e19aad44 no backup of generated stuff;
wenzelm
parents: 64487
diff changeset
   142
    Isabelle_System.rm_tree(target)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   143
    Isabelle_System.mkdirs(target)
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   144
67592
66253039d5ca enforce shared libpoly on all platforms, with File.copy before File.move;
wenzelm
parents: 67589
diff changeset
   145
    for (file <- info.copy_files ::: ldd_files ::: sha1_files)
66253039d5ca enforce shared libpoly on all platforms, with File.copy before File.move;
wenzelm
parents: 67589
diff changeset
   146
      File.copy(Path.explode(file).expand_env(settings), target)
66253039d5ca enforce shared libpoly on all platforms, with File.copy before File.move;
wenzelm
parents: 67589
diff changeset
   147
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   148
    for {
64484
784e28e4dc57 proper options;
wenzelm
parents: 64483
diff changeset
   149
      d <- List("target/bin", "target/lib")
64489
db1bc2732554 clarified command-line;
wenzelm
parents: 64488
diff changeset
   150
      dir = root + Path.explode(d)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   151
      entry <- File.read_dir(dir)
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   152
    } File.move(dir + Path.explode(entry), target)
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   153
67580
eb64467e8bcf more robust access to shared libraries for poly executable: avoid global change of LD_LIBRARY_PATH (e.g. relevant for subprocesses);
wenzelm
parents: 66998
diff changeset
   154
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   155
    /* poly: library path */
67580
eb64467e8bcf more robust access to shared libraries for poly executable: avoid global change of LD_LIBRARY_PATH (e.g. relevant for subprocesses);
wenzelm
parents: 66998
diff changeset
   156
67582
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   157
    if (Platform.is_linux) {
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   158
      bash(target, "chrpath -r '$ORIGIN' poly", echo = true).check
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   159
    }
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   160
    else if (Platform.is_macos) {
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   161
      for (file <- ldd_files) {
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   162
        bash(target,
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   163
          """install_name_tool -change """ + Bash.string(file) + " " +
69366
b6dacf6eabe3 clarified signature;
wenzelm
parents: 69277
diff changeset
   164
            Bash.string("@executable_path/" + Path.explode(file).file_name) + " poly").check
67582
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   165
      }
bf5c69acf2be built-in library path for (optional) libgmp on macos;
wenzelm
parents: 67581
diff changeset
   166
    }
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   167
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   168
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   169
    /* polyc: directory prefix */
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   170
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   171
    {
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   172
      val polyc_path = target + Path.explode("polyc")
67587
wenzelm
parents: 67584
diff changeset
   173
wenzelm
parents: 67584
diff changeset
   174
      val Header = "#! */bin/sh".r
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   175
      val polyc_patched =
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   176
        split_lines(File.read(polyc_path)) match {
67587
wenzelm
parents: 67584
diff changeset
   177
          case Header() :: lines =>
wenzelm
parents: 67584
diff changeset
   178
            val lines1 =
wenzelm
parents: 67584
diff changeset
   179
              lines.map(line =>
wenzelm
parents: 67584
diff changeset
   180
                if (line.startsWith("prefix=")) "prefix=\"$(cd \"$(dirname \"$0\")\"; pwd)\""
wenzelm
parents: 67584
diff changeset
   181
                else if (line.startsWith("BINDIR=")) "BINDIR=\"$prefix\""
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   182
                else if (line.startsWith("LIBDIR=")) "LIBDIR=\"$prefix\""
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   183
                else line)
67587
wenzelm
parents: 67584
diff changeset
   184
            cat_lines("#!/usr/bin/env bash" ::lines1)
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   185
          case lines =>
67587
wenzelm
parents: 67584
diff changeset
   186
            error(cat_lines("Cannot patch polyc -- undetected header:" :: lines.take(3)))
67584
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   187
        }
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   188
      File.write(polyc_path, polyc_patched)
252d33ee6778 patch polyc: avoid hardwired directory prefix;
wenzelm
parents: 67582
diff changeset
   189
    }
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   190
  }
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   191
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   192
64496
wenzelm
parents: 64495
diff changeset
   193
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   194
  /** skeleton for component **/
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   195
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   196
  private def extract_sources(source_archive: Path, component_dir: Path) =
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   197
  {
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   198
    if (source_archive.get_ext == "zip") {
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   199
      Isabelle_System.bash(
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   200
        "unzip -x " + File.bash_path(source_archive.absolute), cwd = component_dir.file).check
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   201
    }
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   202
    else {
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   203
      Isabelle_System.gnutar("-xzf " + File.bash_path(source_archive), dir = component_dir).check
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   204
    }
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   205
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   206
    val src_dir = component_dir + Path.explode("src")
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   207
    File.read_dir(component_dir) match {
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   208
      case List(s) => File.move(component_dir + Path.basic(s), src_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   209
      case _ => error("Source archive contains multiple directories")
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   210
    }
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   211
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   212
    val lines = split_lines(File.read(src_dir + Path.explode("RootX86.ML")))
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   213
    val ml_files =
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   214
      for {
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   215
        line <- lines
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   216
        rest <- Library.try_unprefix("use", line)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   217
      } yield "ML_file" + rest
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   218
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   219
    File.write(src_dir + Path.explode("ROOT.ML"),
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   220
"""(* Poly/ML Compiler root file.
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   221
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   222
When this file is open in the Prover IDE, the ML files of the Poly/ML
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   223
compiler can be explored interactively. This is a separate copy: it does
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   224
not affect the running ML session. *)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   225
""" + ml_files.mkString("\n", "\n", "\n"))
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   226
  }
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   227
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   228
  def build_polyml_component(
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   229
    source_archive: Path,
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   230
    component_dir: Path,
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   231
    sha1_root: Option[Path] = None)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   232
  {
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   233
    if (component_dir.is_file || component_dir.is_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   234
      error("Component directory already exists: " + component_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   235
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   236
    Isabelle_System.mkdirs(component_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   237
    extract_sources(source_archive, component_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   238
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   239
    File.copy(Path.explode("~~/Admin/polyml/README"), component_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   240
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   241
    val etc_dir = component_dir + Path.explode("etc")
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   242
    Isabelle_System.mkdirs(etc_dir)
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   243
    File.copy(Path.explode("~~/Admin/polyml/settings"), etc_dir)
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   244
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   245
    sha1_root match {
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   246
      case Some(dir) =>
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   247
        Mercurial.repository(dir).archive(File.standard_path(component_dir + Path.explode("sha1")))
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   248
      case None =>
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   249
    }
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   250
  }
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   251
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   252
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   253
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   254
  /** Isabelle tool wrappers **/
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   255
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   256
  val isabelle_tool1 =
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   257
    Isabelle_Tool("build_polyml", "build Poly/ML from sources", args =>
64500
159ea1055b39 back to regular Isabelle tool (reverting abc34a149690);
wenzelm
parents: 64499
diff changeset
   258
    {
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   259
      var msys_root: Option[Path] = None
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   260
      var arch_64 = false
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   261
      var sha1_root: Option[Path] = None
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   262
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   263
      val getopts = Getopts("""
64489
db1bc2732554 clarified command-line;
wenzelm
parents: 64488
diff changeset
   264
Usage: isabelle build_polyml [OPTIONS] ROOT [CONFIGURE_OPTIONS]
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   265
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   266
  Options are:
64504
e4707c2655eb clarified msys root;
wenzelm
parents: 64503
diff changeset
   267
    -M DIR       msys root directory (for Windows)
69704
3fb94d9b87b0 updated polyml platform: 32=x86_64_32;
wenzelm
parents: 69691
diff changeset
   268
    -m ARCH      processor architecture (32=x86_64_32, 64=x86_64, default: 32)
69691
9c6651cd6141 clarified URLs: prefer sketis over bitbucket;
wenzelm
parents: 69366
diff changeset
   269
    -s DIR       sha1 sources, see https://isabelle.sketis.net/repos/sha1
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   270
64499
wenzelm
parents: 64496
diff changeset
   271
  Build Poly/ML in the ROOT directory of its sources, with additional
67593
5efb88c90051 clarified command-line defaults;
wenzelm
parents: 67592
diff changeset
   272
  CONFIGURE_OPTIONS (e.g. --without-gmp).
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   273
""",
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   274
        "M:" -> (arg => msys_root = Some(Path.explode(arg))),
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   275
        "m:" ->
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   276
          {
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   277
            case "32" | "x86_64_32" => arch_64 = false
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   278
            case "64" | "x86_64" => arch_64 = true
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   279
            case bad => error("Bad processor architecture: " + quote(bad))
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   280
          },
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   281
        "s:" -> (arg => sha1_root = Some(Path.explode(arg))))
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   282
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   283
      val more_args = getopts(args)
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   284
      val (root, options) =
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   285
        more_args match {
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   286
          case root :: options => (Path.explode(root), options)
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   287
          case Nil => getopts.usage()
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   288
        }
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   289
      build_polyml(root, sha1_root = sha1_root, progress = new Console_Progress,
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   290
        arch_64 = arch_64, options = options, msys_root = msys_root)
69277
258bef08b31e support for user-defined Isabelle/Scala command-line tools;
wenzelm
parents: 67783
diff changeset
   291
    })
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   292
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   293
  val isabelle_tool2 =
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   294
    Isabelle_Tool("build_polyml_component", "make skeleton for Poly/ML component", args =>
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   295
    {
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   296
      var sha1_root: Option[Path] = None
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   297
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   298
      val getopts = Getopts("""
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   299
Usage: isabelle build_polyml_component [OPTIONS] SOURCE_ARCHIVE COMPONENT_DIR
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   300
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   301
  Options are:
69691
9c6651cd6141 clarified URLs: prefer sketis over bitbucket;
wenzelm
parents: 69366
diff changeset
   302
    -s DIR       sha1 sources, see https://isabelle.sketis.net/repos/sha1
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   303
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   304
  Make skeleton for Poly/ML component, based on official source archive
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   305
  (zip or tar.gz).
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   306
""",
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   307
        "s:" -> (arg => sha1_root = Some(Path.explode(arg))))
65880
54c6ec4166a4 clarified build_polyml_component;
wenzelm
parents: 64909
diff changeset
   308
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   309
      val more_args = getopts(args)
71396
c1c61d0d8e7c clarified build_polyml_component: include IDE entry point for ML compiler;
wenzelm
parents: 71117
diff changeset
   310
71686
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   311
      val (source_archive, component_dir) =
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   312
        more_args match {
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   313
          case List(archive, dir) => (Path.explode(archive), Path.explode(dir))
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   314
          case _ => getopts.usage()
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   315
        }
eb44cf7ae926 tuned -- Command_Line.tool is already part of Isabelle_Tool;
wenzelm
parents: 71632
diff changeset
   316
      build_polyml_component(source_archive, component_dir, sha1_root = sha1_root)
69277
258bef08b31e support for user-defined Isabelle/Scala command-line tools;
wenzelm
parents: 67783
diff changeset
   317
    })
64483
bba1d341bdf6 build_polyml in Scala;
wenzelm
parents:
diff changeset
   318
}