src/Pure/Tools/isabelle_system.scala
author wenzelm
Sat, 23 Aug 2008 17:22:54 +0200
changeset 27953 b2003c98897c
parent 27936 947cb8e3d313
child 27956 84bfb2162dd2
permissions -rw-r--r--
added getenv; renamed get_setting to getenv_strict; added shell_prefix (for Cygwin);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     1
/*  Title:      Pure/Tools/isabelle_system.scala
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     3
    Author:     Makarius
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     4
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
     5
Isabelle system support: settings and path specifications.
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     6
*/
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     7
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     8
package isabelle
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
     9
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    10
import java.util.regex.{Pattern, Matcher}
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    11
import java.io.File
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    12
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    13
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    14
object IsabelleSystem {
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    15
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    16
  /* Isabelle settings */
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    17
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    18
  def getenv(name: String) = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    19
    val value = System.getenv(name)
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    20
    if (value != null) value else ""
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    21
  }
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    22
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    23
  class BadVariable(val name: String) extends Exception
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    24
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    25
  def getenv_strict(name: String) = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    26
    val value = getenv(name)
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    27
    if (value != "") value else throw new BadVariable(name)
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    28
  }
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    29
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    30
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    31
  /* File path specifications */
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    32
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    33
  private val cygdrive_pattern = Pattern.compile("/cygdrive/([a-zA-Z])($|/.*)")
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    34
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    35
  def platform_path(source_path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    36
    val result_path = new StringBuilder
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    37
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    38
    def init(path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    39
      val cygdrive = cygdrive_pattern.matcher(path)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    40
      if (cygdrive.matches) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    41
        result_path.length = 0
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    42
        result_path.append(cygdrive.group(1))
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    43
        result_path.append(":")
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    44
        result_path.append(File.separator)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    45
        cygdrive.group(2)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    46
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    47
      else if (path.startsWith("/")) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    48
        result_path.length = 0
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    49
        result_path.append(getenv_strict("ISABELLE_ROOT_JVM"))
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    50
        path.substring(1)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    51
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    52
      else path
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    53
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    54
    def append(path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    55
      for (p <- init(path).split("/")) {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    56
        if (p != "") {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    57
          val len = result_path.length
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    58
          if (len > 0 && result_path(len - 1) != File.separatorChar)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    59
            result_path.append(File.separator)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    60
          result_path.append(p)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    61
        }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    62
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    63
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    64
    for (p <- init(source_path).split("/")) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    65
      if (p.startsWith("$")) append(getenv_strict(p.substring(1)))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    66
      else if (p == "~") append(getenv_strict("HOME"))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    67
      else if (p == "~~") append(getenv_strict("ISABELLE_HOME"))
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    68
      else append(p)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    69
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    70
    result_path.toString
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    71
  }
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    72
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    73
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    74
  /* Cygwin shell prefix */
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    75
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    76
  def shell_prefix() = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    77
    if (Pattern.matches(".*-cygwin", getenv_strict("ML_PLATFORM")))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    78
      Some(platform_path("/usr/bin/env"))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    79
    else None
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    80
  }
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    81
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    82
}