diff options
author | Paul Phillips <paulp@improving.org> | 2009-03-16 13:03:02 +0000 |
---|---|---|
committer | Paul Phillips <paulp@improving.org> | 2009-03-16 13:03:02 +0000 |
commit | 00d196adeeb3aa88f2afedcb5d7eb51f0fc19896 (patch) | |
tree | 856ab3879e450c929c04907551acd6898fa51ede /src/library | |
parent | ff9887891f8f865617c60351a3afc8daced2db0e (diff) | |
download | scala-00d196adeeb3aa88f2afedcb5d7eb51f0fc19896.tar.gz scala-00d196adeeb3aa88f2afedcb5d7eb51f0fc19896.tar.bz2 scala-00d196adeeb3aa88f2afedcb5d7eb51f0fc19896.zip |
Various cleanups and redundancy-removal related...
Various cleanups and redundancy-removal related to properties.
Diffstat (limited to 'src/library')
-rw-r--r-- | src/library/scala/util/Properties.scala | 24 |
1 files changed, 16 insertions, 8 deletions
diff --git a/src/library/scala/util/Properties.scala b/src/library/scala/util/Properties.scala index 45ccb15985..8f45c2b388 100644 --- a/src/library/scala/util/Properties.scala +++ b/src/library/scala/util/Properties.scala @@ -30,6 +30,7 @@ private[scala] trait PropertiesTrait props } + protected def onull[T <: AnyRef](x: T) = if (x eq null) None else Some(x) private def quietlyDispose(action: => Unit, disposal: => Unit) = try { action } finally { @@ -38,12 +39,13 @@ private[scala] trait PropertiesTrait } // for values based on system properties - protected def sysprop(name: String, default: String) = - System.getProperty(name, default) + def sysprop(name: String): String = sysprop(name, "") + def sysprop(name: String, default: String): String = System.getProperty(name, default) + def syspropset(name: String, value: String) = System.setProperty(name, value) // for values based on propFilename - protected def prop(name: String, default: String): String = - props.getProperty(name, default) + def prop(name: String): String = props.getProperty(name, "") + def prop(name: String, default: String): String = props.getProperty(name, default) // XXX file.encoding should not be here, as it causes system setting to // be ignored. See https://lampsvn.epfl.ch/trac/scala/ticket/1581 @@ -54,13 +56,19 @@ private[scala] trait PropertiesTrait val versionString = "version " + prop("version.number", "(unknown)") val copyrightString = prop("copyright.string", "(c) 2002-2009 LAMP/EPFL") val encodingString = prop("file.encoding", "UTF8") - val isWin = sysprop("os.name", "") startsWith "Windows" - val isMac = sysprop("java.vendor", "") startsWith "Apple" - val scalaHome = sysprop("scala.home", null) + val isWin = sysprop("os.name") startsWith "Windows" + val isMac = sysprop("java.vendor") startsWith "Apple" + val javaClassPath = sysprop("java.class.path") + val javaHome = sysprop("java.home") + val javaVmName = sysprop("java.vm.name") + val javaVmVersion = sysprop("java.vm.version") + val javaVmInfo = sysprop("java.vm.info") + val javaVersion = sysprop("java.version") + val scalaHome = sysprop("scala.home", null) // XXX places do null checks... // provide a main method so version info can be obtained by running this private val writer = new java.io.PrintWriter(Console.err, true) - private val versionMsg = "Scala %s %s -- %s".format(propCategory, versionString, copyrightString) + def versionMsg = "Scala %s %s -- %s".format(propCategory, versionString, copyrightString) def main(args: Array[String]) { writer println versionMsg } } |