Я пытаюсь выполнить вычисление типа, чтобы построить некоторую вложенную структуру коллекций, но я получаю 'расходящееся неявное расширение для типа shapeless.ops.hlist.LeftFolder'-error, когда я пытаюсь использовать коллекцию типа Map с Список [T] в качестве ключа или типа значения. Эта вложенная структура работает:
import shapeless._
import shapeless.ops.hlist._
object poly extends Poly2 {
implicit def wrapMap[T] = at[T, Int]((end, t) => Map(t -> end))
//other collection wrap functions
}
def foldToNestedCollections[T <: HList, Out](hl: T)(implicit lf: LeftFolder.Aux[T, Any, poly.type, Out]): Out = lf.apply(hl, 1)
foldToNestedCollections(2 :: HNil) //compiles
foldToNestedCollections(2 :: 3 :: HNil) //compiles
эта структура выдает ошибку:
import shapeless._
import shapeless.ops.hlist._
object poly extends Poly2 {
implicit def wrapMap[T] = at[T, Int]((end, t) => Map(List(t) -> end)) //or Map(t, List(end)) gives the same error
//other collection wrap functions
}
def foldToNestedCollections[T <: HList, Out](hl: T)(implicit lf: LeftFolder.Aux[T, Any, poly.type, Out]): Out = lf.apply(hl, 1)
foldToNestedCollections(2 :: HNil) //compiles
foldToNestedCollections(2 :: 3 :: HNil) //does not compile 'diverging ...
Обновление:
Если я создаю собственный конвертер, он работает. Я строю это, используя ответ на предыдущий вопрос HList для вложенной карты . Есть предложения почему?
import shapeless._
import shapeless.ops.hlist._
sealed trait MyLeftFolder[L <: HList, T] {
type Out
def convert(hlist: L, value: T): Out
}
object MyLeftFolder {
type Aux[L <: HList, T, Out2] = MyLeftFolder[L, T] { type Out = Out2 }
private trait Impl[L <: HList, T, Out2] extends MyLeftFolder[L, T] {
override type Out = Out2
}
implicit def hnil[T]: Aux[HNil, T, T] = new Impl[HNil, T, T] {
override def convert(hlist: HNil, value: T): T = value
}
implicit def hnil2[T]: Aux[HNil.type, T, T] = new Impl[HNil.type, T, T] {
override def convert(hlist: HNil.type, value: T): T = value
}
implicit def recurseint[L <: HList, T](implicit inner: MyLeftFolder[L, T]): Aux[Int :: L, T, Map[List[Int], inner.Out]] = new Impl[Int :: L, T, Map[List[Int], inner.Out]] {
override def convert(hlist: Int :: L, value: T): Map[List[Int], inner.Out] = {
val im = inner.convert(hlist.tail, value)
Map(List(hlist.head) -> im)
}
}
}
def foldToNestedCollections[T <: HList](hl: T)(implicit lf: MyLeftFolder[T, Any]): lf.Out = lf.convert(hl, 1)
foldToNestedCollections(2 :: HNil) //compiles
foldToNestedCollections(2 :: 3 :: HNil) //compiles