斯卡拉 – 无形窄型损失

前端之家收集整理的这篇文章主要介绍了斯卡拉 – 无形窄型损失前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在以下示例中

import shapeless._
import shapeless.Syntax.singleton._

val concat = "right".narrow

def extract[s <: String](x: s)(implicit witness: Witness.Aux[s]): String = witness.value

extract(concat)

我收到了一个错误

Error: could not find implicit value for parameter witness:shapeless.Witness.Aux[String("right")]

我正在尝试做的事情是类型级DSL,它严重依赖单例类型.

由于在typelevel的fork之外支持单例类型的文字,我希望除了类型文字之外还要开发基于值的DSL,并且在值类型中保留可用的单例类型对于此任务至关重要.
所以我正在寻找允许我稍后从值的类型中提取单例字符串见证的任何解决方法.

编辑

使用.witness而不是.narrow的操作完美地工作,但我仍然在寻找没有Witness包装的纯类型的解决方

解决方法

这是类型推断的失败……你会发现,

extract[concat.type](concat)

将按预期工作.

这并不是特别有用,因为我想你想要从值参数中提取单例类型来提取. shapeless提供了对Witness类型的隐式转换,因此以下内容可能适用于您的上下文,

def extract(witness: Witness.Lt[String]): String = witness.value

这将接受文字字符串和缩小值.

猜你在找的Scala相关文章