src/Pure/Admin/build_history.scala
author paulson <lp15@cam.ac.uk>
Sun, 20 May 2018 18:37:34 +0100
changeset 68239 0764ee22a4d1
parent 68221 dbef88c2b6c5
child 69166 5c553c48c0e5
permissions -rw-r--r--
tidy up of Derivative
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64160
1eea419fab65 clarified files;
wenzelm
parents: 64155
diff changeset
     1
/*  Title:      Pure/Admin/build_history.scala
64021
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
65588
b0d8d97198b3 clarified signature;
wenzelm
parents: 65320
diff changeset
    19
  val engine = "build_history"
65596
7fffa01b2d2b proper prefix;
wenzelm
parents: 65591
diff changeset
    20
  val log_prefix = engine + "_"
64119
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
    21
  val META_INFO_MARKER = "\fmeta_info = "
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    22
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
    23
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    24
  /* augment settings */
64050
wenzelm
parents: 64049
diff changeset
    25
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    26
  def augment_settings(
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    27
    other_isabelle: Other_Isabelle,
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    28
    threads: Int,
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
    29
    arch_64: Boolean,
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
    30
    heap: Int,
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
    31
    max_heap: Option[Int],
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    32
    more_settings: List[String]): String =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    33
  {
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    34
    val (ml_platform, ml_settings) =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    35
    {
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    36
      val windows_32 = "x86-windows"
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    37
      val windows_64 = "x86_64-windows"
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    38
      val platform_32 = other_isabelle("getenv -b ISABELLE_PLATFORM32").check.out
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    39
      val platform_64 = other_isabelle("getenv -b ISABELLE_PLATFORM64").check.out
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    40
      val platform_family = other_isabelle("getenv -b ISABELLE_PLATFORM_FAMILY").check.out
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    41
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    42
      val polyml_home =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    43
        try { Path.explode(other_isabelle("getenv -b ML_HOME").check.out).dir }
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    44
        catch { case ERROR(msg) => error("Bad ML_HOME: " + msg) }
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    45
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    46
      def ml_home(platform: String): Path = polyml_home + Path.explode(platform)
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    47
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    48
      def err(platform: String): Nothing =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    49
        error("Platform " + platform + " unavailable on this machine")
64050
wenzelm
parents: 64049
diff changeset
    50
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    51
      def check_dir(platform: String): Boolean =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    52
        platform != "" && ml_home(platform).is_dir
64050
wenzelm
parents: 64049
diff changeset
    53
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    54
      val ml_platform =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    55
        if (Platform.is_windows && arch_64) {
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    56
          if (check_dir(windows_64)) windows_64 else err(windows_64)
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    57
        }
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    58
        else if (Platform.is_windows && !arch_64) {
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    59
          if (check_dir(windows_32)) windows_32
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    60
          else platform_32  // x86-cygwin
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    61
        }
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    62
        else {
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    63
          val (platform, platform_name) =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    64
            if (arch_64) (platform_64, "x86_64-" + platform_family)
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    65
            else (platform_32, "x86-" + platform_family)
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    66
          if (check_dir(platform)) platform else err(platform_name)
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    67
        }
64050
wenzelm
parents: 64049
diff changeset
    68
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    69
      val ml_options =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    70
        "--minheap " + heap + (if (max_heap.isDefined) " --maxheap " + max_heap.get else "") +
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    71
        " --gcthreads " + threads +
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    72
        (if (ml_platform.endsWith("-windows")) " --codepage utf8" else "")
64050
wenzelm
parents: 64049
diff changeset
    73
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    74
      (ml_platform,
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    75
        List(
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    76
          "ML_HOME=" + File.bash_path(ml_home(ml_platform)),
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    77
          "ML_PLATFORM=" + quote(ml_platform),
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    78
          "ML_OPTIONS=" + quote(ml_options)))
64050
wenzelm
parents: 64049
diff changeset
    79
    }
wenzelm
parents: 64049
diff changeset
    80
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    81
    val thread_settings =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    82
      List(
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    83
        "ISABELLE_JAVA_SYSTEM_OPTIONS=\"$ISABELLE_JAVA_SYSTEM_OPTIONS -Disabelle.threads=" + threads + "\"",
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    84
        "ISABELLE_BUILD_OPTIONS=\"threads=" + threads + "\"")
64050
wenzelm
parents: 64049
diff changeset
    85
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    86
    val settings =
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    87
      List(ml_settings, thread_settings) :::
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
    88
      (if (more_settings.isEmpty) Nil else List(more_settings))
64050
wenzelm
parents: 64049
diff changeset
    89
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    90
    File.append(other_isabelle.etc_settings, "\n" + cat_lines(settings.map(terminate_lines(_))))
64050
wenzelm
parents: 64049
diff changeset
    91
64188
f88bae1922c4 clarified modules;
wenzelm
parents: 64173
diff changeset
    92
    ml_platform
64049
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    93
  }
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    94
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    95
ac3ed62c53c3 misc tuning and clarification;
wenzelm
parents: 64048
diff changeset
    96
64050
wenzelm
parents: 64049
diff changeset
    97
  /** build_history **/
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
    98
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
    99
  private val default_user_home = Path.explode("$USER_HOME")
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   100
  private val default_rev = "tip"
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   101
  private val default_multicore = (1, 1)
