|
Scala example source code file (hk-infer.scala)
The Scala hk-infer.scala source code
object Basis {
final case class X[T](t: T)
val x = Seq(X(32))
val y = Seq(X(true))
val x1 = Seq(X("asdf"))
val x2 = Seq(X('d'))
}
import Basis._
object DoesWork {
// Doesn'tWork
// def f1 = x ++ y ++ x1 ++ x2
def f2 = List(x, y, x1, x2).flatten
}
// Testing the not giving of explicit Booper[M] arguments.
object ShouldWorkHK {
class Booper[M[_]](xs: Seq[M[_]]) extends collection.generic.SeqForwarder[M[_]] {
def underlying = xs
def BOOP(ys: Seq[M[_]]) = new Booper(xs ++ ys)
}
implicit def mkBoop[M[_]](xs: Seq[M[_]]) = new Booper(xs)
def f1 = x BOOP y BOOP x1 BOOP x2
}
object DoesWorkHK {
class Booper[M[_]](xs: Seq[M[_]]) extends collection.generic.SeqForwarder[M[_]] {
def underlying = xs
def BOOP(ys: Seq[M[_]]) = new Booper[M](xs ++ ys)
}
implicit def mkBoop[M[_]](xs: Seq[M[_]]) = new Booper[M](xs)
def f1 = x BOOP y BOOP x1 BOOP x2
}
Other Scala examples (source code examples)Here is a short list of links related to this Scala hk-infer.scala source code file: |
| ... this post is sponsored by my books ... | |
#1 New Release! |
FP Best Seller |
Copyright 1998-2024 Alvin Alexander, alvinalexander.com
All Rights Reserved.
A percentage of advertising revenue from
pages under the /java/jwarehouse
URI on this website is
paid back to open source projects.