|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
"""Contains a metaclass and helper functions used to create |
|
protocol message classes from Descriptor objects at runtime. |
|
|
|
Recall that a metaclass is the "type" of a class. |
|
(A class is to a metaclass what an instance is to a class.) |
|
|
|
In this case, we use the GeneratedProtocolMessageType metaclass |
|
to inject all the useful functionality into the classes |
|
output by the protocol compiler at compile-time. |
|
|
|
The upshot of all this is that the real implementation |
|
details for ALL pure-Python protocol buffers are *here in |
|
this file*. |
|
""" |
|
|
|
__author__ = '[email protected] (Will Robinson)' |
|
|
|
import warnings |
|
|
|
from google.protobuf import message_factory |
|
from google.protobuf import symbol_database |
|
|
|
|
|
|
|
GeneratedProtocolMessageType = message_factory._GENERATED_PROTOCOL_MESSAGE_TYPE |
|
|
|
MESSAGE_CLASS_CACHE = {} |
|
|
|
|
|
|
|
def ParseMessage(descriptor, byte_str): |
|
"""Generate a new Message instance from this Descriptor and a byte string. |
|
|
|
DEPRECATED: ParseMessage is deprecated because it is using MakeClass(). |
|
Please use MessageFactory.GetMessageClass() instead. |
|
|
|
Args: |
|
descriptor: Protobuf Descriptor object |
|
byte_str: Serialized protocol buffer byte string |
|
|
|
Returns: |
|
Newly created protobuf Message object. |
|
""" |
|
warnings.warn( |
|
'reflection.ParseMessage() is deprecated. Please use ' |
|
'MessageFactory.GetMessageClass() and message.ParseFromString() instead. ' |
|
'reflection.ParseMessage() will be removed in Jan 2025.', |
|
stacklevel=2, |
|
) |
|
result_class = MakeClass(descriptor) |
|
new_msg = result_class() |
|
new_msg.ParseFromString(byte_str) |
|
return new_msg |
|
|
|
|
|
|
|
def MakeClass(descriptor): |
|
"""Construct a class object for a protobuf described by descriptor. |
|
|
|
DEPRECATED: use MessageFactory.GetMessageClass() instead. |
|
|
|
Args: |
|
descriptor: A descriptor.Descriptor object describing the protobuf. |
|
Returns: |
|
The Message class object described by the descriptor. |
|
""" |
|
warnings.warn( |
|
'reflection.MakeClass() is deprecated. Please use ' |
|
'MessageFactory.GetMessageClass() instead. ' |
|
'reflection.MakeClass() will be removed in Jan 2025.', |
|
stacklevel=2, |
|
) |
|
|
|
|
|
|
|
return message_factory.GetMessageClass(descriptor) |
|
|