trait
TypeCoercion extends AnyRef
Value Members
-
final
def
!=(arg0: AnyRef): Boolean
-
final
def
!=(arg0: Any): Boolean
-
final
def
##(): Int
-
final
def
==(arg0: AnyRef): Boolean
-
final
def
==(arg0: Any): Boolean
-
final
def
asInstanceOf[T0]: T0
-
def
clone(): AnyRef
-
def
coercion[A, B](implicit a: RefInfo[A], b: RefInfo[B]): Option[(A) ⇒ B]
-
final
def
eq(arg0: AnyRef): Boolean
-
def
equals(arg0: Any): Boolean
-
def
finalize(): Unit
-
final
def
getClass(): Class[_]
-
def
hashCode(): Int
-
final
def
isInstanceOf[T0]: Boolean
-
final
def
ne(arg0: AnyRef): Boolean
-
final
def
notify(): Unit
-
final
def
notifyAll(): Unit
-
final
def
synchronized[T0](arg0: ⇒ T0): T0
-
def
toString(): String
-
final
def
wait(): Unit
-
final
def
wait(arg0: Long, arg1: Int): Unit
-
final
def
wait(arg0: Long): Unit
Provides over 200 coercions between types. This works for the following matrix of types:
Where the label abbreviations are:
and value abbreviations are:
The rationale behind not supplying coercion from Strings is that too many exceptions can be thrown during the coercion process. Coercions from String to character have issues with the empty string. One could call one of the following but they all throw exceptions:
Conversion to Boolean from Numbers and vice versa is not supported because there are a number of ways to do this: