summaryrefslogtreecommitdiff
path: root/test/files/pos/t5156.scala
blob: 52412ad4c1e5d3681d898063fee728dace47b22e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
sealed trait HList
final case class HCons[H, T <: HList](head : H, tail : T) extends HList
case object HNil extends HList

object HList {
  type ::[H, T <: HList] = HCons[H, T]
  type HNil = HNil.type

  implicit def hlistOps[L <: HList](l : L) = new {
    def ::[H](h : H) : H :: L = HCons(h, l)
    def last(implicit last : Last[L]) {}
  }

  class Last[L <: HList]
  implicit def hsingleLast[H] = new Last[H :: HNil]
  implicit def hlistLast[H, T <: HList](implicit lt : Last[T]) = new Last[H :: T]

  type III = Int :: Int :: Int :: HNil
  val iii : III = 0 :: 0 :: 0 :: HNil
  val l = iii.last
}