diff options
Diffstat (limited to 'module/lib/thrift/protocol/TBase.py')
| -rw-r--r-- | module/lib/thrift/protocol/TBase.py | 298 | 
1 files changed, 298 insertions, 0 deletions
| diff --git a/module/lib/thrift/protocol/TBase.py b/module/lib/thrift/protocol/TBase.py new file mode 100644 index 000000000..dfe0d79ce --- /dev/null +++ b/module/lib/thrift/protocol/TBase.py @@ -0,0 +1,298 @@ +# +# 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.Thrift import * +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)) +      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(Exception): +  # old style class so python2.4 can raise exceptions derived from this +  #  This can't inherit from TBase because of that limitation. +  __slots__ = [] +   +  __repr__ = TBase.__repr__.im_func +  __eq__ = TBase.__eq__.im_func +  __ne__ = TBase.__ne__.im_func +  read = TBase.read.im_func +  write = TBase.write.im_func + +# +# 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.Thrift import * +from thrift.protocol import TBinaryProtocol +from thrift.transport import TTransport + +try: +  from thrift.protocol import fastbinary +except: +  fastbinary = None + +def read(iprot, types, ftype, spec): +    try: +        return types[ftype][0]() +    except KeyError: +        if ftype == TType.LIST: +            ltype, lsize = iprot.readListBegin() + +            value = [read(iprot, types, spec[0], spec[1]) for i in range(lsize)] + +            iprot.readListEnd() +            return value +         +        elif ftype == TType.SET: +            ltype, lsize = iprot.readSetBegin() + +            value = set([read(iprot, types, spec[0], spec[1]) for i in range(lsize)]) + +            iprot.readSetEnd() +            return value + +        elif ftype == TType.MAP: +            key_type, key_spec = spec[0], spec[1] +            val_type, val_spec = spec[2], spec[3] + +            ktype, vtype, mlen = iprot.readMapBegin() +            res = dict() + +            for i in xrange(mlen): +                key = read(iprot, types, key_type, key_spec) +                res[key] = read(iprot, types, val_type, val_spec) + +            iprot.readMapEnd() +            return res + +        elif ftype == TType.STRUCT: +            return spec[0]().read(iprot) + + + + +def write(oprot, types, ftype, spec, value): +    try: +        types[ftype][1](value) +    except KeyError: +        if ftype == TType.LIST: +            oprot.writeListBegin(spec[0], len(value)) + +            for elem in value: +                write(oprot, types, spec[0], spec[1], elem) + +            oprot.writeListEnd() +        elif ftype == TType.SET: +            oprot.writeSetBegin(spec[0], len(value)) + +            for elem in value: +                write(oprot, types, spec[0], spec[1], elem) +                 +            oprot.writeSetEnd() +        elif ftype == TType.MAP: +            key_type, key_spec = spec[0], spec[1] +            val_type, val_spec = spec[2], spec[3] + +            oprot.writeMapBegin(key_type, val_type, len(value)) +            for key, val in value.iteritems(): +                write(oprot, types, key_type, key_spec, key) +                write(oprot, types, val_type, val_spec, val) + +            oprot.writeMapEnd() +        elif ftype == TType.STRUCT: +            value.write(oprot) + + +class TBase2(object): +    __slots__ = ("thrift_spec") + +    #subclasses provides this information +    thrift_spec = () + +    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)) +            return + +        #local copies for faster access +        thrift_spec = self.thrift_spec +        setter = self.__setattr__ + +        iprot.readStructBegin() +        while True: +            (fname, ftype, fid) = iprot.readFieldBegin() +            if ftype == TType.STOP: +                break + +            try: +                specs = thrift_spec[fid] +                if not specs or specs[1] != ftype: +                    iprot.skip(ftype) + +                else: +                    pos, etype, ename, espec, unk = specs +                    value = read(iprot, iprot.primTypes, etype, espec) +                    setter(ename, value) +                     +            except IndexError: +                iprot.skip() + +            iprot.readFieldEnd() + +        iprot.readStructEnd() + +    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 + +        #local copies for faster access +        oprot.writeStructBegin(self.__class__.__name__) +        getter = self.__getattribute__ + +        for spec in self.thrift_spec: +            if spec is None: continue +            # element attributes +            pos, etype, ename, espec, unk = spec +            value = getter(ename) +            if value is None: continue + +            oprot.writeFieldBegin(ename, etype, pos) +            write(oprot, oprot.primTypes, etype, espec, value) +            oprot.writeFieldEnd() + +        oprot.writeFieldStop() +        oprot.writeStructEnd() + +class TBase(object): +  __slots__ = ('thrift_spec',) + +  #provides by subclasses +  thrift_spec = () + +  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)) +      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(Exception): +  # old style class so python2.4 can raise exceptions derived from this +  #  This can't inherit from TBase because of that limitation. +  __slots__ = [] +   +  __repr__ = TBase.__repr__.im_func +  __eq__ = TBase.__eq__.im_func +  __ne__ = TBase.__ne__.im_func +  read = TBase.read.im_func +  write = TBase.write.im_func + | 
