scala.sys.PropImpl.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of scala-library Show documentation
Show all versions of scala-library Show documentation
Standard library for the Scala Programming Language
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2003-2013, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
package scala.sys
import scala.collection.mutable
/** The internal implementation of scala.sys.Prop.
*/
private[sys] class PropImpl[+T](val key: String, valueFn: String => T) extends Prop[T] {
def value: T = if (isSet) valueFn(get) else zero
def isSet = underlying contains key
def set(newValue: String): String = {
val old = if (isSet) get else null
underlying(key) = newValue
old
}
def setValue[T1 >: T](newValue: T1): T = {
val old = value
if (newValue == null) set(null)
else set("" + newValue)
old
}
def get: String =
if (isSet) underlying.getOrElse(key, "")
else ""
def clear(): Unit = underlying -= key
def option: Option[T] = if (isSet) Some(value) else None
def or[T1 >: T](alt: => T1): T1 = if (isSet) value else alt
/** The underlying property map, in our case always sys.props */
protected def underlying: mutable.Map[String, String] = scala.sys.props
protected def zero: T = null.asInstanceOf[T]
private def getString = if (isSet) "currently: " + get else "unset"
override def toString = "%s (%s)".format(key, getString)
}
private[sys] abstract class CreatorImpl[+T](f: String => T) extends Prop.Creator[T] {
def apply(key: String): Prop[T] = new PropImpl[T](key, f)
}