64335
24e676390259 more ambitious default;
wenzelm
parents: 64305
diff changeset
   102
  private val default_heap = 1500
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   103
  private val default_isabelle_identifier = "build_history"
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   104
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   105
  def build_history(
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   106
    options: Options,
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   107
    root: Path,
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   108
    user_home: Path = default_user_home,
64909
8007f10195af tuned signature;
wenzelm
parents: 64472
diff changeset
   109
    progress: Progress = No_Progress,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   110
    rev: String = default_rev,
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   111
    afp_rev: Option[String] = None,
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   112
    afp_partition: Int = 0,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   113
    isabelle_identifier: String = default_isabelle_identifier,
66867
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   114
    ml_statistics_step: Int = 1,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   115
    components_base: String = "",
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   116
    fresh: Boolean = false,
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   117
    nonfree: Boolean = false,
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   118
    multicore_base: Boolean = false,
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   119
    multicore_list: List[(Int, Int)] = List(default_multicore),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   120
    arch_64: Boolean = false,
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   121
    heap: Int = default_heap,
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   122
    max_heap: Option[Int] = None,
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   123
    init_settings: List[String] = Nil,
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   124
    more_settings: List[String] = Nil,
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   125
    verbose: Boolean = false,
64297
12a47f263122 support for free-form build tags;
wenzelm
parents: 64296
diff changeset
   126
    build_tags: List[String] = Nil,
64194
b5ada7dcceaa integrity test of build_history vs. build_history_base;
wenzelm
parents: 64193
diff changeset
   127
    build_args: List[String] = Nil): List[(Process_Result, Path)] =
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   128
  {
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   129
    /* sanity checks */
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   130
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   131
    if (File.eq(Path.explode("~~"), root))
64046
5a6a7401c48b clarified sanity checks;
wenzelm
parents: 64044
diff changeset
   132
      error("Repository coincides with ISABELLE_HOME=" + Path.explode("~~").expand)
5a6a7401c48b clarified sanity checks;
wenzelm
parents: 64044
diff changeset
   133
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   134
    for ((threads, _) <- multicore_list if threads < 1)
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   135
      error("Bad threads value < 1: " + threads)
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   136
    for ((_, processes) <- multicore_list if processes < 1)
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   137
      error("Bad processes value < 1: " + processes)
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   138
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   139
    if (heap < 100) error("Bad heap value < 100: " + heap)
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   140
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   141
    if (max_heap.isDefined && max_heap.get < heap)
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   142
      error("Bad max_heap value < heap: " + max_heap.get)
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   143
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   144
    System.getenv("ISABELLE_SETTINGS_PRESENT") match {
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   145
      case null | "" =>
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   146
      case _ => error("Cannot run build_history within existing Isabelle settings environment")
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   147
    }
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   148
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   149
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   150
    /* checkout Isabelle + AFP repository */
64031
eef8a3f8ef4a more sanity checks;
wenzelm
parents: 64030
diff changeset
   151
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   152
    def checkout(dir: Path, version: String): String =
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   153
    {
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   154
      val hg = Mercurial.repository(dir)
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   155
      hg.update(rev = version, clean = true)
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   156
      progress.echo_if(verbose, hg.log(version, options = "-l1"))
66866
f5cd84280b7a proper argument;
wenzelm
parents: 66862
diff changeset
   157
      hg.id(rev = version)
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   158
    }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   159
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   160
    val isabelle_version = checkout(root, rev)
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   161
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   162
    val afp_repos = root + Path.explode("AFP")
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   163
    val afp_version = afp_rev.map(checkout(afp_repos, _))
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   164
66862
136793b73c7c clarified stored build_args;
wenzelm
parents: 66861
diff changeset
   165
    val (afp_build_args, afp_sessions) =
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   166
      if (afp_rev.isEmpty) (Nil, Nil)
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   167
      else {
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   168
        val afp = AFP.init(options, afp_repos)
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   169
        (List("-d", "~~/AFP/thys"), afp.partition(afp_partition))
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   170
      }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   171
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   172
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   173
    /* main */
64043
44b6c620c371 more thorought update of components;
wenzelm
parents: 64040
diff changeset
   174
67045
6c94f749410a tuned signature;
wenzelm
parents: 66913
diff changeset
   175
    val other_isabelle =
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   176
      Other_Isabelle(root, isabelle_identifier = isabelle_identifier,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   177
        user_home = user_home, progress = progress)
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   178
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   179
    val build_host = Isabelle_System.hostname()
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   180
    val build_history_date = Date.now()
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   181
    val build_group_id = build_host + ":" + build_history_date.time.ms
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   182
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   183
    var first_build = true
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   184
    for ((threads, processes) <- multicore_list) yield
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   185
    {
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   186
      /* init settings */
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   187
65845
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 65844
diff changeset
   188
      other_isabelle.init_settings(components_base, nonfree, init_settings)
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   189
      other_isabelle.resolve_components(verbose)
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   190
      val ml_platform =
65845
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 65844
diff changeset
   191
        augment_settings(other_isabelle, threads, arch_64, heap, max_heap, more_settings)
64043
44b6c620c371 more thorought update of components;
wenzelm
parents: 64040
diff changeset
   192
68219
c0341c0080e2 clarified store directories;
wenzelm
parents: 68209
diff changeset
   193
      val isabelle_output =
c0341c0080e2 clarified store directories;
wenzelm
parents: 68209
diff changeset
   194
        other_isabelle.isabelle_home_user + Path.explode("heaps") +
c0341c0080e2 clarified store directories;
wenzelm
parents: 68209
diff changeset
   195
          Path.explode(other_isabelle("getenv -b ML_IDENTIFIER").check.out)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   196
      val isabelle_output_log = isabelle_output + Path.explode("log")
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   197
      val isabelle_base_log = isabelle_output + Path.explode("../base_log")
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   198
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   199
      if (first_build) {
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   200
        other_isabelle.resolve_components(verbose)
64376
68ace7f3d78f more thorough cleanup of lib/classes -- it may contain broken Pure.jar or copies of Scala libraries (in historic versions);
wenzelm
parents: 64353
diff changeset
   201
68ace7f3d78f more thorough cleanup of lib/classes -- it may contain broken Pure.jar or copies of Scala libraries (in historic versions);
wenzelm
parents: 64353
diff changeset
   202
        if (fresh)
68ace7f3d78f more thorough cleanup of lib/classes -- it may contain broken Pure.jar or copies of Scala libraries (in historic versions);
wenzelm
parents: 64353
diff changeset
   203
          Isabelle_System.rm_tree(other_isabelle.isabelle_home + Path.explode("lib/classes"))
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   204
        other_isabelle.bash(
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   205
          "env PATH=\"" + File.bash_path(Path.explode("~~/lib/dummy_stty").expand) + ":$PATH\" " +
64376
68ace7f3d78f more thorough cleanup of lib/classes -- it may contain broken Pure.jar or copies of Scala libraries (in historic versions);
wenzelm
parents: 64353
diff changeset
   206
            "bin/isabelle jedit -b", redirect = true, echo = verbose).check
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   207
64213
b265dd04d57d clarified file operations;
wenzelm
parents: 64194
diff changeset
   208
        Isabelle_System.rm_tree(isabelle_base_log)
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   209
      }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   210
64213
b265dd04d57d clarified file operations;
wenzelm
parents: 64194
diff changeset
   211
      Isabelle_System.rm_tree(isabelle_output)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   212
      Isabelle_System.mkdirs(isabelle_output)
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   213
65909
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   214
      val log_path =
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   215
        other_isabelle.isabelle_home_user +
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   216
          Build_Log.log_subdir(build_history_date) +
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   217
          Build_Log.log_filename(Build_History.engine, build_history_date,
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   218
            List(build_host, ml_platform, "M" + threads) ::: build_tags)
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   219
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   220
      Isabelle_System.mkdirs(log_path.dir)
65927
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   221
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   222
      val build_out = other_isabelle.isabelle_home_user + Path.explode("log/build.out")
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   223
      val build_out_progress = new File_Progress(build_out)
65909
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   224
      build_out.file.delete
4940682a2e1a more persistent build.out;
wenzelm
parents: 65889
diff changeset
   225
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   226
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   227
      /* build */
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   228
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   229
      if (multicore_base && !first_build && isabelle_base_log.is_dir)
64189
dfb63036c4f6 tuned signature;
wenzelm
parents: 64188
diff changeset
   230
        Isabelle_System.copy_dir(isabelle_base_log, isabelle_output_log)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   231
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   232
      val build_start = Date.now()
66862
136793b73c7c clarified stored build_args;
wenzelm
parents: 66861
diff changeset
   233
      val build_args1 = List("-v", "-j" + processes) ::: afp_build_args ::: build_args
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   234
      val build_result =
67045
6c94f749410a tuned signature;
wenzelm
parents: 66913
diff changeset
   235
        Other_Isabelle(root, isabelle_identifier = isabelle_identifier,
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   236
          user_home = user_home, progress = build_out_progress)(
67045
6c94f749410a tuned signature;
wenzelm
parents: 66913
diff changeset
   237
            "build " + Bash.strings(build_args1 ::: afp_sessions), redirect = true, echo = true,
6c94f749410a tuned signature;
wenzelm
parents: 66913
diff changeset
   238
            strict = false)
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   239
      val build_end = Date.now()
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   240
65646
014dbbe5331f parse ml_statistics only when required;
wenzelm
parents: 65624
diff changeset
   241
      val build_info: Build_Log.Build_Info =
65999
ee4cf96a9406 tuned signature;
wenzelm
parents: 65950
diff changeset
   242
        Build_Log.Log_File(log_path.base_name, build_result.out_lines).
65646
014dbbe5331f parse ml_statistics only when required;
wenzelm
parents: 65624
diff changeset
   243
          parse_build_info(ml_statistics = true)
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   244
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   245
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   246
      /* output log */
64120
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   247
68221
dbef88c2b6c5 support for build_database_server (PostgreSQL);
wenzelm
parents: 68219
diff changeset
   248
      val store = Sessions.store(options + "build_database_server=false")
65293
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   249
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   250
      val meta_info =
65624
32fa61f694ef clarified multi-line properties;
wenzelm
parents: 65596
diff changeset
   251
        Properties.lines_nonempty(Build_Log.Prop.build_tags.name, build_tags) :::
32fa61f694ef clarified multi-line properties;
wenzelm
parents: 65596
diff changeset
   252
        Properties.lines_nonempty(Build_Log.Prop.build_args.name, build_args1) :::
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   253
        List(
65591
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   254
          Build_Log.Prop.build_group_id.name -> build_group_id,
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   255
          Build_Log.Prop.build_id.name -> (build_host + ":" + build_start.time.ms),
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   256
          Build_Log.Prop.build_engine.name -> Build_History.engine,
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   257
          Build_Log.Prop.build_host.name -> build_host,
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   258
          Build_Log.Prop.build_start.name -> Build_Log.print_date(build_start),
5953c7fbc2b8 more SQL operations;
wenzelm
parents: 65588
diff changeset
   259
          Build_Log.Prop.build_end.name -> Build_Log.print_date(build_end),
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   260
          Build_Log.Prop.isabelle_version.name -> isabelle_version) :::
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   261
        afp_version.map(Build_Log.Prop.afp_version.name -> _).toList
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   262
66913
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   263
      build_out_progress.echo("Reading session build info ...")
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   264
      val session_build_info =
66874
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   265
        build_info.finished_sessions.flatMap(session_name =>
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   266
          {
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   267
            val database = isabelle_output + store.database(session_name)
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   268
66913
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   269
            if (database.is_file) {
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   270
              using(SQLite.open_database(database))(db =>
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   271
              {
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   272
                val theory_timings =
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   273
                  try {
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   274
                    store.read_theory_timings(db, session_name).map(ps =>
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   275
                      Build_Log.Log_File.print_props(Build_Log.THEORY_TIMING_MARKER,
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   276
                        (Build_Log.SESSION_NAME, session_name) :: ps))
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   277
                  }
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   278
                  catch { case ERROR(_) => Nil }
66874
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   279
66913
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   280
                val session_sources =
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   281
                  store.read_build(db, session_name).map(_.sources) match {
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   282
                    case Some(sources) if sources.length == SHA1.digest_length =>
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   283
                      List("Sources " + session_name + " " + sources)
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   284
                    case _ => Nil
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   285
                  }
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   286
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   287
                theory_timings ::: session_sources
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   288
              })
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   289
            }
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   290
            else Nil
66874
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   291
          })
0b8da0fc9563 store theory timings in session in build_log database;
wenzelm
parents: 66871
diff changeset
   292
65927
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   293
      build_out_progress.echo("Reading ML statistics ...")
64119
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
   294
      val ml_statistics =
64120
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   295
        build_info.finished_sessions.flatMap(session_name =>
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   296
          {
65293
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   297
            val database = isabelle_output + store.database(session_name)
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   298
            val log_gz = isabelle_output + store.log_gz(session_name)
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   299
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   300
            val properties =
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   301
              if (database.is_file) {
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   302
                using(SQLite.open_database(database))(db =>
65935
73c099fa96a4 more selective database access;
wenzelm
parents: 65931
diff changeset
   303
                  store.read_ml_statistics(db, session_name))
65293
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   304
              }
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   305
              else if (log_gz.is_file) {
65318
342efc382558 eliminated somewhat redundant inlined name (despite a7aa17a1f721);
wenzelm
parents: 65296
diff changeset
   306
                Build_Log.Log_File(log_gz).parse_session_info(ml_statistics = true).ml_statistics
65293
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   307
              }
a53a5ae88205 prefer database, but also accept log.gz from historic versions;
wenzelm
parents: 64909
diff changeset
   308
              else Nil
66867
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   309
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   310
            val trimmed_properties =
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   311
              if (ml_statistics_step <= 0) Nil
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   312
              else if (ml_statistics_step == 1) properties
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   313
              else {
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   314
                (for { (ps, i) <- properties.iterator.zipWithIndex if i % ml_statistics_step == 0 }
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   315
                 yield ps).toList
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   316
              }
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   317
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   318
            trimmed_properties.map(ps => (Build_Log.SESSION_NAME -> session_name) :: ps)
64120
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   319
          })
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   320
65937
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   321
      build_out_progress.echo("Reading error messages ...")
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   322
      val session_errors =
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   323
        build_info.failed_sessions.flatMap(session_name =>
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   324
          {
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   325
            val database = isabelle_output + store.database(session_name)
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   326
            val errors =
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   327
              if (database.is_file) {
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   328
                try {
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   329
                  using(SQLite.open_database(database))(db => store.read_errors(db, session_name))
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   330
                } // column "errors" could be missing
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   331
                catch { case _: java.sql.SQLException => Nil }
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   332
              }
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   333
              else Nil
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   334
            errors.map(msg => List(Build_Log.SESSION_NAME -> session_name, Markup.CONTENT -> msg))
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   335
          })
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   336
65927
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   337
      build_out_progress.echo("Reading heap sizes ...")
64120
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   338
      val heap_sizes =
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   339
        build_info.finished_sessions.flatMap(session_name =>
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   340
          {
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   341
            val heap = isabelle_output + Path.explode(session_name)
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   342
            if (heap.is_file)
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   343
              Some("Heap " + session_name + " (" + Value.Long(heap.file.length) + " bytes)")
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   344
            else None
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   345
          })
64119
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
   346
65927
23a1e2fa5c8a more progress information, for the sake of sporadic dropouts;
wenzelm
parents: 65917
diff changeset
   347
      build_out_progress.echo("Writing log file " + log_path.ext("xz") + " ...")
64253
a4718dfc9cd4 more compression for big log files;
wenzelm
parents: 64234
diff changeset
   348
      File.write_xz(log_path.ext("xz"),
64173
85ff21510ba9 tuned signature;
wenzelm
parents: 64162
diff changeset
   349
        terminate_lines(
64296
544481988e65 explicit identification of builds and correlated build groups;
wenzelm
parents: 64263
diff changeset
   350
          Build_Log.Log_File.print_props(META_INFO_MARKER, meta_info) :: build_result.out_lines :::
66913
7cdd4d59e95c store session sources stamp;
wenzelm
parents: 66878
diff changeset
   351
          session_build_info :::
64120
6c5039016321 record heap sizes;
wenzelm
parents: 64119
diff changeset
   352
          ml_statistics.map(Build_Log.Log_File.print_props(Build_Log.ML_STATISTICS_MARKER, _)) :::
65937
fde7b5d209d5 store errors in build_history logs and database;
wenzelm
parents: 65935
diff changeset
   353
          session_errors.map(Build_Log.Log_File.print_props(Build_Log.ERROR_MESSAGE_MARKER, _)) :::
64253
a4718dfc9cd4 more compression for big log files;
wenzelm
parents: 64234
diff changeset
   354
          heap_sizes), XZ.options(6))
64117
c2b41b073d8a build_history log files with formal meta info;
wenzelm
parents: 64052
diff changeset
   355
64119
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
   356
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
   357
      /* next build */
8094eaa38d4b inline session ML statistics into main build log;
wenzelm
parents: 64118
diff changeset
   358
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   359
      if (multicore_base && first_build && isabelle_output_log.is_dir)
64189
dfb63036c4f6 tuned signature;
wenzelm
parents: 64188
diff changeset
   360
        Isabelle_System.copy_dir(isabelle_output_log, isabelle_base_log)
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   361
64260
5389ebfd576d more thorough cleanup;
wenzelm
parents: 64256
diff changeset
   362
      Isabelle_System.rm_tree(isabelle_output)
5389ebfd576d more thorough cleanup;
wenzelm
parents: 64256
diff changeset
   363
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   364
      first_build = false
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   365
64468
ed8940d6295c back to more elementary result (see 5f49765a25ec): avoid concurrent use of ssh channel;
wenzelm
parents: 64466
diff changeset
   366
      (build_result, log_path.ext("xz"))
64051
4dd9d9b28fd5 allow multiple threads configurations;
wenzelm
parents: 64050
diff changeset
   367
    }
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   368
  }
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   369
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   370
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   371
  /* command line entry point */
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   372
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   373
  private object Multicore
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   374
  {
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   375
    private val Pat1 = """^(\d+)$""".r
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   376
    private val Pat2 = """^(\d+)x(\d+)$""".r
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   377
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   378
    def parse(s: String): (Int, Int) =
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   379
      s match {
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   380
        case Pat1(Value.Int(x)) => (x, 1)
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   381
        case Pat2(Value.Int(x), Value.Int(y)) => (x, y)
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   382
        case _ => error("Bad multicore configuration: " + quote(s))
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   383
      }
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   384
  }
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   385
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   386
  def main(args: Array[String])
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   387
  {
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   388
    Command_Line.tool0 {
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   389
      var afp_rev: Option[String] = None
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   390
      var multicore_base = false
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   391
      var components_base = ""
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   392
      var heap: Option[Int] = None
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   393
      var max_heap: Option[Int] = None
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   394
      var multicore_list = List(default_multicore)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   395
      var isabelle_identifier = default_isabelle_identifier
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   396
      var afp_partition = 0
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   397
      var more_settings: List[String] = Nil
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   398
      var fresh = false
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   399
      var init_settings: List[String] = Nil
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   400
      var arch_64 = false
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   401
      var nonfree = false
65844
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   402
      var output_file = ""
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   403
      var rev = default_rev
66867
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   404
      var ml_statistics_step = 1
64297
12a47f263122 support for free-form build tags;
wenzelm
parents: 64296
diff changeset
   405
      var build_tags = List.empty[String]
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   406
      var user_home = default_user_home
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   407
      var verbose = false
65950
34c4cd9abc1a no exit code from build processes by default, e.g. relevant for non-strict results of remote_build_history;
wenzelm
parents: 65937
diff changeset
   408
      var exit_code = false
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   409
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   410
      val getopts = Getopts("""
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   411
Usage: Admin/build_history [OPTIONS] REPOSITORY [ARGS ...]
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   412
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   413
  Options are:
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   414
    -A REV       include $ISABELLE_HOME/AFP repository at given revision
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   415
    -B           first multicore build serves as base for scheduling information
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   416
    -C DIR       base directory for Isabelle components (default: $ISABELLE_HOME_USER/../contrib)
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   417
    -H SIZE      minimal ML heap in MB (default: """ + default_heap + """ for x86, """ +
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   418
      default_heap * 2 + """ for x86_64)
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   419
    -M MULTICORE multicore configurations (see below)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   420
    -N NAME      alternative ISABELLE_IDENTIFIER (default: """ + default_isabelle_identifier + """)
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   421
    -P NUMBER    AFP partition number (0, 1, 2, default: 0=unrestricted)
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   422
    -U SIZE      maximal ML heap in MB (default: unbounded)
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   423
    -e TEXT      additional text for generated etc/settings
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   424
    -f           fresh build of Isabelle/Scala components (recommended)
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   425
    -i TEXT      initial text for generated etc/settings
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   426
    -m ARCH      processor architecture (32=x86, 64=x86_64, default: x86)
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   427
    -n           include nonfree components
65844
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   428
    -o FILE      output file for log names (default: stdout)
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   429
    -r REV       update to revision (default: """ + default_rev + """)
66867
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   430
    -s NUMBER    step size for ML statistics (0=none, 1=all, n=step, default: 1)
64297
12a47f263122 support for free-form build tags;
wenzelm
parents: 64296
diff changeset
   431
    -t TAG       free-form build tag (multiple occurrences possible)
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   432
    -u DIR       alternative USER_HOME directory
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   433
    -v           verbose
65950
34c4cd9abc1a no exit code from build processes by default, e.g. relevant for non-strict results of remote_build_history;
wenzelm
parents: 65937
diff changeset
   434
    -x           return overall exit code from build processes
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   435
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   436
  Build Isabelle sessions from the history of another REPOSITORY clone,
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   437
  passing ARGS directly to its isabelle build tool.
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   438
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   439
  Each MULTICORE configuration consists of one or two numbers (default 1):
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   440
  THREADS or THREADSxPROCESSES, e.g. -M 1,2,4 or -M 1x4,2x2,4.
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   441
""",
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   442
        "A:" -> (arg => afp_rev = Some(arg)),
64052
72fa79eab7f6 added multicore_base option;
wenzelm
parents: 64051
diff changeset
   443
        "B" -> (_ => multicore_base = true),
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   444
        "C:" -> (arg => components_base = arg),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   445
        "H:" -> (arg => heap = Some(Value.Int.parse(arg))),
64301
8053c882839f more flexible multicore configuration;
wenzelm
parents: 64300
diff changeset
   446
        "M:" -> (arg => multicore_list = space_explode(',', arg).map(Multicore.parse(_))),
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   447
        "N:" -> (arg => isabelle_identifier = arg),
66861
f6676691ef8a partition AFP sessions according to structure, which happens to cut it roughly into equal parts;
wenzelm
parents: 66860
diff changeset
   448
        "P:" -> (arg => afp_partition = Value.Int.parse(arg)),
64036
a14fe26c0144 clarified heap options;
wenzelm
parents: 64034
diff changeset
   449
        "U:" -> (arg => max_heap = Some(Value.Int.parse(arg))),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   450
        "e:" -> (arg => more_settings = more_settings ::: List(arg)),
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   451
        "f" -> (_ => fresh = true),
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   452
        "i:" -> (arg => init_settings = init_settings ::: List(arg)),
64030
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   453
        "m:" ->
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   454
          {
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   455
            case "32" | "x86" => arch_64 = false
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   456
            case "64" | "x86_64" => arch_64 = true
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   457
            case bad => error("Bad processor architecture: " + quote(bad))
04f9e1e9003a more options for generated settings;
wenzelm
parents: 64027
diff changeset
   458
          },
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   459
        "n" -> (_ => nonfree = true),
65844
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   460
        "o:" -> (arg => output_file = arg),
64025
ff4910ced9ba clarified command-line;
wenzelm
parents: 64023
diff changeset
   461
        "r:" -> (arg => rev = arg),
66867
b00d8e1f8ddd added ml_statistics_step to trim stored properties;
wenzelm
parents: 66866
diff changeset
   462
        "s:" -> (arg => ml_statistics_step = Value.Int.parse(arg)),
64297
12a47f263122 support for free-form build tags;
wenzelm
parents: 64296
diff changeset
   463
        "t:" -> (arg => build_tags = build_tags ::: List(arg)),
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   464
        "u:" -> (arg => user_home = Path.explode(arg)),
65950
34c4cd9abc1a no exit code from build processes by default, e.g. relevant for non-strict results of remote_build_history;
wenzelm
parents: 65937
diff changeset
   465
        "v" -> (_ => verbose = true),
34c4cd9abc1a no exit code from build processes by default, e.g. relevant for non-strict results of remote_build_history;
wenzelm
parents: 65937
diff changeset
   466
        "x" -> (_ => exit_code = true))
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   467
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   468
      val more_args = getopts(args)
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   469
      val (root, build_args) =
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   470
        more_args match {
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   471
          case root :: build_args => (Path.explode(root), build_args)
64026
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   472
          case _ => getopts.usage()
cbecd26e063f clarified command line;
wenzelm
parents: 64025
diff changeset
   473
        }
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   474
64162
03057a8fdd1f simplified: no internal state for Mercurial;
wenzelm
parents: 64160
diff changeset
   475
      val progress = new Console_Progress(stderr = true)
64346
5f49765a25ec process results immediately;
wenzelm
parents: 64335
diff changeset
   476
64162
03057a8fdd1f simplified: no internal state for Mercurial;
wenzelm
parents: 64160
diff changeset
   477
      val results =
67047
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   478
        build_history(Options.init(), root, user_home = user_home, progress = progress, rev = rev,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   479
          afp_rev = afp_rev, afp_partition = afp_partition,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   480
          isabelle_identifier = isabelle_identifier, ml_statistics_step = ml_statistics_step,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   481
          components_base = components_base, fresh = fresh, nonfree = nonfree,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   482
          multicore_base = multicore_base, multicore_list = multicore_list, arch_64 = arch_64,
19b6091c2137 support alternative USER_HOME directory;
wenzelm
parents: 67045
diff changeset
   483
          heap = heap.getOrElse(if (arch_64) default_heap * 2 else default_heap),
65843
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   484
          max_heap = max_heap, init_settings = init_settings, more_settings = more_settings,
d547173212d2 proper init_settings for init_component (before generated ML_OPTIONS etc.);
wenzelm
parents: 65646
diff changeset
   485
          verbose = verbose, build_tags = build_tags, build_args = build_args)
64162
03057a8fdd1f simplified: no internal state for Mercurial;
wenzelm
parents: 64160
diff changeset
   486
65844
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   487
      if (output_file == "") {
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   488
        for ((_, log_path) <- results)
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   489
          Output.writeln(log_path.implode, stdout = true)
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   490
      }
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   491
      else {
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   492
        File.write(Path.explode(output_file),
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   493
          cat_lines(for ((_, log_path) <- results) yield log_path.implode))
76e60a142ca1 support for explicit output file: potentially more robust than stdout;
wenzelm
parents: 65843
diff changeset
   494
      }
64472
c2191352e908 recovered Output.writeln for remote build_history (cf. ed8940d6295c), in order to have log files copied and removed;
wenzelm
parents: 64468
diff changeset
   495
64194
b5ada7dcceaa integrity test of build_history vs. build_history_base;
wenzelm
parents: 64193
diff changeset
   496
      val rc = (0 /: results) { case (rc, (res, _)) => rc max res.rc }
65950
34c4cd9abc1a no exit code from build processes by default, e.g. relevant for non-strict results of remote_build_history;
wenzelm
parents: 65937
diff changeset
   497
      if (rc != 0 && exit_code) sys.exit(rc)
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   498
    }
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   499
  }
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   500
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   501
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   502
64225
wenzelm
parents: 64223
diff changeset
   503
  /** remote build_history -- via command-line **/
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   504
64225
wenzelm
parents: 64223
diff changeset
   505
  def remote_build_history(
64256
c3197aeae90b simplified SSH.Session: sftp channel is always open and its operations provided by the main interface;
wenzelm
parents: 64253
diff changeset
   506
    ssh: SSH.Session,
64227
wenzelm
parents: 64225
diff changeset
   507
    isabelle_repos_self: Path,
wenzelm
parents: 64225
diff changeset
   508
    isabelle_repos_other: Path,
67753
f28aee3ad1e6 uniform setup_repository (pull/clone without update);
wenzelm
parents: 67744
diff changeset
   509
    isabelle_repos_source: String = Isabelle_Cronjob.isabelle_repos_source,
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   510
    afp_repos_source: String = AFP.repos_source,
65928
38eb5d633b0b avoid conflict with generated settings of other_isabelle;
wenzelm
parents: 65927
diff changeset
   511
    isabelle_identifier: String = "remote_build_history",
64227
wenzelm
parents: 64225
diff changeset
   512
    self_update: Boolean = false,
64909
8007f10195af tuned signature;
wenzelm
parents: 64472
diff changeset
   513
    progress: Progress = No_Progress,
66106
b5333fc056da always start with fresh clone (with explicitly given rev): more robust on Windows;
wenzelm
parents: 65999
diff changeset
   514
    rev: String = "",
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   515
    afp_rev: Option[String] = None,
64227
wenzelm
parents: 64225
diff changeset
   516
    options: String = "",
65929
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   517
    args: String = ""): List[(String, Bytes)] =
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   518
  {
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   519
    /* Isabelle self repository */
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   520
67754
197366313aaf self_update implies push_isabelle_home (see also 4c253e84ae62);
wenzelm
parents: 67753
diff changeset
   521
    val self_hg =
66570
9af879e222cc clarified signature;
wenzelm
parents: 66107
diff changeset
   522
      Mercurial.setup_repository(isabelle_repos_source, isabelle_repos_self, ssh = ssh)
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   523
66877
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   524
    def execute(cmd: String, args: String, echo: Boolean = false, strict: Boolean = true): Unit =
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   525
      ssh.execute(
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   526
        Isabelle_System.export_isabelle_identifier(isabelle_identifier) +
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   527
          ssh.bash_path(isabelle_repos_self + Path.explode(cmd)) + " " + args,
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   528
        progress_stdout = progress.echo_if(echo, _),
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   529
        progress_stderr = progress.echo_if(echo, _),
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   530
        strict = strict).check
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   531
66106
b5333fc056da always start with fresh clone (with explicitly given rev): more robust on Windows;
wenzelm
parents: 65999
diff changeset
   532
    if (self_update) {
67754
197366313aaf self_update implies push_isabelle_home (see also 4c253e84ae62);
wenzelm
parents: 67753
diff changeset
   533
      val hg = Mercurial.repository(Path.explode("~~"))
67756
d2fe32ebe3c7 clarified self_update: imitate visible directory state on remote side;
wenzelm
parents: 67754
diff changeset
   534
      hg.push(self_hg.root_url, force = true)
d2fe32ebe3c7 clarified self_update: imitate visible directory state on remote side;
wenzelm
parents: 67754
diff changeset
   535
      self_hg.update(rev = hg.parent(), clean = true)
67754
197366313aaf self_update implies push_isabelle_home (see also 4c253e84ae62);
wenzelm
parents: 67753
diff changeset
   536
66877
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   537
      execute("bin/isabelle", "components -I")
66878
91da58bb560d tuned output;
wenzelm
parents: 66877
diff changeset
   538
      execute("bin/isabelle", "components -a", echo = true)
66877
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   539
      execute("Admin/build", "jars_fresh")
66106
b5333fc056da always start with fresh clone (with explicitly given rev): more robust on Windows;
wenzelm
parents: 65999
diff changeset
   540
    }
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   541
67773
4a7ed678785c more robust: normalize potentially symbolic rev;
wenzelm
parents: 67756
diff changeset
   542
    val rev_id = self_hg.id(rev)
4a7ed678785c more robust: normalize potentially symbolic rev;
wenzelm
parents: 67756
diff changeset
   543
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   544
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   545
    /* Isabelle other + AFP repository */
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   546
66570
9af879e222cc clarified signature;
wenzelm
parents: 66107
diff changeset
   547
    if (Mercurial.is_repository(isabelle_repos_other, ssh = ssh)) {
66107
8c8e77dbe6fe more robust: do not touch unrelated directory isabelle_repos_other (i.e. bad argument);
wenzelm
parents: 66106
diff changeset
   548
      ssh.rm_tree(isabelle_repos_other)
8c8e77dbe6fe more robust: do not touch unrelated directory isabelle_repos_other (i.e. bad argument);
wenzelm
parents: 66106
diff changeset
   549
    }
64348
4c253e84ae62 clarified push/pull chain: current ISABELLE_HOME may server as source for changes that are not published on isabelle_repos_source yet (e.g. isabelle-release branch);
wenzelm
parents: 64346
diff changeset
   550
    val other_hg =
66106
b5333fc056da always start with fresh clone (with explicitly given rev): more robust on Windows;
wenzelm
parents: 65999
diff changeset
   551
      Mercurial.clone_repository(
67773
4a7ed678785c more robust: normalize potentially symbolic rev;
wenzelm
parents: 67756
diff changeset
   552
        ssh.bash_path(isabelle_repos_self), isabelle_repos_other, rev = rev_id, ssh = ssh)
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   553
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   554
    val afp_options =
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   555
      if (afp_rev.isEmpty) ""
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   556
      else {
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   557
        val afp_repos = isabelle_repos_other + Path.explode("AFP")
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   558
        val afp_hg = Mercurial.setup_repository(afp_repos_source, afp_repos, ssh = ssh)
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   559
        " -A " + Bash.string(afp_rev.get)
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   560
      }
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   561
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   562
64256
c3197aeae90b simplified SSH.Session: sftp channel is always open and its operations provided by the main interface;
wenzelm
parents: 64253
diff changeset
   563
    /* Admin/build_history */
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   564
65846
aa6e58dc54d0 prefer explicit output file: potentially more robust than stdout;
wenzelm
parents: 65845
diff changeset
   565
    ssh.with_tmp_dir(tmp_dir =>
aa6e58dc54d0 prefer explicit output file: potentially more robust than stdout;
wenzelm
parents: 65845
diff changeset
   566
    {
aa6e58dc54d0 prefer explicit output file: potentially more robust than stdout;
wenzelm
parents: 65845
diff changeset
   567
      val output_file = tmp_dir + Path.explode("output")
64346
5f49765a25ec process results immediately;
wenzelm
parents: 64335
diff changeset
   568
66877
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   569
      execute("Admin/build_history",
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   570
        "-o " + ssh.bash_path(output_file) +
67773
4a7ed678785c more robust: normalize potentially symbolic rev;
wenzelm
parents: 67756
diff changeset
   571
          (if (rev == "") "" else " -r " + Bash.string(rev_id)) + " " +
66860
54ae2cc05325 support for AFP in build_history and remote_build_history;
wenzelm
parents: 66570
diff changeset
   572
          options + afp_options + " " + ssh.bash_path(isabelle_repos_other) + " " + args,
66877
4f0ccfe1bcb6 uniform execute, with proper isabelle_identifier (notably for "isabelle components -I");
wenzelm
parents: 66876
diff changeset
   573
        echo = true, strict = false)
64468
ed8940d6295c back to more elementary result (see 5f49765a25ec): avoid concurrent use of ssh channel;
wenzelm
parents: 64466
diff changeset
   574
65929
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   575
      for (line <- split_lines(ssh.read(output_file)))
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   576
      yield {
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   577
        val log = Path.explode(line)
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   578
        val bytes = ssh.read_bytes(log)
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   579
        ssh.rm(log)
65999
ee4cf96a9406 tuned signature;
wenzelm
parents: 65950
diff changeset
   580
        (log.base_name, bytes)
65929
de3adcf6a276 prefer strict result (in contrast to 0f3b0a929c02);
wenzelm
parents: 65928
diff changeset
   581
      }
65846
aa6e58dc54d0 prefer explicit output file: potentially more robust than stdout;
wenzelm
parents: 65845
diff changeset
   582
    })
64223
9d5b9f41df77 remove invocation of build_history: results are reported via stdout;
wenzelm
parents: 64213
diff changeset
   583
  }
64021
1e23caac8757 basic setup for Admin/build_history -- outside of Isabelle environment;
wenzelm
parents:
diff changeset
   584
}