blob: bd41350aa44203c889c9eab83ad132ce9cde0676 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/** When using `AbstractTransformed` abstract inner class in views in order
* to force generating bridges, one must take care to push the corresponding
* collection trait (such as `Iterable` or `Seq`) as far as possible to the
* left in the linearization order -- otherwise, overridden methods from these
* traits can override the already overridden methods in view. This was the
* case with `takeWhile`.
* Mind blowing, I know.
*/
object Test {
def main(args: Array[String]): Unit = {
println("bar".view.reverse.filter(_ > 'a').mkString(","))
println("bar".view.reverse.take(1).mkString(","))
println("bar".view.reverse.dropWhile(_ > 'a').mkString(","))
println("bar".view.reverse.takeWhile(_ => true).mkString(","))
}
}
|