2

我正在尝试定义用于与 EELink GPS 通信的 Scodec 副产品编解码器。

这是代码:

import scodec.Codec
import scodec.bits.ByteVector
import scodec.codecs._

trait Message
object Message {
  implicit val discriminated: Discriminated[ Message, Int ] = Discriminated(uint8)
  val codec: Codec[ Message ] = Codec.coproduct[ Message ].discriminatedByIndex(uint8)
}

case class GpsId(value: ByteVector)
object GpsId {
  val codec = bytes(8).as[ GpsId ]
}

case class SerialNumber(value: Int)
object SerialNumber {
  val codec = uint16.as[ SerialNumber ]
}

case class Header(protocolNumber: Int, length: Int, serial: SerialNumber)
object Header {
  val codec = (uint8 :: uint16 :: SerialNumber.codec).as[ Header ]
}

case class Login(header: Header, id: GpsId, language: Int) extends Message
object Login {
  val protocolNumber = 0x01
  implicit val discriminator: Discriminator[ Message, Login, Int ] = Discriminator(protocolNumber)
  implicit val codec: Codec[Login] = (Header.codec :: GpsId.codec :: uint8).as[ Login ]
}

我得到以下信息:

Error:(14, 48) could not find implicit value for parameter auto: scodec.codecs.CoproductBuilderAuto[com.tecnoguru.ridespark.gps.eelink.messages.Message]
  val codec: Codec[ Message ] = Codec.coproduct[ Message ].discriminatedByIndex(uint8)
                                           ^

我查看了Scodec - Coproducts 找不到参数 auto: scodec.codecs.CoproductBuilderAuto 的隐含值,但它没有帮助,从我看到的我正确定义了编解码器和鉴别器。

我在 Scala 2.11.5 上运行 scodec-core 1.7.0 和 scodec-bits 1.0.5

4

1 回答 1

3

那里的代码现在需要两个小改动:

  1. Message特征必须是sealed,否则,Shapeless 将不会提供实例Generic.Aux[Message, SomeCoproduct]
  2. 调用Codec.coproduct[Message]必须在定义所有子类型之后。将伴侣移动到文件末尾就足够了。

通过这两个更改,示例编译成功。

于 2015-06-15T01:40:22.070 回答