0

我正在尝试解决下面的以下 Scala 编译器错误。

case class CC[E](l:List[E])

trait D[E,L<:CC[E]]{
  def f(l:L):L = l.copy(l=List()) // does not compile: "found CC[E], required: L"
}

在(伪)-Haskell(没有子类型)中,这将类似于:

 data CC = CC {l::[e]}
 'makeLens CC
 f l = l .~ _e []

目前我正在研究 ScalaZ、Shapeless 和 Monocle。

乍一看,Monocle 似乎没有问题(虽然不确定),如果我的直觉是错误的,请证明我错了。

ScalaZ + Shapeless 可能起作用,我不确定如何(从未使用过它们)。

1) 在 Scala 中解决这个问题的最简单方法是什么?

2) ScalaZ 本身就足够了吗?还是无形本身就足够了?还是两者的结合是必要的?或者也许其他方式?

4

1 回答 1

1

您可以使用Monocle执行以下操作:

import monocle.macros.Lenses

@Lenses
case class CC[E](l:List[E])

object D {
  def f[E](cc: CC[E]): CC[E] = CC.l.set(List())(cc)
}
于 2017-01-11T23:25:57.240 回答