0

我在用

addSbtPlugin("com.thesamet" % "sbt-protoc" % "0.99.23")
libraryDependencies += "com.thesamet.scalapb" %% "compilerplugin" % "0.9.0-M7"

我有一些自定义的原始包装器(我们没有使用谷歌包装器)

syntax = "proto3";

package com.github.piotrkowalczuk.ntypes;

// Int32 represents a int32 that may be nil.
message Int32 {
    int32 int32 = 1;
    bool valid = 2;
}

然后我想Int32在另一条消息中使用原始包装器消息,但在 Scala 案例类中自动取消包装的值:

syntax = "proto3";

package com.github.fpopic;

import "scalapb/scalapb.proto";
import "ntypes.proto";

message Usage {
    com.github.piotrkowalczuk.ntypes.Int32 ntype_primitive = 1 [(scalapb.field).type = "Option[Int]"];
}

我创建了一个简单Main.scala的指定自定义TypeMapper

package com.github.fpopic

import com.github.piotrkowalczuk.ntypes.ntypes.Int32
import scalapb.TypeMapper

object Main {

  implicit val ntypeInt32ToInt: TypeMapper[Int32, Option[Int]] =
    TypeMapper[Int32, Option[Int]] {
      ntypeInt32: Int32 => if (ntypeInt32.valid) Some(ntypeInt32.int32) else None
    } {
      optInt: Option[Int] => Int32(optInt.getOrElse(0), valid = optInt.isDefined)
    }

  def main(args: Array[String]): Unit = {

    implicitly[TypeMapper[Int32, Option[Int]]]

    val u: Usage = new Usage(
      ntypePrimitive = Option(1234)
    )

  }
}

所以想进入ScalaOption[Int]而不是Option[Int32]甚至Option[Option[Int]]被双重包装,因为每个message都会Option自动获取。

但我收到错误:

No TypeMapper found for conversion between com.github.piotrkowalczuk.ntypes.ntypes.Int32 and Option[Int].
4

1 回答 1

1

no_box除了自定义类型之外,这可以通过将此字段设置为 true 来实现Option[Int]

为了使生成的代码能够找到隐式类型映射器,您可以将其放在与生成的代码(或其任何父级)相同的包的包对象中

package com.github

package object fpopic {
  implicit val myTypemapper = ...
}
于 2019-07-01T04:09:27.290 回答