| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // Copyright 2019 The Go Authors. All rights reserved. | 
					
						
							|  |  |  | // Use of this source code is governed by a BSD-style | 
					
						
							|  |  |  | // license that can be found in the LICENSE file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Package proto provides functions operating on protocol buffer messages. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // For documentation on protocol buffers in general, see: | 
					
						
							| 
									
										
										
										
											2023-05-12 14:33:40 +02:00
										 |  |  | // https://protobuf.dev. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // For a tutorial on using protocol buffers with Go, see: | 
					
						
							| 
									
										
										
										
											2023-05-12 14:33:40 +02:00
										 |  |  | // https://protobuf.dev/getting-started/gotutorial. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // For a guide to generated Go protocol buffer code, see: | 
					
						
							| 
									
										
										
										
											2023-05-12 14:33:40 +02:00
										 |  |  | // https://protobuf.dev/reference/go/go-generated. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2022-09-28 18:30:40 +01:00
										 |  |  | // # Binary serialization | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // This package contains functions to convert to and from the wire format, | 
					
						
							|  |  |  | // an efficient binary serialization of protocol buffers. | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Size] reports the size of a message in the wire format. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Marshal] converts a message to the wire format. | 
					
						
							|  |  |  | //     The [MarshalOptions] type provides more control over wire marshaling. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Unmarshal] converts a message from the wire format. | 
					
						
							|  |  |  | //     The [UnmarshalOptions] type provides more control over wire unmarshaling. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2022-09-28 18:30:40 +01:00
										 |  |  | // # Basic message operations | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Clone] makes a deep copy of a message. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Merge] merges the content of a message into another. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Equal] compares two messages. For more control over comparisons | 
					
						
							|  |  |  | //     and detailed reporting of differences, see package | 
					
						
							|  |  |  | //     [google.golang.org/protobuf/testing/protocmp]. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Reset] clears the content of a message. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [CheckInitialized] reports whether all required fields in a message are set. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2022-09-28 18:30:40 +01:00
										 |  |  | // # Optional scalar constructors | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // The API for some generated messages represents optional scalar fields | 
					
						
							|  |  |  | // as pointers to a value. For example, an optional string field has the | 
					
						
							|  |  |  | // Go type *string. | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [Bool], [Int32], [Int64], [Uint32], [Uint64], [Float32], [Float64], and [String] | 
					
						
							|  |  |  | //     take a value and return a pointer to a new instance of it, | 
					
						
							|  |  |  | //     to simplify construction of optional field values. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // Generated enum types usually have an Enum method which performs the | 
					
						
							|  |  |  | // same operation. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // Optional scalar fields are only supported in proto2. | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2022-09-28 18:30:40 +01:00
										 |  |  | // # Extension accessors | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - [HasExtension], [GetExtension], [SetExtension], and [ClearExtension] | 
					
						
							|  |  |  | //     access extension field values in a protocol buffer message. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // Extension fields are only supported in proto2. | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2022-09-28 18:30:40 +01:00
										 |  |  | // # Related packages | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - Package [google.golang.org/protobuf/encoding/protojson] converts messages to | 
					
						
							|  |  |  | //     and from JSON. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - Package [google.golang.org/protobuf/encoding/prototext] converts messages to | 
					
						
							|  |  |  | //     and from the text format. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - Package [google.golang.org/protobuf/reflect/protoreflect] provides a | 
					
						
							|  |  |  | //     reflection interface for protocol buffer data types. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - Package [google.golang.org/protobuf/testing/protocmp] provides features | 
					
						
							|  |  |  | //     to compare protocol buffer messages with the [github.com/google/go-cmp/cmp] | 
					
						
							|  |  |  | //     package. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2024-03-11 10:12:06 +00:00
										 |  |  | //   - Package [google.golang.org/protobuf/types/dynamicpb] provides a dynamic | 
					
						
							|  |  |  | //     message type, suitable for working with messages where the protocol buffer | 
					
						
							|  |  |  | //     type is only known at runtime. | 
					
						
							| 
									
										
										
										
											2021-08-12 21:03:24 +02:00
										 |  |  | // | 
					
						
							|  |  |  | // This module contains additional packages for more specialized use cases. | 
					
						
							|  |  |  | // Consult the individual package documentation for details. | 
					
						
							|  |  |  | package proto |