summaryrefslogtreecommitdiff
path: root/lib/py/src/protocol/TBase.py
blob: d106f4e03bb8d8078876ffe6dfb893ede26b8238 (plain)
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
87
88
89
90
91
92
93
94
95
96
97
98
#
# Licensed to the Apache Software Foundation (ASF) under one
# or more contributor license agreements. See the NOTICE file
# distributed with this work for additional information
# regarding copyright ownership. The ASF licenses this file
# to you under the Apache License, Version 2.0 (the
# "License"); you may not use this file except in compliance
# with the License. You may obtain a copy of the License at
#
#   http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing,
# software distributed under the License is distributed on an
# "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
# KIND, either express or implied. See the License for the
# specific language governing permissions and limitations
# under the License.
#

from thrift.protocol import TBinaryProtocol
from thrift.transport import TTransport

try:
  from thrift.protocol import fastbinary
except:
  fastbinary = None


class TBase(object):
  __slots__ = ()

  def __repr__(self):
    L = ['%s=%r' % (key, getattr(self, key)) for key in self.__slots__]
    return '%s(%s)' % (self.__class__.__name__, ', '.join(L))

  def __eq__(self, other):
    if not isinstance(other, self.__class__):
      return False
    for attr in self.__slots__:
      my_val = getattr(self, attr)
      other_val = getattr(other, attr)
      if my_val != other_val:
        return False
    return True

  def __ne__(self, other):
    return not (self == other)

  def read(self, iprot):
    if (iprot.__class__ == TBinaryProtocol.TBinaryProtocolAccelerated and
       isinstance(iprot.trans, TTransport.CReadableTransport) and
       self.thrift_spec is not None and
       fastbinary is not None):
      fastbinary.decode_binary(self,
                               iprot.trans,
                               (self.__class__, self.thrift_spec),
                               iprot.string_length_limit,
                               iprot.container_length_limit)
      return
    iprot.readStruct(self, self.thrift_spec)

  def write(self, oprot):
    if (oprot.__class__ == TBinaryProtocol.TBinaryProtocolAccelerated and
       self.thrift_spec is not None and
       fastbinary is not None):
      oprot.trans.write(
        fastbinary.encode_binary(self, (self.__class__, self.thrift_spec)))
      return
    oprot.writeStruct(self, self.thrift_spec)


class TExceptionBase(TBase, Exception):
  pass


class TFrozenBase(TBase):
  def __setitem__(self, *args):
    raise TypeError("Can't modify frozen struct")

  def __delitem__(self, *args):
    raise TypeError("Can't modify frozen struct")

  def __hash__(self, *args):
    return hash(self.__class__) ^ hash(self.__slots__)

  @classmethod
  def read(cls, iprot):
    if (iprot.__class__ == TBinaryProtocol.TBinaryProtocolAccelerated and
       isinstance(iprot.trans, TTransport.CReadableTransport) and
       cls.thrift_spec is not None and
       fastbinary is not None):
      self = cls()
      return fastbinary.decode_binary(None,
                                      iprot.trans,
                                      (self.__class__, self.thrift_spec),
                                      iprot.string_length_limit,
                                      iprot.container_length_limit)
    return iprot.readStruct(cls, cls.thrift_spec, True)