@dxos/codec-protobuf
TypeScript icon, indicating that this package has built-in type declarations

0.4.9 • Public • Published

codec-protobuf

There's an associated @dxos/protobuf-compiler package that does codegen based on protobuf schema.

Handling of scalar fields with default values

Based on:

In protobuf scalar fields (numbers, booleans, strings, bytes, enums) may have an implicit default value:

  • 0 for number types
  • false for booleans
  • '' (empty string) for strings
  • [] for bytes
  • First enum value for enums

Non-optional fields

Example:

int32 number = 1;

If the field is set to it's default value (0 in this example) it MAY be missing in the wire encoding (Go implementation) or present with the value set to 0 (JS implementation).

When decoding, the missing fields MUST be treated as having the default implicit value (0 in this case).

Optional fields

optional int32 number = 1;

If the field is set to it's default value (0 in this example) it MUST be present in the wire encoding with the value set to 0.

When decoding, the missing fields it MUST be set as undefined. If the field is present in the wire format, it must be set to its numeric value.

Toolchain

This package must NOT use toolchain to avoid cyclic dependencies.

Readme

Keywords

none

Package Sidebar

Install

npm i @dxos/codec-protobuf

Homepage

dxos.org

Weekly Downloads

11,386

Version

0.4.9

License

MIT

Unpacked Size

281 kB

Total Files

77

Last publish

Collaborators

  • zhenya-dxos
  • mykola-vrmchk
  • dxos-bot
  • richburdon
  • marik_d
  • wittjosiah