首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何用scalapb描述proto中的Option[FiniteDuration]

如何用scalapb描述proto中的Option[FiniteDuration]
EN

Stack Overflow用户
提问于 2021-11-14 16:17:12
回答 1查看 60关注 0票数 0

我正在尝试使用proto3和scalapb,但我无法映射FiniteDuration,也无法将其用作Option。有没有人能就此提个建议?

代码语言:javascript
复制
case class Message(id:Int , interval: Option[FiniteDuration])
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-11-14 21:05:06

假设您在sbt中按照installation guide中的描述配置了scalabp

您需要为要从int64 (默认情况下映射为Long )转换为FiniteDuration的字段定义custom type

例如:

代码语言:javascript
复制
syntax="proto3";

import "scalapb/scalapb.proto";

option java_package = "my.app.proto";

message Message {
  int32 id = 1;
  optional int64 interval = 2 [(scalapb.field).type = "scala.concurrent.duration.FiniteDuration"];
}

这将生成一个看起来符合您需要的case类。

ScalaPB将依靠隐式解析来编译它,并应用从LongFiniteDuration的映射。为此,您需要在生成case类的同一个包的package object中定义一个scalapb.TypeMapper[Long, FiniteDuration],即my.app.proto.message

代码语言:javascript
复制
package my.app.proto

import scalapb.TypeMapper

import java.util.concurrent.TimeUnit
import scala.concurrent.duration.FiniteDuration

package object message {
  implicit val finiteDuration: TypeMapper[Long, FiniteDuration] =
    TypeMapper[Long, FiniteDuration](s => FiniteDuration.apply(s, TimeUnit.MILLISECONDS))(_.toMillis)
}
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/69964897

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档