Skip to content

cloudwego/prutal

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.

About

Pure Go alternative to protocol buffers with minimum code generation

Resources

License

Code of conduct

Contributing

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages

Generated from cloudwego/.github