src/Pure/Admin/other_isabelle.scala
author wenzelm
Mon, 09 Oct 2017 17:09:08 +0200
changeset 66820 fc516da7ee4f
parent 65930 9a28fc03c3fe
child 67045 6c94f749410a
permissions -rw-r--r--
some administrative support for AFP;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Admin/other_isabelle.scala
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     3
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     4
Manage other Isabelle distributions.
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     5
*/
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     6
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     7
package isabelle
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     8
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
     9
64315
e48e2532ac17 proper echo;
wenzelm
parents: 64304
diff changeset
    10
class Other_Isabelle(progress: Progress, val isabelle_home: Path, val isabelle_identifier: String)
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    11
{
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    12
  other_isabelle =>
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    13
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    14
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    15
  /* static system */
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    16
65930
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    17
  def bash(
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    18
      script: String,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    19
      redirect: Boolean = false,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    20
      echo: Boolean = false,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    21
      strict: Boolean = true): Process_Result =
65916
wenzelm
parents: 65845
diff changeset
    22
    progress.bash(Isabelle_System.export_isabelle_identifier(isabelle_identifier) + script,
65930
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    23
      env = null, cwd = isabelle_home.file, redirect = redirect, echo = echo, strict = strict)
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    24
65930
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    25
  def apply(
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    26
      cmdline: String,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    27
      redirect: Boolean = false,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    28
      echo: Boolean = false,
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    29
      strict: Boolean = true): Process_Result =
9a28fc03c3fe tuned signature;
wenzelm
parents: 65916
diff changeset
    30
    bash("bin/isabelle " + cmdline, redirect = redirect, echo = echo, strict = strict)
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    31
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    32
  def resolve_components(echo: Boolean): Unit =
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    33
    other_isabelle("components -a", redirect = true, echo = echo).check
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    34
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    35
  val isabelle_home_user: Path =
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    36
    Path.explode(other_isabelle("getenv -b ISABELLE_HOME_USER").check.out)
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    37
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    38
  val etc_settings: Path = isabelle_home_user + Path.explode("etc/settings")
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    39
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    40
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    41
  /* init settings */
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    42
65845
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    43
  def init_settings(components_base: String, nonfree: Boolean, more_settings: List[String])
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    44
  {
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    45
    if (etc_settings.is_file && !File.read(etc_settings).startsWith("# generated by Isabelle"))
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    46
      error("Cannot proceed with existing user settings file: " + etc_settings)
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    47
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    48
    Isabelle_System.mkdirs(etc_settings.dir)
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    49
    File.write(etc_settings,
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    50
      "# generated by Isabelle " + Date.now() + "\n" +
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    51
      "#-*- shell-script -*- :mode=shellscript:\n")
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    52
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    53
    val component_settings =
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    54
    {
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    55
      val components_base_path =
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    56
        if (components_base == "") isabelle_home_user.dir + Path.explode("contrib")
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    57
        else Path.explode(components_base).expand
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    58
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    59
      val catalogs =
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    60
        if (nonfree) List("main", "optional", "nonfree") else List("main", "optional")
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    61
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    62
      catalogs.map(catalog =>
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    63
        "init_components " + File.bash_path(components_base_path) +
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    64
          " \"$ISABELLE_HOME/Admin/components/" + catalog + "\"")
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    65
    }
65845
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    66
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    67
    val settings =
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    68
      List(component_settings) :::
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    69
      (if (more_settings.isEmpty) Nil else List(more_settings))
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    70
b8ff63149256 proper init_settings, before inspecting ML_HOME etc;
wenzelm
parents: 64315
diff changeset
    71
    File.append(etc_settings, "\n" + cat_lines(settings.map(terminate_lines(_))))
64188
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    72
  }
f88bae1922c4 clarified modules;
wenzelm
parents:
diff changeset
    73
}