EDITARcontinuación es mi respuesta original, pero se puede lograr esto ahora con
def asInstanceOfOption[T: ClassTag](o: Any): Option[T] =
Some(o) collect { case m: T => m}
Se podría utilizar manifiestos de moverse por el hecho de que el tipo T
es borran en tiempo de compilación:
scala> import scala.reflect._
import scala.reflect._
scala> def asInstanceOfOption[B](x : Any)(implicit m: Manifest[B]) : Option[B] = {
| if (Manifest.singleType(x) <:< m)
| Some(x.asInstanceOf[B])
| else
| None
| }
asInstanceOfOption: [B](x: Any)(implicit m: scala.reflect.Manifest[B])Option[B]
entonces esto podría ser utilizado:
scala> asInstanceOfOption[Int]("Hello")
res1: Option[Int] = None
scala> asInstanceOfOption[String]("World")
res2: Option[String] = Some(World)
Incluso puede utilizar las conversiones implícitas para conseguir que esto sea un método disponible en Any
. Creo que prefiero el nombre del método matchInstance
:
implicit def any2optionable(x : Any) = new { //structural type
def matchInstance[B](implicit m: Manifest[B]) : Option[B] = {
if (Manifest.singleType(x) <:< m)
Some(x.asInstanceOf[B])
else
None
}
}
Ahora puede escribir código como:
"Hello".matchInstance[String] == Some("Hello") //true
"World".matchInstance[Int] == None //true
EDIT: código actualizado para 2.9.x, donde no se puede utilizar Any
pero sólo AnyRef
:
implicit def any2optionable(x : AnyRef) = new { //structural type
def matchInstance[B](implicit m: Manifest[B]) : Option[B] = {
if (Manifest.singleType(x) <:< m)
Some(x.asInstanceOf[B])
else
None
}
}
Esa es una expresión muy inteligente, y la respuesta de oxbow también fue muy inteligente. –
@Daniel - ¡gracias por el elogio! –