2018-11-29 02:25:20 +00:00
|
|
|
// Copyright 2018 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
|
|
|
|
|
2019-04-01 20:31:55 +00:00
|
|
|
import (
|
2020-01-17 21:40:51 +00:00
|
|
|
"google.golang.org/protobuf/internal/errors"
|
2019-05-14 06:55:40 +00:00
|
|
|
"google.golang.org/protobuf/reflect/protoreflect"
|
2019-04-01 20:31:55 +00:00
|
|
|
)
|
2018-11-29 02:25:20 +00:00
|
|
|
|
|
|
|
// Message is the top-level interface that all messages must implement.
|
2020-02-12 00:21:06 +00:00
|
|
|
// It provides access to a reflective view of a message.
|
|
|
|
// Any implementation of this interface may be used with all functions in the
|
|
|
|
// protobuf module that accept a Message, except where otherwise specified.
|
|
|
|
//
|
|
|
|
// This is the v2 interface definition for protobuf messages.
|
2021-04-12 20:48:27 +00:00
|
|
|
// The v1 interface definition is [github.com/golang/protobuf/proto.Message].
|
2020-02-12 00:21:06 +00:00
|
|
|
//
|
2021-04-12 20:48:27 +00:00
|
|
|
// - To convert a v1 message to a v2 message,
|
|
|
|
// use [google.golang.org/protobuf/protoadapt.MessageV2Of].
|
|
|
|
// - To convert a v2 message to a v1 message,
|
|
|
|
// use [google.golang.org/protobuf/protoadapt.MessageV1Of].
|
2018-11-29 02:25:20 +00:00
|
|
|
type Message = protoreflect.ProtoMessage
|
2020-01-17 21:40:51 +00:00
|
|
|
|
2021-04-12 20:48:27 +00:00
|
|
|
// Error matches all errors produced by packages in the protobuf module
|
|
|
|
// according to [errors.Is].
|
2020-01-17 21:40:51 +00:00
|
|
|
//
|
2021-04-12 20:48:27 +00:00
|
|
|
// Example usage:
|
|
|
|
//
|
|
|
|
// if errors.Is(err, proto.Error) { ... }
|
2020-01-17 21:40:51 +00:00
|
|
|
var Error error
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
Error = errors.Error
|
|
|
|
}
|
2020-07-13 20:13:26 +00:00
|
|
|
|
|
|
|
// MessageName returns the full name of m.
|
|
|
|
// If m is nil, it returns an empty string.
|
|
|
|
func MessageName(m Message) protoreflect.FullName {
|
|
|
|
if m == nil {
|
|
|
|
return ""
|
|
|
|
}
|
|
|
|
return m.ProtoReflect().Descriptor().FullName()
|
|
|
|
}
|