目录

Prutal

Prutal is a pure Go alternative to protocol buffers, it covers most of the functionality offered by Protocol Buffers.

Prutal aims to minimize code generation as much as possible while ensuring serialization and maintaining good performance.

Since Prutal is NOT yet ready for production use, we are not providing usage documentation at this time, nor do we guarantee backward compatibility of the interface.

Feature Comparison

Features Prutal Protobuf
Supported Languages Go C++, Java, Python, Go, and more
Code Generation
Generated Code Size 😄 compact 😡 bulky
Serialization
Performance ⭐️⭐️⭐️⭐️⭐️ ⭐️⭐️⭐️
Extensibility 😄 Package 😡 Plugin
Compatibility ✅ (see Protobuf Compatibility)
gRPC
Non-Pointer Field ✅ (aka gogoproto.nullable)

Protobuf Compatibility

  • ✅ Works with code generated by the official Protocol Buffer Go

Core Message Operations

  • ✅ Marshal / Unmarshal — binary wire format
  • ✅ MarshalAppend — append-friendly encoding
  • ✅ Size — compute wire size without marshaling (zero allocation)
  • ✅ Reset
  • ❌ Clone / Merge / Equal
  • ❌ CheckInitialized — validate required field presence
  • ❌ MarshalOptions / UnmarshalOptions (deterministic output, discard unknown, recursion limits, etc.)

Proto Language Support

  • ✅ Scalar types: all 15 protobuf scalar types
  • ✅ Messages and nested messages
  • ✅ Repeated fields
  • ✅ Enums (including allow_alias)
  • ✅ Optional / field presence
  • ✅ Map fields
  • ✅ Oneof fields
  • ✅ Required fields (proto2)
  • ✅ Packed / unpacked encoding
    • PACKED / EXPANDED (repeated field encoding, edition 2023)
  • ✅ Unknown field preservation
  • ✅ Reserved fields and names
  • Default scalar values (proto2, edition 2023)
  • Groups (proto2, deprecated)
  • ❌ UTF-8 validation
  • ❌ Message sets (legacy format)

Encoding Formats

  • ✅ Binary wire format
  • ⚠️ JSON: struct tag only, no protojson equivalent
  • ❌ Text format (prototext)
  • ❌ Delimited format (length-prefixed message streams)

Reflection

  • ❌ Descriptor-based reflection (protoreflect)
  • ❌ Type registries (protoregistry)
  • ❌ Dynamic messages (dynamicpb)

Extension Support

  • ⚠️ Extensions (proto2): parsed but limited codegen
  • ❌ Has / Get / Set / Clear / Range extensions

Code Generation (prutalgen)

  • ✅ Proto2, proto3, edition 2023
  • ✅ Imports (regular, public, weak)
  • ✅ gRPC / Services (client/server stubs, streaming)
  • ⚠️ Go only
  • ⚠️ Well-known types: reuses google.golang.org/protobuf/types/known, Any is limited
  • ⚠️ Custom options: subset of gogoproto options
  • ❌ Edition 2024
  • ❌ Opaque API / lazy decoding
  • ❌ Deprecation markers

How to use Prutal with gRPC

Use pkg/grpccodec and pass grpccodec.PrutalCodec to the gRPC v1 codec APIs on both server and client.

See pkg/grpccodec/README.md for usage details and tests/cases/grpc for a complete example.

Contributing

Contributor guide: Contributing.

License

Prutal is licensed under the terms of the Apache license 2.0. See LICENSE for more information. Dependencies used by prutal are listed under licenses.

关于
533.0 KB
邀请码
    Gitlink(确实开源)
  • 加入我们
  • 官网邮箱:gitlink@ccf.org.cn
  • QQ群
  • QQ群
  • 公众号
  • 公众号

版权所有:中国计算机学会技术支持:开源发展技术委员会
京ICP备13000930号-9 京公网安备 11010802032778号