Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Lazily coalesce Options in Scala

I have several ways of calculating a value, in decreasing preference.

firstWay()
second() + way()
orA(thirdWay())

Each of these returns an Option. I want to "coalesce" these and get an Option which the the value returned by the first Some of these, or None if all returned None.

Of course, if firstWay() returns a Some, I shouldn't calculate the rest.

What is the most idiomatic (or at least reasonably readable) way to do this?

like image 948
Paul Draper Avatar asked Feb 18 '14 01:02

Paul Draper


2 Answers

firstWay().orElse(second() + way()).orElse(orA(thirdWay()))

orElse's argument is lazily evaluated.

See the documentation.

like image 142
Karol S Avatar answered Nov 11 '22 04:11

Karol S


If you have enough ways that Karol's answer becomes unwieldy, or don't know in advance how many:

val options: Stream[Option[A]] = ...
// in the example: firstWay() #:: (second() + way()) #:: orA(thirdWay())

options.foldLeft[Option[A]](None)(_.orElse(_))
like image 2
Alexey Romanov Avatar answered Nov 11 '22 04:11

Alexey Romanov