98 lines
3.1 KiB
Python
98 lines
3.1 KiB
Python
|
# Protocol Buffers - Google's data interchange format
|
||
|
# Copyright 2008 Google Inc. All rights reserved.
|
||
|
#
|
||
|
# Use of this source code is governed by a BSD-style
|
||
|
# license that can be found in the LICENSE file or at
|
||
|
# https://developers.google.com/open-source/licenses/bsd
|
||
|
|
||
|
"""Contains Unknown Fields APIs.
|
||
|
|
||
|
Simple usage example:
|
||
|
unknown_field_set = UnknownFieldSet(message)
|
||
|
for unknown_field in unknown_field_set:
|
||
|
wire_type = unknown_field.wire_type
|
||
|
field_number = unknown_field.field_number
|
||
|
data = unknown_field.data
|
||
|
"""
|
||
|
|
||
|
|
||
|
from google.protobuf.internal import api_implementation
|
||
|
|
||
|
if api_implementation._c_module is not None: # pylint: disable=protected-access
|
||
|
UnknownFieldSet = api_implementation._c_module.UnknownFieldSet # pylint: disable=protected-access
|
||
|
else:
|
||
|
from google.protobuf.internal import decoder # pylint: disable=g-import-not-at-top
|
||
|
from google.protobuf.internal import wire_format # pylint: disable=g-import-not-at-top
|
||
|
|
||
|
class UnknownField:
|
||
|
"""A parsed unknown field."""
|
||
|
|
||
|
# Disallows assignment to other attributes.
|
||
|
__slots__ = ['_field_number', '_wire_type', '_data']
|
||
|
|
||
|
def __init__(self, field_number, wire_type, data):
|
||
|
self._field_number = field_number
|
||
|
self._wire_type = wire_type
|
||
|
self._data = data
|
||
|
return
|
||
|
|
||
|
@property
|
||
|
def field_number(self):
|
||
|
return self._field_number
|
||
|
|
||
|
@property
|
||
|
def wire_type(self):
|
||
|
return self._wire_type
|
||
|
|
||
|
@property
|
||
|
def data(self):
|
||
|
return self._data
|
||
|
|
||
|
class UnknownFieldSet:
|
||
|
"""UnknownField container."""
|
||
|
|
||
|
# Disallows assignment to other attributes.
|
||
|
__slots__ = ['_values']
|
||
|
|
||
|
def __init__(self, msg):
|
||
|
|
||
|
def InternalAdd(field_number, wire_type, data):
|
||
|
unknown_field = UnknownField(field_number, wire_type, data)
|
||
|
self._values.append(unknown_field)
|
||
|
|
||
|
self._values = []
|
||
|
msg_des = msg.DESCRIPTOR
|
||
|
# pylint: disable=protected-access
|
||
|
unknown_fields = msg._unknown_fields
|
||
|
if (msg_des.has_options and
|
||
|
msg_des.GetOptions().message_set_wire_format):
|
||
|
local_decoder = decoder.UnknownMessageSetItemDecoder()
|
||
|
for _, buffer in unknown_fields:
|
||
|
(field_number, data) = local_decoder(memoryview(buffer))
|
||
|
InternalAdd(field_number, wire_format.WIRETYPE_LENGTH_DELIMITED, data)
|
||
|
else:
|
||
|
for tag_bytes, buffer in unknown_fields:
|
||
|
# pylint: disable=protected-access
|
||
|
(tag, _) = decoder._DecodeVarint(tag_bytes, 0)
|
||
|
field_number, wire_type = wire_format.UnpackTag(tag)
|
||
|
if field_number == 0:
|
||
|
raise RuntimeError('Field number 0 is illegal.')
|
||
|
(data, _) = decoder._DecodeUnknownField(
|
||
|
memoryview(buffer), 0, wire_type)
|
||
|
InternalAdd(field_number, wire_type, data)
|
||
|
|
||
|
def __getitem__(self, index):
|
||
|
size = len(self._values)
|
||
|
if index < 0:
|
||
|
index += size
|
||
|
if index < 0 or index >= size:
|
||
|
raise IndexError('index %d out of range'.index)
|
||
|
|
||
|
return self._values[index]
|
||
|
|
||
|
def __len__(self):
|
||
|
return len(self._values)
|
||
|
|
||
|
def __iter__(self):
|
||
|
return iter(self._values)
|