trait OptionSugar extends AnyRef
Trait providing an implicit class that adds a toOr
method to
Option
, which converts Some
to Good
,
None
to Bad
.
You can use the toOr
method to record information about why
a processing of nested Option
s resulted in None
.
For example, the following for
expression results in
None
if either the passed optional Person
is
None
or else if the contained optional age is None
:
scala> case class Person(name: String, age: Option[Int]) defined class Person scala> def ageOf(person: Option[Person]) = | for { | per <- person | age <- per.age | } yield age ageOf: (person: Option[Person])Option[Int] scala> ageOf(Some(Person("Ralph", Some(32)))) res0: Option[Int] = Some(32) scala> ageOf(Some(Person("Curt", None))) res3: Option[Int] = None scala> ageOf(None) res2: Option[Int] = None
If you instead populate the for
expression with Or
s,
supplying an error message or other "bad" value to the toOr
method
in case of None
, you'll get an indication of which part
failed if a None
is encountered:
scala> import OptionSugar._ import OptionSugar._ scala> def ageOf(person: Option[Person]) = | for { | per <- person toOr "no person here" | age <- per.age toOr "ageless person" | } yield age ageOf: (person: Option[Person])org.scalactic.Or[Int,String] scala> ageOf(Some(Person("Ralph", Some(32)))) res1: org.scalactic.Or[Int,String] = Good(32) scala> ageOf(Some(Person("Curt", None))) res2: org.scalactic.Or[Int,String] = Bad(ageless person) scala> ageOf(None) res3: org.scalactic.Or[Int,String] = Bad(no person here)
- Source
- OptionSugar.scala
Linear Supertypes
Known Subclasses
Ordering
- Alphabetic
- By Inheritance
Inherited
- OptionSugar
- AnyRef
- Any
- Hide All
- Show All
Visibility
- Public
- All
Type Members
-
implicit
class
Optionizer[G] extends AnyRef
Implicit class that adds a
toOr
method toOption
, which convertsSome
toGood
,None
toBad
.
Value Members
-
final
def
!=(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
##(): Int
- Definition Classes
- AnyRef → Any
-
final
def
==(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
final
def
asInstanceOf[T0]: T0
- Definition Classes
- Any
-
def
clone(): AnyRef
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @native() @throws( ... )
-
final
def
eq(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
def
equals(arg0: Any): Boolean
- Definition Classes
- AnyRef → Any
-
def
finalize(): Unit
- Attributes
- protected[java.lang]
- Definition Classes
- AnyRef
- Annotations
- @throws( classOf[java.lang.Throwable] )
-
final
def
getClass(): Class[_]
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
-
def
hashCode(): Int
- Definition Classes
- AnyRef → Any
- Annotations
- @native()
-
final
def
isInstanceOf[T0]: Boolean
- Definition Classes
- Any
-
final
def
ne(arg0: AnyRef): Boolean
- Definition Classes
- AnyRef
-
final
def
notify(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
-
final
def
notifyAll(): Unit
- Definition Classes
- AnyRef
- Annotations
- @native()
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
- Definition Classes
- AnyRef
-
def
toString(): String
- Definition Classes
- AnyRef → Any
-
final
def
wait(): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long, arg1: Int): Unit
- Definition Classes
- AnyRef
- Annotations
- @throws( ... )
-
final
def
wait(arg0: Long): Unit
- Definition Classes
- AnyRef
- Annotations
- @native() @throws( ... )