src/Pure/Tools/build_history.scala
author wenzelm
Sun, 09 Oct 2016 14:19:46 +0200
changeset 64118 0996fab2ec03
parent 64117 c2b41b073d8a
child 64119 8094eaa38d4b
permissions -rw-r--r--
modernized;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/build_history.scala
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     3
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     4
Build other history versions.
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     5
*/
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     6
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     7
package isabelle
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     8
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
     9
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
    10
import java.io.{File => JFile}
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    11
import java.time.format.DateTimeFormatter
64118
0996fab2ec03 modernized;
wenzelm
parents: 64117
diff changeset
    12
import java.util.Locale
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
    13
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
    14
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
    15
object Build_History
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
    16
{
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    17
  /* log files */
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    18
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    19
  val BUILD_HISTORY = "build_history"
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    20
  val META_INFO = "\fmeta_info = "
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    21
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    22
  def log_date(date: Date): String =
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    23
    String.format(Locale.ROOT, "%s.%05d",
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    24
      DateTimeFormatter.ofPattern("yyyy-MM-dd").format(date.rep),
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    25
      new java.lang.Long((date.time - date.midnight.time).ms / 1000))
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    26
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    27
  def log_name(date: Date, parts: String*): String =
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    28
    (BUILD_HISTORY :: log_date(date) :: parts.toList).mkString("", "_", ".log.gz")
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    29
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    30
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    31
64050
wenzelm
parents: 64049
diff changeset
    32
  /** other Isabelle environment **/
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    33
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    34
  private class Other_Isabelle(progress: Progress, isabelle_home: Path, isabelle_identifier: String)
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    35
  {
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    36
    other_isabelle =>
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    37
64050
wenzelm
parents: 64049
diff changeset
    38
wenzelm
parents: 64049
diff changeset
    39
    /* static system */
wenzelm
parents: 64049
diff changeset
    40
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    41
    def bash(script: String, redirect: Boolean = false, echo: Boolean = false): Process_Result =
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    42
      Isabelle_System.bash(
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    43
        "export ISABELLE_IDENTIFIER=" + File.bash_string(isabelle_identifier) + "\n" + script,
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    44
        env = null, cwd = isabelle_home.file, redirect = redirect,
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    45
        progress_stdout = progress.echo_if(echo, _),
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    46
        progress_stderr = progress.echo_if(echo, _))
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    47
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
    48
    def copy_dir(dir1: Path, dir2: Path): Unit =
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
    49
      bash("cp -a " + File.bash_path(dir1) + " " + File.bash_path(dir2)).check
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
    50
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    51
    def apply(cmdline: String, redirect: Boolean = false, echo: Boolean = false): Process_Result =
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    52
      bash("bin/isabelle " + cmdline, redirect, echo)
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    53
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    54
    def resolve_components(echo: Boolean): Unit =
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    55
      other_isabelle("components -a", redirect = true, echo = echo).check
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    56
64050
wenzelm
parents: 64049
diff changeset
    57
    val isabelle_home_user: Path =
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    58
      Path.explode(other_isabelle("getenv -b ISABELLE_HOME_USER").check.out)
64050
wenzelm
parents: 64049
diff changeset
    59
wenzelm
parents: 64049
diff changeset
    60
    val etc_settings: Path = isabelle_home_user + Path.explode("etc/settings")
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    61
    val log_dir: Path = isabelle_home_user + Path.explode("log")
64050
wenzelm
parents: 64049
diff changeset
    62
wenzelm
parents: 64049
diff changeset
    63
wenzelm
parents: 64049
diff changeset
    64
    /* reset settings */
wenzelm
parents: 64049
diff changeset
    65
wenzelm
parents: 64049
diff changeset
    66
    def reset_settings(components_base: String, nonfree: Boolean)
wenzelm
parents: 64049
diff changeset
    67
    {
wenzelm
parents: 64049
diff changeset
    68
      if (etc_settings.is_file && !File.read(etc_settings).startsWith("# generated by Isabelle"))
wenzelm
parents: 64049
diff changeset
    69
        error("Cannot proceed with existing user settings file: " + etc_settings)
wenzelm
parents: 64049
diff changeset
    70
wenzelm
parents: 64049
diff changeset
    71
      Isabelle_System.mkdirs(etc_settings.dir)
wenzelm
parents: 64049
diff changeset
    72
      File.write(etc_settings,
64118
0996fab2ec03 modernized;
wenzelm
parents: 64117
diff changeset
    73
        "# generated by Isabelle " + Date.Format.default(Date.now()) + "\n" +
64050
wenzelm
parents: 64049
diff changeset
    74
        "#-*- shell-script -*- :mode=shellscript:\n")
wenzelm
parents: 64049
diff changeset
    75
wenzelm
parents: 64049
diff changeset
    76
      val component_settings =
wenzelm
parents: 64049
diff changeset
    77
      {
wenzelm
parents: 64049
diff changeset
    78
        val components_base_path =
wenzelm
parents: 64049
diff changeset
    79
          if (components_base == "") isabelle_home_user.dir + Path.explode("contrib")
wenzelm
parents: 64049
diff changeset
    80
          else Path.explode(components_base).expand
wenzelm
parents: 64049
diff changeset
    81
wenzelm
parents: 64049
diff changeset
    82
        val catalogs =
wenzelm
parents: 64049
diff changeset
    83
          if (nonfree) List("main", "optional", "nonfree") else List("main", "optional")
wenzelm
parents: 64049
diff changeset
    84
wenzelm
parents: 64049
diff changeset
    85
        catalogs.map(catalog =>
wenzelm
parents: 64049
diff changeset
    86
          "init_components " + File.bash_path(components_base_path) +
wenzelm
parents: 64049
diff changeset
    87
            " \"$ISABELLE_HOME/Admin/components/" + catalog + "\"")
wenzelm
parents: 64049
diff changeset
    88
      }
wenzelm
parents: 64049
diff changeset
    89
      File.append(etc_settings, "\n" + Library.terminate_lines(component_settings))
wenzelm
parents: 64049
diff changeset
    90
    }
wenzelm
parents: 64049
diff changeset
    91
wenzelm
parents: 64049
diff changeset
    92
wenzelm
parents: 64049
diff changeset
    93
    /* augment settings */
wenzelm
parents: 64049
diff changeset
    94
wenzelm
parents: 64049
diff changeset
    95
    def augment_settings(
wenzelm
parents: 64049
diff changeset
    96
      threads: Int,
wenzelm
parents: 64049
diff changeset
    97
      arch_64: Boolean = false,
wenzelm
parents: 64049
diff changeset
    98
      heap: Int = default_heap,
wenzelm
parents: 64049
diff changeset
    99
      max_heap: Option[Int] = None,
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   100
      more_settings: List[String]): String =
64050
wenzelm
parents: 64049
diff changeset
   101
    {
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   102
      val (ml_platform, ml_settings) =
64050
wenzelm
parents: 64049
diff changeset
   103
      {
wenzelm
parents: 64049
diff changeset
   104
        val windows_32 = "x86-windows"
wenzelm
parents: 64049
diff changeset
   105
        val windows_64 = "x86_64-windows"
wenzelm
parents: 64049
diff changeset
   106
        val platform_32 = other_isabelle("getenv -b ISABELLE_PLATFORM32").check.out
wenzelm
parents: 64049
diff changeset
   107
        val platform_64 = other_isabelle("getenv -b ISABELLE_PLATFORM64").check.out
wenzelm
parents: 64049
diff changeset
   108
        val platform_family = other_isabelle("getenv -b ISABELLE_PLATFORM_FAMILY").check.out
wenzelm
parents: 64049
diff changeset
   109
wenzelm
parents: 64049
diff changeset
   110
        val polyml_home =
wenzelm
parents: 64049
diff changeset
   111
          try { Path.explode(other_isabelle("getenv -b ML_HOME").check.out).dir }
wenzelm
parents: 64049
diff changeset
   112
          catch { case ERROR(msg) => error("Bad ML_HOME: " + msg) }
wenzelm
parents: 64049
diff changeset
   113
wenzelm
parents: 64049
diff changeset
   114
        def ml_home(platform: String): Path = polyml_home + Path.explode(platform)
wenzelm
parents: 64049
diff changeset
   115
wenzelm
parents: 64049
diff changeset
   116
        def err(platform: String): Nothing =
wenzelm
parents: 64049
diff changeset
   117
          error("Platform " + platform + " unavailable on this machine")
wenzelm
parents: 64049
diff changeset
   118
wenzelm
parents: 64049
diff changeset
   119
        def check_dir(platform: String): Boolean =
wenzelm
parents: 64049
diff changeset
   120
          platform != "" && ml_home(platform).is_dir
wenzelm
parents: 64049
diff changeset
   121
wenzelm
parents: 64049
diff changeset
   122
        val ml_platform =
wenzelm
parents: 64049
diff changeset
   123
          if (Platform.is_windows && arch_64) {
wenzelm
parents: 64049
diff changeset
   124
            if (check_dir(windows_64)) windows_64 else err(windows_64)
wenzelm
parents: 64049
diff changeset
   125
          }
wenzelm
parents: 64049
diff changeset
   126
          else if (Platform.is_windows && !arch_64) {
wenzelm
parents: 64049
diff changeset
   127
            if (check_dir(windows_32)) windows_32
wenzelm
parents: 64049
diff changeset
   128
            else platform_32  // x86-cygwin
wenzelm
parents: 64049
diff changeset
   129
          }
wenzelm
parents: 64049
diff changeset
   130
          else {
wenzelm
parents: 64049
diff changeset
   131
            val (platform, platform_name) =
wenzelm
parents: 64049
diff changeset
   132
              if (arch_64) (platform_64, "x86_64-" + platform_family)
wenzelm
parents: 64049
diff changeset
   133
              else (platform_32, "x86-" + platform_family)
wenzelm
parents: 64049
diff changeset
   134
            if (check_dir(platform)) platform else err(platform_name)
wenzelm
parents: 64049
diff changeset
   135
          }
wenzelm
parents: 64049
diff changeset
   136
wenzelm
parents: 64049
diff changeset
   137
        val ml_options =
wenzelm
parents: 64049
diff changeset
   138
          "--minheap " + heap + (if (max_heap.isDefined) " --maxheap " + max_heap.get else "") +
wenzelm
parents: 64049
diff changeset
   139
          " --gcthreads " + threads +
wenzelm
parents: 64049
diff changeset
   140
          (if (ml_platform.endsWith("-windows")) " --codepage utf8" else "")
wenzelm
parents: 64049
diff changeset
   141
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   142
        (ml_platform,
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   143
          List(
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   144
            "ML_HOME=" + File.bash_path(ml_home(ml_platform)),
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   145
            "ML_PLATFORM=" + quote(ml_platform),
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   146
            "ML_OPTIONS=" + quote(ml_options)))
64050
wenzelm
parents: 64049
diff changeset
   147
      }
wenzelm
parents: 64049
diff changeset
   148
wenzelm
parents: 64049
diff changeset
   149
      val thread_settings =
wenzelm
parents: 64049
diff changeset
   150
        List(
wenzelm
parents: 64049
diff changeset
   151
          "ISABELLE_JAVA_SYSTEM_OPTIONS=\"$ISABELLE_JAVA_SYSTEM_OPTIONS -Disabelle.threads=" + threads + "\"",
wenzelm
parents: 64049
diff changeset
   152
          "ISABELLE_BUILD_OPTIONS=\"threads=" + threads + "\"")
wenzelm
parents: 64049
diff changeset
   153
wenzelm
parents: 64049
diff changeset
   154
      val settings =
wenzelm
parents: 64049
diff changeset
   155
        List(ml_settings, thread_settings) :::
wenzelm
parents: 64049
diff changeset
   156
          (if (more_settings.isEmpty) Nil else List(more_settings))
wenzelm
parents: 64049
diff changeset
   157
wenzelm
parents: 64049
diff changeset
   158
      File.append(etc_settings, "\n" + cat_lines(settings.map(Library.terminate_lines(_))))
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   159
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   160
      ml_platform
64050
wenzelm
parents: 64049
diff changeset
   161
    }
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   162
  }
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   163
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   164
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   165
64050
wenzelm
parents: 64049
diff changeset
   166
  /** build_history **/
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   167
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   168
  private val default_rev = "tip"
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   169
  private val default_threads = 1
64034
51bf28aa18a5 more ambitious default as in former isatest;
wenzelm
parents: 64032
diff changeset
   170
  private val default_heap = 1000
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   171
  private val default_isabelle_identifier = "build_history"
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   172
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   173
  def build_history(
64038
f69ce5e7ea7f incremental output;
wenzelm
parents: 64037
diff changeset
   174
    progress: Progress,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   175
    hg: Mercurial.Repository,
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   176
    rev: String = default_rev,
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   177
    isabelle_identifier: String = default_isabelle_identifier,
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   178
    components_base: String = "",
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   179
    fresh: Boolean = false,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   180
    nonfree: Boolean = false,
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   181
    multicore_base: Boolean = false,
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   182
    threads_list: List[Int] = List(default_threads),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   183
    arch_64: Boolean = false,
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   184
    heap: Int = default_heap,
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   185
    max_heap: Option[Int] = None,
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   186
    more_settings: List[String] = Nil,
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   187
    verbose: Boolean = false,
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   188
    build_args: List[String] = Nil): List[Process_Result] =
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   189
  {
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   190
    /* sanity checks */
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   191
64046
5a6a7401c48b clarified sanity checks;
wenzelm
parents: 64044
diff changeset
   192
    if (File.eq(Path.explode("~~").file, hg.root.file))
5a6a7401c48b clarified sanity checks;
wenzelm
parents: 64044
diff changeset
   193
      error("Repository coincides with ISABELLE_HOME=" + Path.explode("~~").expand)
5a6a7401c48b clarified sanity checks;
wenzelm
parents: 64044
diff changeset
   194
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   195
    for (threads <- threads_list if threads < 1) error("Bad threads value < 1: " + threads)
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   196
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   197
    if (heap < 100) error("Bad heap value < 100: " + heap)
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   198
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   199
    if (max_heap.isDefined && max_heap.get < heap)
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   200
      error("Bad max_heap value < heap: " + max_heap.get)
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   201
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   202
    System.getenv("ISABELLE_SETTINGS_PRESENT") match {
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   203
      case null | "" =>
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   204
      case _ => error("Cannot run build_history within existing Isabelle settings environment")
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   205
    }
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   206
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   207
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   208
    /* init repository */
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   209
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   210
    hg.update(rev = rev, clean = true)
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   211
    progress.echo_if(verbose, hg.log(rev, options = "-l1"))
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   212
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   213
    val isabelle_version = hg.identify(rev, options = "-i")
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
   214
    val other_isabelle = new Other_Isabelle(progress, hg.root, isabelle_identifier)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   215
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   216
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   217
    /* main */
64043
44b6c620c371 more thorought update of components;
wenzelm
parents: 64040
diff changeset
   218
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   219
    val build_history_date = Date.now()
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   220
    val build_host = Library.trim_line(Isabelle_System.bash("hostname").check.out)
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   221
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   222
    var first_build = true
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   223
    for (threads <- threads_list) yield
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   224
    {
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   225
      /* init settings */
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   226
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   227
      other_isabelle.reset_settings(components_base, nonfree)
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   228
      other_isabelle.resolve_components(verbose)
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   229
      val ml_platform =
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   230
        other_isabelle.augment_settings(threads, arch_64, heap, max_heap, more_settings)
64043
44b6c620c371 more thorought update of components;
wenzelm
parents: 64040
diff changeset
   231
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   232
      val isabelle_output = Path.explode(other_isabelle("getenv -b ISABELLE_OUTPUT").check.out)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   233
      val isabelle_output_log = isabelle_output + Path.explode("log")
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   234
      val isabelle_base_log = isabelle_output + Path.explode("../base_log")
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   235
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   236
      if (first_build) {
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   237
        other_isabelle.resolve_components(verbose)
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   238
        other_isabelle.bash(
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   239
          "env PATH=\"" + File.bash_path(Path.explode("~~/lib/dummy_stty").expand) + ":$PATH\" " +
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   240
            "bin/isabelle jedit -b" + (if (fresh) " -f" else ""),
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   241
          redirect = true, echo = verbose).check
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   242
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   243
        Isabelle_System.rm_tree(isabelle_base_log.file)
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   244
      }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   245
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   246
      Isabelle_System.rm_tree(isabelle_output.file)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   247
      Isabelle_System.mkdirs(isabelle_output)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   248
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   249
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   250
      /* build */
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   251
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   252
      if (multicore_base && !first_build && isabelle_base_log.is_dir)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   253
        other_isabelle.copy_dir(isabelle_base_log, isabelle_output_log)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   254
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   255
      val build_start = Date.now()
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   256
      val res = other_isabelle("build " + File.bash_args(build_args), redirect = true, echo = verbose)
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   257
      val build_end = Date.now()
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   258
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   259
      val log_path =
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   260
        other_isabelle.log_dir + Path.explode(build_history_date.rep.getYear.toString) +
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   261
          Path.explode(log_name(build_history_date, ml_platform, "M" + threads))
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   262
      Isabelle_System.mkdirs(log_path.dir)
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   263
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   264
      val meta_info =
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   265
        List(Build_Log.Field.build_engine -> BUILD_HISTORY,
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   266
          Build_Log.Field.build_host -> build_host,
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   267
          Build_Log.Field.build_start -> Build_Log.Log_File.Date_Format(build_start),
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   268
          Build_Log.Field.build_end -> Build_Log.Log_File.Date_Format(build_end),
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   269
          Build_Log.Field.isabelle_version -> isabelle_version)
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   270
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   271
      File.write_gzip(log_path,
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   272
        Build_Log.Log_File.print_props(META_INFO, meta_info) + "\n" + res.out)
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   273
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   274
      Output.writeln(log_path.implode, stdout = true)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   275
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   276
      if (multicore_base && first_build && isabelle_output_log.is_dir)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   277
        other_isabelle.copy_dir(isabelle_output_log, isabelle_base_log)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   278
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   279
      first_build = false
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   280
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   281
      res
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   282
    }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   283
  }
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   284
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   285
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   286
  /* command line entry point */
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   287
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   288
  def main(args: Array[String])
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   289
  {
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   290
    Command_Line.tool0 {
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   291
      var multicore_base = false
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   292
      var components_base = ""
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   293
      var heap: Option[Int] = None
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   294
      var max_heap: Option[Int] = None
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   295
      var threads_list = List(default_threads)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   296
      var isabelle_identifier = default_isabelle_identifier
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   297
      var more_settings: List[String] = Nil
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   298
      var fresh = false
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   299
      var arch_64 = false
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   300
      var nonfree = false
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   301
      var rev = default_rev
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   302
      var verbose = false
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   303
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   304
      val getopts = Getopts("""
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   305
Usage: isabelle build_history [OPTIONS] REPOSITORY [ARGS ...]
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   306
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   307
  Options are:
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   308
    -B           first multicore build serves as base for scheduling information
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   309
    -C DIR       base directory for Isabelle components (default: $ISABELLE_HOME_USER/../contrib)
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   310
    -H SIZE      minimal ML heap in MB (default: """ + default_heap + """ for x86, """ + default_heap * 2 + """ for x86_64)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   311
    -M THREADS   multicore configurations (comma-separated list, default: """ + default_threads + """)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   312
    -N NAME      alternative ISABELLE_IDENTIFIER (default: """ + default_isabelle_identifier + """)
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   313
    -U SIZE      maximal ML heap in MB (default: unbounded)
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   314
    -e TEXT      additional text for generated etc/settings
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   315
    -f           fresh build of Isabelle/Scala components (recommended)
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   316
    -m ARCH      processor architecture (32=x86, 64=x86_64, default: x86)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   317
    -n           include nonfree components
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   318
    -r REV       update to revision (default: """ + default_rev + """)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   319
    -v           verbose
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   320
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   321
  Build Isabelle sessions from the history of another REPOSITORY clone,
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   322
  passing ARGS directly to its isabelle build tool.
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   323
""",
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   324
        "B" -> (_ => multicore_base = true),
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   325
        "C:" -> (arg => components_base = arg),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   326
        "H:" -> (arg => heap = Some(Value.Int.parse(arg))),
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   327
        "M:" -> (arg => threads_list = space_explode(',', arg).map(Value.Int.parse(_))),
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   328
        "N:" -> (arg => isabelle_identifier = arg),
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   329
        "U:" -> (arg => max_heap = Some(Value.Int.parse(arg))),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   330
        "e:" -> (arg => more_settings = more_settings ::: List(arg)),
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   331
        "f" -> (_ => fresh = true),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   332
        "m:" ->
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   333
          {
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   334
            case "32" | "x86" => arch_64 = false
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   335
            case "64" | "x86_64" => arch_64 = true
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   336
            case bad => error("Bad processor architecture: " + quote(bad))
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   337
          },
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   338
        "n" -> (_ => nonfree = true),
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   339
        "r:" -> (arg => rev = arg),
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   340
        "v" -> (_ => verbose = true))
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   341
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   342
      val more_args = getopts(args)
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   343
      val (root, build_args) =
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   344
        more_args match {
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   345
          case root :: build_args => (root, build_args)
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   346
          case _ => getopts.usage()
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   347
        }
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   348
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   349
      using(Mercurial.open_repository(Path.explode(root)))(hg =>
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   350
        {
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   351
          val progress = new Console_Progress(stderr = true)
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   352
          val results =
64038
f69ce5e7ea7f incremental output;
wenzelm
parents: 64037
diff changeset
   353
            build_history(progress, hg, rev = rev, isabelle_identifier = isabelle_identifier,
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   354
              components_base = components_base, fresh = fresh, nonfree = nonfree,
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   355
              multicore_base = multicore_base, threads_list = threads_list, arch_64 = arch_64,
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   356
              heap = heap.getOrElse(if (arch_64) default_heap * 2 else default_heap),
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   357
              max_heap = max_heap, more_settings = more_settings, verbose = verbose,
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   358
              build_args = build_args)
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   359
          val rc = (0 /: results) { case (rc, res) => rc max res.rc }
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   360
          if (rc != 0) sys.exit(rc)
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   361
        })
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   362
    }
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   363
  }
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   364
}