diff options
| author | 2011-08-15 11:34:38 +0200 | |
|---|---|---|
| committer | 2011-08-15 11:34:38 +0200 | |
| commit | a02dd3b213bcb0c8aff84dc0b2462ce21ed2cc6a (patch) | |
| tree | 03a2245a03ebee111fd9df61f95abd5890397dac /module/lib | |
| parent | rs fix (diff) | |
| download | pyload-a02dd3b213bcb0c8aff84dc0b2462ce21ed2cc6a.tar.xz | |
updated thrift, --clean method, youtube fix closed #379
Diffstat (limited to 'module/lib')
| -rw-r--r-- | module/lib/thrift/Thrift.py | 2 | ||||
| -rw-r--r-- | module/lib/thrift/protocol/TBase.py | 226 | ||||
| -rw-r--r-- | module/lib/thrift/protocol/TCompactProtocol.py | 28 | ||||
| -rw-r--r-- | module/lib/thrift/protocol/TProtocol.py | 22 | 
4 files changed, 38 insertions, 240 deletions
| diff --git a/module/lib/thrift/Thrift.py b/module/lib/thrift/Thrift.py index a96351276..1d271fcff 100644 --- a/module/lib/thrift/Thrift.py +++ b/module/lib/thrift/Thrift.py @@ -96,6 +96,8 @@ class TApplicationException(TException):    WRONG_METHOD_NAME = 3    BAD_SEQUENCE_ID = 4    MISSING_RESULT = 5 +  INTERNAL_ERROR = 6 +  PROTOCOL_ERROR = 7    def __init__(self, type=UNKNOWN, message=None):      TException.__init__(self, message) diff --git a/module/lib/thrift/protocol/TBase.py b/module/lib/thrift/protocol/TBase.py index dfe0d79ce..e675c7dc0 100644 --- a/module/lib/thrift/protocol/TBase.py +++ b/module/lib/thrift/protocol/TBase.py @@ -69,230 +69,4 @@ class TExceptionBase(Exception):    __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 - diff --git a/module/lib/thrift/protocol/TCompactProtocol.py b/module/lib/thrift/protocol/TCompactProtocol.py index 280b54f0f..016a33171 100644 --- a/module/lib/thrift/protocol/TCompactProtocol.py +++ b/module/lib/thrift/protocol/TCompactProtocol.py @@ -1,3 +1,22 @@ +# +# 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 TProtocol import *  from struct import pack, unpack @@ -204,7 +223,10 @@ class TCompactProtocol(TProtocolBase):              ctype = CompactType.FALSE          self.__writeFieldHeader(ctype, self.__bool_fid)      elif self.state == CONTAINER_WRITE: -      self.__writeByte(int(bool)) +       if bool: +           self.__writeByte(CompactType.TRUE) +       else: +           self.__writeByte(CompactType.FALSE)      else:        raise AssertionError, "Invalid state in compact protocol" @@ -338,9 +360,9 @@ class TCompactProtocol(TProtocolBase):    def readBool(self):      if self.state == BOOL_READ: -      return self.__bool_value +      return self.__bool_value == CompactType.TRUE      elif self.state == CONTAINER_READ: -      return bool(self.__readByte()) +      return self.__readByte() == CompactType.TRUE      else:        raise AssertionError, "Invalid state in compact protocol: %d" % self.state diff --git a/module/lib/thrift/protocol/TProtocol.py b/module/lib/thrift/protocol/TProtocol.py index beb6bea16..7338ff68a 100644 --- a/module/lib/thrift/protocol/TProtocol.py +++ b/module/lib/thrift/protocol/TProtocol.py @@ -247,10 +247,11 @@ class TProtocolBase:        for idx in xrange(list_len):          results.append(reader())      else: -      (elem_class, elem_spec) = tspec +      # this is like an inlined readFieldByTType +      container_reader = self._TTYPE_HANDLERS[list_type][0] +      val_reader = getattr(self, container_reader)        for idx in xrange(list_len): -        val = elem_class() -        val.read(self) +        val = val_reader(tspec)          results.append(val)      self.readListEnd()      return results @@ -260,17 +261,16 @@ class TProtocolBase:      ttype, tspec = spec[0], spec[1]      r_handler = self._TTYPE_HANDLERS[ttype][0]      reader = getattr(self, r_handler) -    (list_type, set_len) = self.readSetBegin() +    (set_type, set_len) = self.readSetBegin()      if tspec is None: -      # list values are simple types +      # set members are simple types        for idx in xrange(set_len):          results.add(reader())      else: -      (elem_class, elem_spec) = tspec +      container_reader = self._TTYPE_HANDLERS[set_type][0] +      val_reader = getattr(self, container_reader)        for idx in xrange(set_len): -        val = elem_class() -        val.read(self) -        results.add(val) +        results.add(val_reader(tspec))       self.readSetEnd()      return results @@ -336,7 +336,7 @@ class TProtocolBase:          e_writer(elem)      else:        for elem in val: -        e_writer(elem, spec) +        e_writer(elem, spec[1])      self.writeListEnd()    def writeContainerSet(self, val, spec): @@ -348,7 +348,7 @@ class TProtocolBase:          e_writer(elem)      else:        for elem in val: -        e_writer(elem, spec) +        e_writer(elem, spec[1])      self.writeSetEnd()    def writeContainerMap(self, val, spec): | 
