src/Pure/Admin/components.scala
author wenzelm
Thu, 21 Jan 2021 16:10:43 +0100
changeset 73172 fc828f64da5b
parent 73090 9db6072eb711
child 73173 91fc3b3df93f
permissions -rw-r--r--
support isabelle components -u and -x;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Admin/components.scala
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     3
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     4
Isabelle system components.
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     5
*/
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     6
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     7
package isabelle
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     8
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
     9
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    10
import java.io.{File => JFile}
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    11
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    12
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    13
object Components
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    14
{
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    15
  /* archive name */
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    16
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    17
  object Archive
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    18
  {
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    19
    val suffix: String = ".tar.gz"
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    20
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    21
    def apply(name: String): String =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    22
      if (name == "") error("Bad component name: " + quote(name))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    23
      else name + suffix
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    24
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    25
    def unapply(archive: String): Option[String] =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    26
    {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    27
      for {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    28
        name0 <- Library.try_unsuffix(suffix, archive)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    29
        name <- proper_string(name0)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    30
      } yield name
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    31
    }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    32
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    33
    def get_name(archive: String): String =
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    34
      unapply(archive) getOrElse
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    35
        error("Bad component archive name (expecting .tar.gz): " + quote(archive))
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    36
  }
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    37
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    38
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    39
  /* component collections */
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    40
71601
97ccf48c2f0c misc tuning based on hints by IntelliJ IDEA;
wenzelm
parents: 70102
diff changeset
    41
  val default_components_base: Path = Path.explode("$ISABELLE_COMPONENTS_BASE")
69434
b93404a4c3dd clarified settings and defaults;
wenzelm
parents: 69430
diff changeset
    42
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    43
  def admin(dir: Path): Path = dir + Path.explode("Admin/components")
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    44
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    45
  def contrib(dir: Path = Path.current, name: String = ""): Path =
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    46
    dir + Path.explode("contrib") + Path.explode(name)
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    47
71726
a5fda30edae2 clarified signature: more uniform treatment of stopped/interrupted state;
wenzelm
parents: 71601
diff changeset
    48
  def unpack(dir: Path, archive: Path, progress: Progress = new Progress): String =
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    49
  {
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    50
    val name = Archive.get_name(archive.file_name)
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    51
    progress.echo("Unpacking " + name)
69425
94f6ca69d983 clarified gnutar options: more uniform owner;
wenzelm
parents: 69418
diff changeset
    52
    Isabelle_System.gnutar("-xzf " + File.bash_path(archive), dir = dir).check
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    53
    name
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    54
  }
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    55
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    56
  def resolve(base_dir: Path, names: List[String],
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    57
    target_dir: Option[Path] = None,
70102
e48ffba6b557 retain copy of required components;
wenzelm
parents: 69703
diff changeset
    58
    copy_dir: Option[Path] = None,
71726
a5fda30edae2 clarified signature: more uniform treatment of stopped/interrupted state;
wenzelm
parents: 71601
diff changeset
    59
    progress: Progress = new Progress)
69398
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    60
  {
72375
e48d93811ed7 clarified signature;
wenzelm
parents: 72353
diff changeset
    61
    Isabelle_System.make_directory(base_dir)
69398
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    62
    for (name <- names) {
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    63
      val archive_name = Archive(name)
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    64
      val archive = base_dir + Path.explode(archive_name)
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    65
      if (!archive.is_file) {
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    66
        val remote = Isabelle_System.getenv("ISABELLE_COMPONENT_REPOSITORY") + "/" + archive_name
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    67
        progress.echo("Getting " + remote)
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    68
        Bytes.write(archive, Url.read_bytes(Url(remote)))
69398
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    69
      }
70102
e48ffba6b557 retain copy of required components;
wenzelm
parents: 69703
diff changeset
    70
      for (dir <- copy_dir) {
72375
e48d93811ed7 clarified signature;
wenzelm
parents: 72353
diff changeset
    71
        Isabelle_System.make_directory(dir)
70102
e48ffba6b557 retain copy of required components;
wenzelm
parents: 69703
diff changeset
    72
        File.copy(archive, dir)
e48ffba6b557 retain copy of required components;
wenzelm
parents: 69703
diff changeset
    73
      }
69413
52727566c1ba more explicit Components.Archive;
wenzelm
parents: 69410
diff changeset
    74
      unpack(target_dir getOrElse base_dir, archive, progress = progress)
69398
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    75
    }
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    76
  }
0698ded5caf1 Components.download similar to "isabelle components", but without unpacking;
wenzelm
parents: 69395
diff changeset
    77
69410
c071fcec4323 more explicit Platform.Family;
wenzelm
parents: 69401
diff changeset
    78
  def purge(dir: Path, platform: Platform.Family.Value)
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    79
  {
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    80
    def purge_platforms(platforms: String*): Set[String] =
73090
9db6072eb711 proper purge for arm64-darwin;
wenzelm
parents: 72763
diff changeset
    81
      platforms.flatMap(name =>
9db6072eb711 proper purge for arm64-darwin;
wenzelm
parents: 72763
diff changeset
    82
        List("arm64-" + name, "x86-" + name, "x86_64_32-" + name, "x86_64-" + name)).toSet +
72353
1e5516c55b46 purge arm64-linux --- no build_release support yet;
wenzelm
parents: 71726
diff changeset
    83
      "ppc-darwin" + "arm64-linux"
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    84
    val purge_set =
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    85
      platform match {
69410
c071fcec4323 more explicit Platform.Family;
wenzelm
parents: 69401
diff changeset
    86
        case Platform.Family.linux => purge_platforms("darwin", "cygwin", "windows")
c071fcec4323 more explicit Platform.Family;
wenzelm
parents: 69401
diff changeset
    87
        case Platform.Family.macos => purge_platforms("linux", "cygwin", "windows")
c071fcec4323 more explicit Platform.Family;
wenzelm
parents: 69401
diff changeset
    88
        case Platform.Family.windows => purge_platforms("linux", "darwin")
69401
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    89
      }
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    90
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    91
    File.find_files(dir.file,
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    92
      (file: JFile) => file.isDirectory && purge_set(file.getName),
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    93
      include_dirs = true).foreach(Isabelle_System.rm_tree)
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    94
  }
7a1b7b737c02 eliminated old makedist_bundle and remote_dmg: build_release does everything in Scala;
wenzelm
parents: 69398
diff changeset
    95
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    96
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    97
  /* component directory content */
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
    98
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
    99
  def settings(dir: Path = Path.current): Path = dir + Path.explode("etc/settings")
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   100
  def components(dir: Path = Path.current): Path = dir + Path.explode("etc/components")
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   101
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   102
  def check_dir(dir: Path): Boolean =
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   103
    settings(dir).is_file || components(dir).is_file
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   104
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   105
  def read_components(dir: Path): List[String] =
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   106
    split_lines(File.read(components(dir))).filter(_.nonEmpty)
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   107
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   108
  def write_components(dir: Path, lines: List[String]): Unit =
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   109
    File.write(components(dir), terminate_lines(lines))
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   110
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   111
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   112
  /* component repository content */
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   113
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   114
  val components_sha1: Path = Path.explode("~~/Admin/components/components.sha1")
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   115
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   116
  sealed case class SHA1_Digest(sha1: String, file_name: String)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   117
  {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   118
    override def toString: String = sha1 + "  " + file_name
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   119
  }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   120
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   121
  def read_components_sha1(lines: List[String] = Nil): List[SHA1_Digest] =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   122
    (proper_list(lines) getOrElse split_lines(File.read(components_sha1))).flatMap(line =>
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   123
      Word.explode(line) match {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   124
        case Nil => None
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   125
        case List(sha1, name) => Some(SHA1_Digest(sha1, name))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   126
        case _ => error("Bad components.sha1 entry: " + quote(line))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   127
      })
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   128
71601
97ccf48c2f0c misc tuning based on hints by IntelliJ IDEA;
wenzelm
parents: 70102
diff changeset
   129
  def write_components_sha1(entries: List[SHA1_Digest]): Unit =
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   130
    File.write(components_sha1, entries.sortBy(_.file_name).mkString("", "\n", "\n"))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   131
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   132
73172
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   133
  /** manage user components **/
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   134
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   135
  val components_path = Path.explode("$ISABELLE_HOME_USER/components")
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   136
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   137
  def read_components(): List[String] =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   138
    if (components_path.is_file) Library.trim_split_lines(File.read(components_path))
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   139
    else Nil
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   140
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   141
  def write_components(lines: List[String]): Unit =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   142
  {
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   143
    Isabelle_System.make_directory(components_path.dir)
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   144
    File.write(components_path, Library.terminate_lines(lines))
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   145
  }
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   146
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   147
  def update_components(add: Boolean, path0: Path, progress: Progress = new Progress): Unit =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   148
  {
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   149
    val path = path0.expand.absolute
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   150
    if (!(path + Path.explode("etc/settings")).is_file &&
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   151
        !(path + Path.explode("etc/components")).is_file) error("Bad component directory: " + path)
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   152
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   153
    val lines1 = read_components()
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   154
    val lines2 =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   155
      lines1.filter(line =>
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   156
        line.isEmpty || line.startsWith("#") || !File.eq(Path.explode(line), path))
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   157
    val lines3 = if (add) lines2 ::: List(path.implode) else lines2
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   158
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   159
    if (lines1 != lines3) write_components(lines3)
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   160
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   161
    val prefix = if (lines1 == lines3) "Unchanged" else if (add) "Added" else "Removed"
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   162
    progress.echo(prefix + " component " + path)
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   163
  }
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   164
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   165
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   166
  /* main entry point */
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   167
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   168
  def main(args: Array[String]): Unit =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   169
  {
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   170
    Command_Line.tool {
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   171
      for (arg <- args) {
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   172
        val add =
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   173
          if (arg.startsWith("+")) true
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   174
          else if (arg.startsWith("-")) false
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   175
          else error("Bad argument: " + quote(arg))
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   176
        val path = Path.explode(arg.substring(1))
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   177
        update_components(add, path, progress = new Console_Progress)
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   178
      }
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   179
    }
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   180
  }
fc828f64da5b support isabelle components -u and -x;
wenzelm
parents: 73090
diff changeset
   181
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   182
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   183
  /** build and publish components **/
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   184
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   185
  def build_components(
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   186
    options: Options,
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   187
    components: List[Path],
71726
a5fda30edae2 clarified signature: more uniform treatment of stopped/interrupted state;
wenzelm
parents: 71601
diff changeset
   188
    progress: Progress = new Progress,
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   189
    publish: Boolean = false,
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   190
    force: Boolean = false,
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   191
    update_components_sha1: Boolean = false)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   192
  {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   193
    val archives: List[Path] =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   194
      for (path <- components) yield {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   195
        path.file_name match {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   196
          case Archive(_) => path
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   197
          case name =>
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   198
            if (!path.is_dir) error("Bad component directory: " + path)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   199
            else if (!check_dir(path)) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   200
              error("Malformed component directory: " + path +
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   201
                "\n  (requires " + settings() + " or " + Components.components() + ")")
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   202
            }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   203
            else {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   204
              val component_path = path.expand
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   205
              val archive_dir = component_path.dir
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   206
              val archive_name = Archive(name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   207
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   208
              val archive = archive_dir + Path.explode(archive_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   209
              if (archive.is_file && !force) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   210
                error("Component archive already exists: " + archive)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   211
              }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   212
69439
22d4cb91ea6d tuned message;
wenzelm
parents: 69434
diff changeset
   213
              progress.echo("Packaging " + archive_name)
69430
684935cbc8e1 proper path before tar -C context switch;
wenzelm
parents: 69429
diff changeset
   214
              Isabelle_System.gnutar("-czf " + File.bash_path(archive) + " " + Bash.string(name),
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   215
                dir = archive_dir).check
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   216
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   217
              archive
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   218
            }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   219
        }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   220
      }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   221
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   222
    if ((publish && archives.nonEmpty) || update_components_sha1) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   223
      options.string("isabelle_components_server") match {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   224
        case SSH.Target(user, host) =>
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   225
          using(SSH.open_session(options, host = host, user = user))(ssh =>
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   226
          {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   227
            val components_dir = Path.explode(options.string("isabelle_components_dir"))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   228
            val contrib_dir = Path.explode(options.string("isabelle_components_contrib_dir"))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   229
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   230
            for (dir <- List(components_dir, contrib_dir) if !ssh.is_dir(dir)) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   231
              error("Bad remote directory: " + dir)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   232
            }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   233
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   234
            if (publish) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   235
              for (archive <- archives) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   236
                val archive_name = archive.file_name
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   237
                val name = Archive.get_name(archive_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   238
                val remote_component = components_dir + archive.base
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   239
                val remote_contrib = contrib_dir + Path.explode(name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   240
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   241
                // component archive
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   242
                if (ssh.is_file(remote_component) && !force) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   243
                  error("Remote component archive already exists: " + remote_component)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   244
                }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   245
                progress.echo("Uploading " + archive_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   246
                ssh.write_file(remote_component, archive)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   247
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   248
                // contrib directory
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   249
                val is_standard_component =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   250
                  Isabelle_System.with_tmp_dir("component")(tmp_dir =>
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   251
                  {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   252
                    Isabelle_System.gnutar("-xzf " + File.bash_path(archive), dir = tmp_dir).check
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   253
                    check_dir(tmp_dir + Path.explode(name))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   254
                  })
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   255
                if (is_standard_component) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   256
                  if (ssh.is_dir(remote_contrib)) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   257
                    if (force) ssh.rm_tree(remote_contrib)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   258
                    else error("Remote component directory already exists: " + remote_contrib)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   259
                  }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   260
                  progress.echo("Unpacking remote " + archive_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   261
                  ssh.execute("tar -C " + ssh.bash_path(contrib_dir) + " -xzf " +
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   262
                    ssh.bash_path(remote_component)).check
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   263
                }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   264
                else {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   265
                  progress.echo_warning("No unpacking of non-standard component: " + archive_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   266
                }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   267
              }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   268
            }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   269
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   270
            // remote SHA1 digests
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   271
            if (update_components_sha1) {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   272
              val lines =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   273
                for {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   274
                  entry <- ssh.read_dir(components_dir)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   275
                  if entry.is_file && entry.name.endsWith(Archive.suffix)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   276
                }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   277
                yield {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   278
                  progress.echo("Digesting remote " + entry.name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   279
                  Library.trim_line(
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   280
                    ssh.execute("cd " + ssh.bash_path(components_dir) +
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   281
                      "; sha1sum " + Bash.string(entry.name)).check.out)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   282
                }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   283
              write_components_sha1(read_components_sha1(lines))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   284
            }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   285
          })
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   286
        case s => error("Bad isabelle_components_server: " + quote(s))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   287
      }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   288
    }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   289
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   290
    // local SHA1 digests
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   291
    {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   292
      val new_entries =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   293
        for (archive <- archives)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   294
        yield {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   295
          val file_name = archive.file_name
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   296
          progress.echo("Digesting local " + file_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   297
          val sha1 = SHA1.digest(archive).rep
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   298
          SHA1_Digest(sha1, file_name)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   299
        }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   300
      val new_names = new_entries.map(_.file_name).toSet
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   301
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   302
      write_components_sha1(
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   303
        new_entries :::
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   304
        read_components_sha1().filterNot(entry => new_names.contains(entry.file_name)))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   305
    }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   306
  }
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   307
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   308
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   309
  /* Isabelle tool wrapper */
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   310
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   311
  private val relevant_options =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   312
    List("isabelle_components_server", "isabelle_components_dir", "isabelle_components_contrib_dir")
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   313
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   314
  val isabelle_tool =
72763
3cc73d00553c added document antiquotation @{tool};
wenzelm
parents: 72375
diff changeset
   315
    Isabelle_Tool("build_components", "build and publish Isabelle components",
3cc73d00553c added document antiquotation @{tool};
wenzelm
parents: 72375
diff changeset
   316
      Scala_Project.here, args =>
69429
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   317
    {
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   318
      var publish = false
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   319
      var update_components_sha1 = false
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   320
      var force = false
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   321
      var options = Options.init()
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   322
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   323
      def show_options: String =
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   324
        cat_lines(relevant_options.map(name => options.options(name).print))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   325
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   326
      val getopts = Getopts("""
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   327
Usage: isabelle build_components [OPTIONS] ARCHIVES... DIRS...
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   328
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   329
  Options are:
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   330
    -P           publish on SSH server (see options below)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   331
    -f           force: overwrite existing component archives and directories
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   332
    -o OPTION    override Isabelle system OPTION (via NAME=VAL or NAME)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   333
    -u           update all SHA1 keys in Isabelle repository Admin/components
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   334
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   335
  Build and publish Isabelle components as .tar.gz archives on SSH server,
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   336
  depending on system options:
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   337
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   338
""" + Library.prefix_lines("  ", show_options) + "\n",
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   339
        "P" -> (_ => publish = true),
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   340
        "f" -> (_ => force = true),
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   341
        "o:" -> (arg => options = options + arg),
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   342
        "u" -> (_ => update_components_sha1 = true))
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   343
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   344
      val more_args = getopts(args)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   345
      if (more_args.isEmpty && !update_components_sha1) getopts.usage()
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   346
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   347
      val progress = new Console_Progress
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   348
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   349
      build_components(options, more_args.map(Path.explode), progress = progress,
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   350
        publish = publish, force = force, update_components_sha1 = update_components_sha1)
dc5fbcb07c7b replaced "isabelle components_checksum" shell script by "isabelle build_components" in Scala, with more functionality;
wenzelm
parents: 69426
diff changeset
   351
    })
69395
d1c4a1dee9e7 more explicit support for Isabelle system components;
wenzelm
parents:
diff changeset
   352
}