2

是否可以将 HList 作为函数参数传递?

这是我到目前为止所拥有的:

import shapeless._
import poly._

object id extends (Id ~> Id) {
  def apply[T](f: shapeless.Id[T]): shapeless.Id[T] = f
}

object ListHandler {
  def mapOverHlist[ListType <: HList](list: ListType) = list.map(id)
}

val x = "foo" :: "bar" :: 0xb33f :: HNil    
ListHandler.mapOverHlist(x)

导致此错误:

could not find implicit value for parameter mapper:   
shapeless.ops.hlist.Mapper[ShapelessSpec.this.id.type,ListType]
4

1 回答 1

5

错误文本包含解决方案:

import shapeless.ops.hlist.Mapper

def mapOverHlist[L <: HList](list: L)(implicit m: Mapper[id.type, L]): m.Out =
  list.map(id)

方法map接受一个隐式参数,你应该提供这样的参数(通过在你的方法声明中添加相同的参数)。

于 2013-12-04T07:10:29.227 回答