如何在 Erlang 中编码/解码 Google 的协议缓冲区扩展?



我正在使用basho的erlang协议缓冲区

有一个usr.proto:

message Msg {
  required int32 id = 1;
  extensions 100 to max;
}
message Usr {
  extend Msg { optional Usr msg = 1000; }
  required int64 id = 1;
}

我可以编码Usr:

UsrBin = usr_pb:encode_usr(#usr{id = 1})

并解码Usr:

UsrMsg = usr_pb:decode_usr(list_to_binary(UsrBin))

问题是:现在我想对Msg进行编码,所以我创建了一个dict:

Extensions = dict:append(1000, UsrMsg, dict:new())

然后我对Msg:进行编码

MsgBin = usr_pb:encode_msg(#msg{id = 1, '$extensions' = Extensions})

并解码Msg:

MsgMsg = usr_pb:decode_msg(list_to_binary(MsgBin))

然而,我无法获得扩展:

msg_pb:get_extension(MsgMsg, 1000)(this returned "undefined")

怎么了?我以为我编码错了,请帮帮我!

在我深入研究protobuffs_compile:generate/1生成的usr_pb.erl后,我认为这是protobuffs库中的一个错误。

如果扩展定义是嵌套的(即扩展是在消息定义中定义的),它就不会为扩展生成正确的函数。现在,如果我像这样重写原始文件:

message Msg {
  required int32 id = 1;
  extensions 100 to max;
}
message Usr {
  required int64 id = 1;
}
extend Msg {
  optional Usr msg = 1000;
}

一切都很顺利。

与扩展对应的API很清楚:

usr_pb:set_extension(#msg{id = 1, '$extensions' = dict:new()}, msg, UsrMsg)
{ok, Extension} = usr_pb:get_extension(MsgDecoded, msg),

最新更新