繁体   English   中英

无形:有没有办法从案例类或元组中获取Hlist类型

[英]Shapeless: is there a way to get Hlist type from a case class or a tuple

我完全没有变形。 我从列表中创建一个case类,如下所示:

val list = Seq(Some(1), Some(1.0), ...)
val y =
  list
    .toHList[Option[Int]::Option[Double]::Option[Int]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::Option[Double]::HNil]

val z = y.get.tupled
val aa = YieldVariables.tupled(z)

它运作良好,但我想知道是否有办法不在toHList[Here]部分写入所有这些类型。

所以我想知道像list.toHList[find the type yourself]或者list.getTypesForHlist或者是导致Option[Int]::Option[Double]... MyCaseClass.getTypesForHlist

对于case类(和元组,这些也是case类!),使用Generic

case class A(i: Int, s: String)
shapeless.Generic[A].to(A(1, "")) // Int :: String :: HNil

这在Seq上是不可能做到的。 实际上,只要您调用了构造函数,就会从类型的角度来看有关传递给该构造函数的元素数量的信息。 Shapeless还有SingletonProductArgs :一个类似varargs的宏,它返回HList而不是Seq

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM