aboutsummaryrefslogtreecommitdiffstats
path: root/vendor/google.golang.org/protobuf/proto/doc.go
blob: 80ed16a0c295452592bea7bc8a22f2dc2ffc4b67 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
// 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:
// https://protobuf.dev.
//
// For a tutorial on using protocol buffers with Go, see:
// https://protobuf.dev/getting-started/gotutorial.
//
// For a guide to generated Go protocol buffer code, see:
// https://protobuf.dev/reference/go/go-generated.
//
// # Binary serialization
//
// This package contains functions to convert to and from the wire format,
// an efficient binary serialization of protocol buffers.
//
//   - [Size] reports the size of a message in the wire format.
//
//   - [Marshal] converts a message to the wire format.
//     The [MarshalOptions] type provides more control over wire marshaling.
//
//   - [Unmarshal] converts a message from the wire format.
//     The [UnmarshalOptions] type provides more control over wire unmarshaling.
//
// # Basic message operations
//
//   - [Clone] makes a deep copy of a message.
//
//   - [Merge] merges the content of a message into another.
//
//   - [Equal] compares two messages. For more control over comparisons
//     and detailed reporting of differences, see package
//     [google.golang.org/protobuf/testing/protocmp].
//
//   - [Reset] clears the content of a message.
//
//   - [CheckInitialized] reports whether all required fields in a message are set.
//
// # Optional scalar constructors
//
// 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.
//
//   - [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.
//
// Generated enum types usually have an Enum method which performs the
// same operation.
//
// Optional scalar fields are only supported in proto2.
//
// # Extension accessors
//
//   - [HasExtension], [GetExtension], [SetExtension], and [ClearExtension]
//     access extension field values in a protocol buffer message.
//
// Extension fields are only supported in proto2.
//
// # Related packages
//
//   - Package [google.golang.org/protobuf/encoding/protojson] converts messages to
//     and from JSON.
//
//   - Package [google.golang.org/protobuf/encoding/prototext] converts messages to
//     and from the text format.
//
//   - Package [google.golang.org/protobuf/reflect/protoreflect] provides a
//     reflection interface for protocol buffer data types.
//
//   - Package [google.golang.org/protobuf/testing/protocmp] provides features
//     to compare protocol buffer messages with the [github.com/google/go-cmp/cmp]
//     package.
//
//   - 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.
//
// This module contains additional packages for more specialized use cases.
// Consult the individual package documentation for details.
package proto