src/Pure/Tools/isabelle_system.scala
author wenzelm
Thu, 28 Aug 2008 19:29:59 +0200
changeset 28046 1447932b1b13
parent 27993 6dd90ef9f927
child 28057 6b90e6532d51
permissions -rw-r--r--
added is_cygwin; added exec2, which joins stdout/stderr; tuned thread arrangement;
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
28046
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    16
  /* Isabelle environment settings */
27919
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
  def getenv_strict(name: String) = {
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    24
    val value = getenv(name)
27993
6dd90ef9f927 simplified exceptions: use plain error function / RuntimeException;
wenzelm
parents: 27974
diff changeset
    25
    if (value != "") value else error("Undefined environment variable: " + name)
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    26
  }
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    27
28046
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    28
  def is_cygwin() = Pattern.matches(".*-cygwin", getenv_strict("ML_PLATFORM"))
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    29
27936
947cb8e3d313 added get_setting;
wenzelm
parents: 27919
diff changeset
    30
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    31
  /* file path specifications */
27936
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
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    74
  /* processes */
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    75
28046
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    76
  private def posix_prefix() = if (is_cygwin()) List(platform_path("/bin/env")) else Nil
27953
b2003c98897c added getenv;
wenzelm
parents: 27936
diff changeset
    77
27974
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    78
  def exec(args: List[String]) = Runtime.getRuntime.exec((posix_prefix() ++ args).toArray)
1dfb0e260e4c added exec;
wenzelm
parents: 27962
diff changeset
    79
28046
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    80
  def exec2(args: List[String]) = {
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    81
    val cmdline = new java.util.LinkedList[String]
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    82
    for (s <- posix_prefix() ++ args) cmdline.add(s)
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    83
    new ProcessBuilder(cmdline).redirectErrorStream(true).start
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    84
  }
1447932b1b13 added is_cygwin;
wenzelm
parents: 27993
diff changeset
    85
27919
1eb8a3902d49 Isabelle system support.
wenzelm
parents:
diff changeset
    86
}