src/Pure/Tools/isabelle_system.scala
author wenzelm
Sat, 23 Aug 2008 23:07:46 +0200
changeset 27974 1dfb0e260e4c
parent 27962 28a306e675ba
child 27993 6dd90ef9f927
permissions -rw-r--r--
added exec; private posix_prefix;
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
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
     5
Isabelle system support -- basic Cygwin/Posix compatibility.
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
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    33
  /* file path specifications */
27936
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
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    76
  /* processes */
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    77
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    78
  private def posix_prefix() = {
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    79
    if (Pattern.matches(".*-cygwin", getenv_strict("ML_PLATFORM")))
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    80
      List(platform_path("/bin/env"))
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    81
    else Nil
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    82
  }
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    83
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    84
  def exec(args: List[String]) = Runtime.getRuntime.exec((posix_prefix() ++ args).toArray)
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    85
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    86
}