As long as we have a PartialFunction[X,R]
it's very easy to convert it to a function returning Option[R]
, e.g.
def pfToOptf[X, R](f: PartialFunction[X,R])(x: X) =
if (f.isDefinedAt(x)) Some(f(x))
else None
However, what if the task is opposite: suppose I have a function f
getting X
as an argument and returning Option[R]
as a result. And I want to make a PartialFunction[X,R]
out of it. What is the best way?
What I've come up with looks pretty ugly to my taste:
def optfToPf[X,R](f: X => Option[R]) : PartialFunction[X,R] = {
object extractor {
def unapply(x: X): Option[R] = f(x)
}
{ case extractor(r) => r }
}
Is there some better way I missed?
How about this:
I suppose you could override apply and isDefinedAt by hand, but I'd do it the way you find ugly.
Testing:
I know this is an old thread, but if anyone else comes across this, Function.unlift does precisely this.