• Home
  • History
  • Annotate
Name Date Size #Lines LOC

..03-May-2022-

cmd/protoc-gen-go/H04-May-2020-

compiler/protogen/H04-May-2020-

encoding/H04-May-2020-

internal/H04-May-2020-

proto/H04-May-2020-

reflect/H04-May-2020-

runtime/H04-May-2020-

testing/H04-May-2020-

types/H04-May-2020-

.gitignoreH A D04-May-2020306

.travis.ymlH A D04-May-2020221

AUTHORSH A D04-May-2020174

CONTRIBUTING.mdH A D04-May-20202.6 KiB

CONTRIBUTORSH A D04-May-2020171

LICENSEH A D04-May-20201.4 KiB

PATENTSH A D04-May-20201.3 KiB

README.mdH A D04-May-202016.8 KiB

go.modH A D04-May-2020123

go.sumH A D04-May-20201.7 KiB

integration_test.goH A D04-May-202013.1 KiB

regenerate.bashH A D04-May-2020297

release.bashH A D04-May-20203.7 KiB

test.bashH A D04-May-2020295

README.md

1# Go support for Protocol Buffers
2
3[![GoDev](https://img.shields.io/static/v1?label=godev&message=reference&color=00add8)](https://pkg.go.dev/mod/google.golang.org/protobuf)
4[![Build Status](https://travis-ci.org/protocolbuffers/protobuf-go.svg?branch=master)](https://travis-ci.org/protocolbuffers/protobuf-go)
5
6This project hosts the Go implementation for
7[protocol buffers](https://developers.google.com/protocol-buffers), which is a
8language-neutral, platform-neutral, extensible mechanism for serializing
9structured data. The protocol buffer language is a language for specifying the
10schema for structured data. This schema is compiled into language specific
11bindings. This project provides both a tool to generate Go code for the
12protocol buffer language, and also the runtime implementation to handle
13serialization of messages in Go. See the
14[protocol buffer developer guide](https://developers.google.com/protocol-buffers/docs/overview)
15for more information about protocol buffers themselves.
16
17This project is comprised of two components:
18
19*   Code generator: The
20    [`protoc-gen-go`](https://pkg.go.dev/google.golang.org/protobuf/cmd/protoc-gen-go)
21    tool is a compiler plugin to `protoc`, the protocol buffer compiler. It
22    augments the `protoc` compiler so that it knows how to
23    [generate Go specific code for a given `.proto` file](https://developers.google.com/protocol-buffers/docs/reference/go-generated).
24
25*   Runtime library: The
26    [`protobuf`](https://pkg.go.dev/mod/google.golang.org/protobuf) module
27    contains a set of Go packages that form the runtime implementation of
28    protobufs in Go. This provides the set of interfaces that
29    [define what a message is](https://pkg.go.dev/google.golang.org/protobuf/reflect/protoreflect)
30    and functionality to serialize message in various formats (e.g.,
31    [wire](https://pkg.go.dev/google.golang.org/protobuf/proto),
32    [JSON](https://pkg.go.dev/google.golang.org/protobuf/encoding/protojson),
33    and
34    [text](https://pkg.go.dev/google.golang.org/protobuf/encoding/prototext)).
35
36See the
37[developer guide for protocol buffers in Go](https://developers.google.com/protocol-buffers/docs/gotutorial)
38for a general guide for how to get started using protobufs in Go.
39
40This project is the second major revision of the Go protocol buffer API
41implemented by the
42[`google.golang.org/protobuf`](https://pkg.go.dev/mod/google.golang.org/protobuf)
43module. The first major version is implemented by the
44[`github.com/golang/protobuf`](https://pkg.go.dev/mod/github.com/golang/protobuf)
45module.
46
47## Package index
48
49Summary of the packages provided by this module:
50
51*   [`proto`](https://pkg.go.dev/google.golang.org/protobuf/proto): Package
52    `proto` provides functions operating on protobuf messages such as cloning,
53    merging, and checking equality, as well as binary serialization.
54*   [`encoding/protojson`](https://pkg.go.dev/google.golang.org/protobuf/encoding/protojson):
55    Package `protojson` serializes protobuf messages as JSON.
56*   [`encoding/prototext`](https://pkg.go.dev/google.golang.org/protobuf/encoding/prototext):
57    Package `prototext` serializes protobuf messages as the text format.
58*   [`encoding/protowire`](https://pkg.go.dev/google.golang.org/protobuf/encoding/protowire):
59    Package `protowire` parses and formats the low-level raw wire encoding. Most
60    users should use package `proto` to serialize messages in the wire format.
61*   [`reflect/protoreflect`](https://pkg.go.dev/google.golang.org/protobuf/reflect/protoreflect):
62    Package `protoreflect` provides interfaces to dynamically manipulate
63    protobuf messages.
64*   [`reflect/protoregistry`](https://pkg.go.dev/google.golang.org/protobuf/reflect/protoregistry):
65    Package `protoregistry` provides data structures to register and lookup
66    protobuf descriptor types.
67*   [`reflect/protodesc`](https://pkg.go.dev/google.golang.org/protobuf/reflect/protodesc):
68    Package `protodesc` provides functionality for converting
69    `descriptorpb.FileDescriptorProto` messages to/from the reflective
70    `protoreflect.FileDescriptor`.
71*   [`testing/protocmp`](https://pkg.go.dev/google.golang.org/protobuf/testing/protocmp):
72    Package `protocmp` provides protobuf specific options for the `cmp` package.
73*   [`testing/protopack`](https://pkg.go.dev/google.golang.org/protobuf/testing/protopack):
74    Package `protopack` aids manual encoding and decoding of the wire format.
75*   [`testing/prototest`](https://pkg.go.dev/google.golang.org/protobuf/testing/prototest):
76    Package `prototest` exercises the protobuf reflection implementation for
77    concrete message types.
78*   [`types/dynamicpb`](https://pkg.go.dev/google.golang.org/protobuf/types/dynamicpb):
79    Package `dynamicpb` creates protobuf messages at runtime from protobuf
80    descriptors.
81*   [`types/known/anypb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/anypb):
82    Package `anypb` is the generated package for `google/protobuf/any.proto`.
83*   [`types/known/emptypb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/emptypb):
84    Package `emptypb` is the generated package for
85    `google/protobuf/empty.proto`.
86*   [`types/known/timestamppb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/timestamppb):
87    Package `timestamppb` is the generated package for
88    `google/protobuf/timestamp.proto`.
89*   [`types/known/durationpb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/durationpb):
90    Package `durationpb` is the generated package for
91    `google/protobuf/duration.proto`.
92*   [`types/known/wrapperspb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/wrapperspb):
93    Package `wrapperspb` is the generated package for
94    `google/protobuf/wrappers.proto`.
95*   [`types/known/structpb`](https://pkg.go.dev/google.golang.org/protobuf/types/known/structpb):
96    Package `structpb` is the generated package for
97    `google/protobuf/struct.proto`.
98*   [`types/descriptorpb`](https://pkg.go.dev/google.golang.org/protobuf/types/descriptorpb):
99    Package `descriptorpb` is the generated package for
100    `google/protobuf/descriptor.proto`.
101*   [`types/pluginpb`](https://pkg.go.dev/google.golang.org/protobuf/types/pluginpb):
102    Package `pluginpb` is the generated package for
103    `google/protobuf/compiler/plugin.proto`.
104*   [`compiler/protogen`](https://pkg.go.dev/google.golang.org/protobuf/compiler/protogen):
105    Package `protogen` provides support for writing protoc plugins.
106*   [`cmd/protoc-gen-go`](https://pkg.go.dev/google.golang.org/protobuf/cmd/protoc-gen-go):
107    The `protoc-gen-go` binary is a protoc plugin to generate a Go protocol
108    buffer package.
109
110## Reporting issues
111
112The issue tracker for this project is currently located at
113[golang/protobuf](https://github.com/golang/protobuf/issues).
114
115Please report any issues there with a sufficient description of the bug or
116feature request. Bug reports should ideally be accompanied by a minimal
117reproduction of the issue. Irreproducible bugs are difficult to diagnose and fix
118(and likely to be closed after some period of time). Bug reports must specify
119the version of the
120[Go protocol buffer module](https://github.com/protocolbuffers/protobuf-go/releases)
121and also the version of the
122[protocol buffer toolchain](https://github.com/protocolbuffers/protobuf/releases)
123being used.
124
125## Contributing
126
127This project is open-source and accepts contributions. See the
128[contribution guide](https://github.com/protocolbuffers/protobuf-go/blob/master/CONTRIBUTING.md)
129for more information.
130
131## Compatibility
132
133This module and the generated code are expected to be stable over time. However,
134we reserve the right to make breaking changes without notice for the following
135reasons:
136
137*   **Security:** A security issue in the specification or implementation may
138    come to light whose resolution requires breaking compatibility. We reserve
139    the right to address such issues.
140*   **Unspecified behavior:** There are some aspects of the protocol buffer
141    specification that are undefined. Programs that depend on unspecified
142    behavior may break in future releases.
143*   **Specification changes:** It may become necessary to address an
144    inconsistency, incompleteness, or change in the protocol buffer
145    specification, which may affect the behavior of existing programs. We
146    reserve the right to address such changes.
147*   **Bugs:** If a package has a bug that violates correctness, a program
148    depending on the buggy behavior may break if the bug is fixed. We reserve
149    the right to fix such bugs.
150*   **Generated additions**: We reserve the right to add new declarations to
151    generated Go packages of `.proto` files. This includes declared constants,
152    variables, functions, types, fields in structs, and methods on types. This
153    may break attempts at injecting additional code on top of what is generated
154    by `protoc-gen-go`. Such practice is not supported by this project.
155*   **Internal changes**: We reserve the right to add, modify, and remove
156    internal code, which includes all unexported declarations, the
157    [`protoc-gen-go/internal_gengo`](https://pkg.go.dev/google.golang.org/protobuf/cmd/protoc-gen-go/internal_gengo)
158    package, the
159    [`runtime/protoimpl`](https://pkg.go.dev/google.golang.org/protobuf/runtime/protoimpl?tab=doc)
160    package, and all packages under
161    [`internal`](https://pkg.go.dev/google.golang.org/protobuf/internal).
162
163Any breaking changes outside of these will be announced 6 months in advance to
164[protobuf@googlegroups.com](https://groups.google.com/forum/#!forum/protobuf).
165
166Users should use generated code produced by a version of
167[`protoc-gen-go`](https://pkg.go.dev/google.golang.org/protobuf/cmd/protoc-gen-go)
168that is identical to the runtime version provided by the
169[protobuf module](https://pkg.go.dev/mod/google.golang.org/protobuf). This
170project promises that the runtime remains compatible with code produced by a
171version of the generator that is no older than 1 year from the version of the
172runtime used, according to the release dates of the minor version. Generated
173code is expected to use a runtime version that is at least as new as the
174generator used to produce it. Generated code contains references to
175[`protoimpl.EnforceVersion`](https://pkg.go.dev/google.golang.org/protobuf/runtime/protoimpl?tab=doc#EnforceVersion)
176to statically ensure that the generated code and runtime do not drift
177sufficiently far apart.
178
179## Historical legacy
180
181This project is the second major revision
182([released in 2020](https://blog.golang.org/a-new-go-api-for-protocol-buffers))
183of the Go protocol buffer API implemented by the
184[`google.golang.org/protobuf`](https://pkg.go.dev/mod/google.golang.org/protobuf)
185module. The first major version
186([released publicly in 2010](https://blog.golang.org/third-party-libraries-goprotobuf-and))
187is implemented by the
188[`github.com/golang/protobuf`](https://pkg.go.dev/mod/github.com/golang/protobuf)
189module.
190
191The first version predates the release of Go 1 by several years. It has a long
192history as one of the first core pieces of infrastructure software ever written
193in Go. As such, the Go protobuf project was one of many pioneers for determining
194what the Go language should even look like and what would eventually be
195considered good design patterns and “idiomatic” Go (by simultaneously being
196both positive and negative examples of it).
197
198Consider the changing signature of the `proto.Unmarshal` function as an example
199of Go language and library evolution throughout the life of this project:
200
201```go
202// 2007/09/25 - Conception of Go
203
204// 2008/11/12
205export func UnMarshal(r io.Read, pb_e reflect.Empty) *os.Error
206
207// 2008/11/13
208export func UnMarshal(buf *[]byte, pb_e reflect.Empty) *os.Error
209
210// 2008/11/24
211export func UnMarshal(buf *[]byte, pb_e interface{}) *os.Error
212
213// 2008/12/18
214export func UnMarshal(buf []byte, pb_e interface{}) *os.Error
215
216// 2009/01/20
217func UnMarshal(buf []byte, pb_e interface{}) *os.Error
218
219// 2009/04/17
220func UnMarshal(buf []byte, pb_e interface{}) os.Error
221
222// 2009/05/22
223func Unmarshal(buf []byte, pb_e interface{}) os.Error
224
225// 2011/11/03
226func Unmarshal(buf []byte, pb_e interface{}) error
227
228// 2012/03/28 - Release of Go 1
229
230// 2012/06/12
231func Unmarshal(buf []byte, pb Message) error
232```
233
234These changes demonstrate the difficulty of determining what the right API is
235for any new technology. It takes time multiplied by many users to determine what
236is best; even then, “best” is often still somewhere over the horizon.
237
238The change on June 6th, 2012 added a degree of type-safety to Go protobufs by
239declaring a new interface that all protobuf messages were required to implement:
240
241```go
242type Message interface {
243   Reset()
244   String() string
245   ProtoMessage()
246}
247```
248
249This interface reduced the set of types that can be passed to `proto.Unmarshal`
250from the universal set of all possible Go types to those with a special
251`ProtoMessage` marker method. The intention of this change is to limit the
252protobuf API to only operate on protobuf data types (i.e., protobuf messages).
253For example, there is no sensible operation if a Go channel were passed to the
254protobuf API as a channel cannot be serialized. The restricted interface would
255prevent that.
256
257This interface does not behaviorally describe what a protobuf message is, but
258acts as a marker with an undocumented expectation that protobuf messages must be
259a Go struct with a specific layout of fields with formatted tags. This
260expectation is not statically enforced by the Go language, for it is an
261implementation detail checked dynamically at runtime using Go reflection. Back
262in 2012, the only types with this marker were those generated by
263`protoc-gen-go`. Since `protoc-gen-go` would always generate messages with the
264proper layout of fields, this was deemed an acceptable and dramatic improvement
265over `interface{}`.
266
267Over the next 10 years,
268[use of Go would skyrocket](https://blog.golang.org/10years) and use of
269protobufs in Go would skyrocket as well. With increased popularity also came
270more diverse usages and requirements for Go protobufs and an increased number of
271custom `proto.Message` implementations that were not generated by
272`protoc-gen-go`.
273
274The increasingly diverse ecosystem of Go types implementing the `proto.Message`
275interface led to incompatibilities, which often occurred when:
276
277*   **Passing custom `proto.Message` types to the protobuf APIs**: A concrete
278    message implementation might work with some top-level functions (e.g.,
279    `proto.Marshal`), but cause others (e.g., `proto.Equal`) to choke and panic.
280    This occurs because the type only had partial support for being an actual
281    message by only implementing the `proto.Marshaler` interface or having
282    malformed struct field tags that happened to work with one function, but not
283    another.
284
285*   **Using Go reflection on any `proto.Message` types**: A common desire is to
286    write general-purpose code that operates on any protobuf message. For
287    example, a microservice might want to populate a `trace_id` field if it is
288    present in a message. To accomplish this, one would use Go reflection to
289    introspect the message type, and assume it were a pointer to a Go struct
290    with a field named `TraceId` (as would be commonly produced by
291    `protoc-gen-go`). If the concrete message type did not match this
292    expectation, it either failed to work or even resulted in a panic. Such was
293    the case for concrete message types that might be backed by a Go map instead
294    of a Go struct.
295
296Both of these issues are solved by following the idiom that _interfaces should
297describe behavior, not data_. This means that the interface itself should
298provide sufficient functionality through its methods that users can introspect
299and interact with all aspects of a protobuf message through a principled API.
300This feature is called _protobuf reflection_. Just as how Go reflection provides
301an API for programmatically interacting with any arbitrary Go value, protobuf
302reflection provides an API for programmatically interacting with any arbitrary
303protobuf message.
304
305Since an interface cannot be extended in a backwards compatible way, this
306suggested the need for a new major version that defines a new `proto.Message`
307interface:
308
309```go
310type Message interface {
311    ProtoReflect() protoreflect.Message
312}
313```
314
315The new
316[`proto.Message`](https://pkg.go.dev/google.golang.org/protobuf/proto?tab=doc#Message)
317interface contains a single `ProtoReflect` method that returns a
318[`protoreflect.Message`](https://pkg.go.dev/google.golang.org/protobuf/reflect/protoreflect?tab=doc#Message),
319which is a reflective view over a protobuf message. In addition to making a
320breaking change to the `proto.Message` interface, we took this opportunity to
321cleanup the supporting functionality that operate on a `proto.Message`, split up
322complicated functionality apart into manageable packages, and to hide
323implementation details away from the public API.
324
325The goal for this major revision is to improve upon all the benefits of, while
326addressing all the shortcomings of the old API. We hope that it will serve the
327Go ecosystem well for the next 10 years and beyond.
328