【发布时间】:2017-08-09 19:10:02
【问题描述】:
我希望这段代码能够编译
import shapeless._
import record._
import ops.record._
import ops.hlist.Align
import syntax.singleton._
case class From(i: Int, s: String, a: Int, b: Int, c: Int)
case class To(j: Int, s1: String, s2: String, a: Int, b: Int, c: Int)
val f = From(1, "FROM", 1, 1, 1)
val fromGen = LabelledGeneric[From]
val toGen = LabelledGeneric[To]
val lgenRepr = fromGen.to(f)
val modified = lgenRepr.renameField('i, 'j) - 's + ('s1 ->> "S1") + ('s2 ->> "S2")
val align = Align[modified.type, toGen.Repr]
toGen.from(align(modified))
但是如果失败了
could not find implicit value for parameter alm: shapeless.ops.hlist.Align[modified.type,toGen.Repr]
val align = Align[modified.type, toGen.Repr]
有a trick 使用labelled.FieldType 构造所需的类型,但它没有解释如何删除字段,所以如果不可能使Align 与单例类型一起工作,了解如何处理这些字段。
【问题讨论】: