1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
/* __ *\
** ________ ___ / / ___ Scala API **
** / __/ __// _ | / / / _ | (c) 2002-2010, LAMP/EPFL **
** __\ \/ /__/ __ |/ /__/ __ | http://scala-lang.org/ **
** /____/\___/_/ |_/____/_/ | | **
** |/ **
\* */
// generated by genprod on Thu Sep 09 09:06:40 PDT 2010 (with fancy comment) (with extra methods)
package scala
/** <p>
* Function with 1 parameter.
* </p>
* <p>
* In the following example the definition of
* <code>succ</code> is a shorthand for the anonymous class
* definition <code>anonfun1</code>:
* </p>
* <pre>
* <b>object</b> Main <b>extends</b> Application {
*
* <b>val</b> succ = (x: Int) => x + 1
*
* <b>val</b> anonfun1 = <b>new</b> Function1[Int, Int] {
* <b>def</b> apply(x: Int): Int = x + 1
* }
*
* println(succ(0))
* println(anonfun1(0))
* }</pre>
*/
trait Function1[@specialized(scala.Int, scala.Long, scala.Float, scala.Double) -T1, @specialized(scala.Unit, scala.Boolean, scala.Int, scala.Float, scala.Long, scala.Double) +R] extends AnyRef { self =>
def apply(v1:T1): R
override def toString() = "<function1>"
/** (f compose g)(x) == f(g(x))
*/
def compose[A](g: A => T1): A => R = { x => apply(g(x)) }
/** (f andThen g)(x) == g(f(x))
*/
def andThen[A](g: R => A): T1 => A = { x => g(apply(x)) }
/** Turns a function A => Option[B] into a PartialFunction[A, B]. Important note:
* this transformation implies the original function will be called 2 or more
* times on each logical invocation, because the only way to supply an implementation
* of isDefinedAt is to call the function and examine the return value.
*
* @see PartialFunction#lift
* @return a partial function which is defined for those inputs
* where this function returns Some(_) and undefined where
* this function returns None.
*/
def unlift[R1](implicit ev: R <:< Option[R1]): PartialFunction[T1, R1] = new PartialFunction[T1, R1] {
def apply(x: T1): R1 = ev(Function1.this.apply(x)).get
def isDefinedAt(x: T1): Boolean = Function1.this.apply(x).isDefined
override def lift = Function1.this.asInstanceOf[T1 => Option[R1]]
}
}
|