src/Pure/Tools/isabelle_system.scala
author wenzelm
Sat, 23 Aug 2008 19:42:16 +0200
changeset 27962 28a306e675ba
parent 27956 84bfb2162dd2
child 27974 1dfb0e260e4c
permissions -rw-r--r--
shell_prefix: physical /bin/env on 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
27956
84bfb2162dd2 BadVariable: toString;
wenzelm
parents: 27953
diff changeset
    23
  class BadVariable(val name: String) extends Exception {
84bfb2162dd2 BadVariable: toString;
wenzelm
parents: 27953
diff changeset
    24
    override def toString = "BadVariable: " + name
84bfb2162dd2 BadVariable: toString;
wenzelm
parents: 27953
diff changeset
    25
  }
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    26
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    27
  def getenv_strict(name: String) = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    28
    val value = getenv(name)
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    29
    if (value != "") value else throw new BadVariable(name)
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    30
  }
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    31
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    32
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    33
  /* File path specifications */
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    34
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    35
  private val cygdrive_pattern = Pattern.compile("/cygdrive/([a-zA-Z])($|/.*)")
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    36
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    37
  def platform_path(source_path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    38
    val result_path = new StringBuilder
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    39
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    40
    def init(path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    41
      val cygdrive = cygdrive_pattern.matcher(path)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    42
      if (cygdrive.matches) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    43
        result_path.length = 0
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    44
        result_path.append(cygdrive.group(1))
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    45
        result_path.append(":")
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    46
        result_path.append(File.separator)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    47
        cygdrive.group(2)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    48
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    49
      else if (path.startsWith("/")) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    50
        result_path.length = 0
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    51
        result_path.append(getenv_strict("ISABELLE_ROOT_JVM"))
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    52
        path.substring(1)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    53
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    54
      else path
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    55
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    56
    def append(path: String) = {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    57
      for (p <- init(path).split("/")) {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    58
        if (p != "") {
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    59
          val len = result_path.length
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    60
          if (len > 0 && result_path(len - 1) != File.separatorChar)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    61
            result_path.append(File.separator)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    62
          result_path.append(p)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    63
        }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    64
      }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    65
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    66
    for (p <- init(source_path).split("/")) {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    67
      if (p.startsWith("$")) append(getenv_strict(p.substring(1)))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    68
      else if (p == "~") append(getenv_strict("HOME"))
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    69
      else if (p == "~~") append(getenv_strict("ISABELLE_HOME"))
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    70
      else append(p)
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    71
    }
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    72
    result_path.toString
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    73
  }
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    74
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    75
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    76
  /* Cygwin shell prefix */
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    77
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    78
  def shell_prefix() = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    79
    if (Pattern.matches(".*-cygwin", getenv_strict("ML_PLATFORM")))
27962
28a306e675ba shell_prefix: physical /bin/env on Cygwin;
wenzelm
parents: 27956
diff changeset
    80
      Some(platform_path("/bin/env"))
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    81
    else None
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    82
  }
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    83
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    84
}