Roger Meier | 6cf0ffc | 2014-04-05 00:45:42 +0200 | [diff] [blame] | 1 | -- |
| 2 | -- Licensed to the Apache Software Foundation (ASF) under one |
| 3 | -- or more contributor license agreements. See the NOTICE file |
| 4 | -- distributed with this work for additional information |
| 5 | -- regarding copyright ownership. The ASF licenses this file |
| 6 | -- to you under the Apache License, Version 2.0 (the |
| 7 | -- "License"); you may not use this file except in compliance |
| 8 | -- with the License. You may obtain a copy of the License at |
| 9 | -- |
| 10 | -- http://www.apache.org/licenses/LICENSE-2.0 |
| 11 | -- |
| 12 | -- Unless required by applicable law or agreed to in writing, |
| 13 | -- software distributed under the License is distributed on an |
| 14 | -- "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
| 15 | -- KIND, either express or implied. See the License for the |
| 16 | -- specific language governing permissions and limitations |
| 17 | -- under the License. |
| 18 | -- |
| 19 | |
| 20 | require 'Thrift' |
| 21 | |
| 22 | TProtocolException = TException:new { |
| 23 | UNKNOWN = 0, |
| 24 | INVALID_DATA = 1, |
| 25 | NEGATIVE_SIZE = 2, |
| 26 | SIZE_LIMIT = 3, |
| 27 | BAD_VERSION = 4, |
| 28 | INVALID_PROTOCOL = 5, |
Jens Geyer | 6d1a83a | 2014-05-03 00:49:05 +0200 | [diff] [blame] | 29 | DEPTH_LIMIT = 6, |
Roger Meier | 6cf0ffc | 2014-04-05 00:45:42 +0200 | [diff] [blame] | 30 | errorCode = 0, |
| 31 | __type = 'TProtocolException' |
| 32 | } |
| 33 | function TProtocolException:__errorCodeToString() |
| 34 | if self.errorCode == self.INVALID_DATA then |
| 35 | return 'Invalid data' |
| 36 | elseif self.errorCode == self.NEGATIVE_SIZE then |
| 37 | return 'Negative size' |
| 38 | elseif self.errorCode == self.SIZE_LIMIT then |
| 39 | return 'Size limit' |
| 40 | elseif self.errorCode == self.BAD_VERSION then |
| 41 | return 'Bad version' |
| 42 | elseif self.errorCode == self.INVALID_PROTOCOL then |
| 43 | return 'Invalid protocol' |
Jens Geyer | 6d1a83a | 2014-05-03 00:49:05 +0200 | [diff] [blame] | 44 | elseif self.errorCode == self.DEPTH_LIMIT then |
| 45 | return 'Exceeded size limit' |
Roger Meier | 6cf0ffc | 2014-04-05 00:45:42 +0200 | [diff] [blame] | 46 | else |
| 47 | return 'Default (unknown)' |
| 48 | end |
| 49 | end |
| 50 | |
| 51 | TProtocolBase = __TObject:new{ |
| 52 | __type = 'TProtocolBase', |
| 53 | trans |
| 54 | } |
| 55 | |
| 56 | function TProtocolBase:new(obj) |
| 57 | if ttype(obj) ~= 'table' then |
| 58 | error(ttype(self) .. 'must be initialized with a table') |
| 59 | end |
| 60 | |
| 61 | -- Ensure a transport is provided |
| 62 | if not obj.trans then |
| 63 | error('You must provide ' .. ttype(self) .. ' with a trans') |
| 64 | end |
| 65 | |
| 66 | return __TObject.new(self, obj) |
| 67 | end |
| 68 | |
| 69 | function TProtocolBase:writeMessageBegin(name, ttype, seqid) end |
| 70 | function TProtocolBase:writeMessageEnd() end |
| 71 | function TProtocolBase:writeStructBegin(name) end |
| 72 | function TProtocolBase:writeStructEnd() end |
| 73 | function TProtocolBase:writeFieldBegin(name, ttype, id) end |
| 74 | function TProtocolBase:writeFieldEnd() end |
| 75 | function TProtocolBase:writeFieldStop() end |
| 76 | function TProtocolBase:writeMapBegin(ktype, vtype, size) end |
| 77 | function TProtocolBase:writeMapEnd() end |
| 78 | function TProtocolBase:writeListBegin(ttype, size) end |
| 79 | function TProtocolBase:writeListEnd() end |
| 80 | function TProtocolBase:writeSetBegin(ttype, size) end |
| 81 | function TProtocolBase:writeSetEnd() end |
| 82 | function TProtocolBase:writeBool(bool) end |
| 83 | function TProtocolBase:writeByte(byte) end |
| 84 | function TProtocolBase:writeI16(i16) end |
| 85 | function TProtocolBase:writeI32(i32) end |
| 86 | function TProtocolBase:writeI64(i64) end |
| 87 | function TProtocolBase:writeDouble(dub) end |
| 88 | function TProtocolBase:writeString(str) end |
| 89 | function TProtocolBase:readMessageBegin() end |
| 90 | function TProtocolBase:readMessageEnd() end |
| 91 | function TProtocolBase:readStructBegin() end |
| 92 | function TProtocolBase:readStructEnd() end |
| 93 | function TProtocolBase:readFieldBegin() end |
| 94 | function TProtocolBase:readFieldEnd() end |
| 95 | function TProtocolBase:readMapBegin() end |
| 96 | function TProtocolBase:readMapEnd() end |
| 97 | function TProtocolBase:readListBegin() end |
| 98 | function TProtocolBase:readListEnd() end |
| 99 | function TProtocolBase:readSetBegin() end |
| 100 | function TProtocolBase:readSetEnd() end |
| 101 | function TProtocolBase:readBool() end |
| 102 | function TProtocolBase:readByte() end |
| 103 | function TProtocolBase:readI16() end |
| 104 | function TProtocolBase:readI32() end |
| 105 | function TProtocolBase:readI64() end |
| 106 | function TProtocolBase:readDouble() end |
| 107 | function TProtocolBase:readString() end |
| 108 | |
| 109 | function TProtocolBase:skip(ttype) |
| 110 | if type == TType.STOP then |
| 111 | return |
| 112 | elseif ttype == TType.BOOL then |
| 113 | self:readBool() |
| 114 | elseif ttype == TType.BYTE then |
| 115 | self:readByte() |
| 116 | elseif ttype == TType.I16 then |
| 117 | self:readI16() |
| 118 | elseif ttype == TType.I32 then |
| 119 | self:readI32() |
| 120 | elseif ttype == TType.I64 then |
| 121 | self:readI64() |
| 122 | elseif ttype == TType.DOUBLE then |
| 123 | self:readDouble() |
| 124 | elseif ttype == TType.STRING then |
| 125 | self:readString() |
| 126 | elseif ttype == TType.STRUCT then |
| 127 | local name = self:readStructBegin() |
| 128 | while true do |
| 129 | local name, ttype, id = self:readFieldBegin() |
| 130 | if ttype == TType.STOP then |
| 131 | break |
| 132 | end |
| 133 | self:skip(ttype) |
| 134 | self:readFieldEnd() |
| 135 | end |
| 136 | self:readStructEnd() |
| 137 | elseif ttype == TType.MAP then |
| 138 | local kttype, vttype, size = self:readMapBegin() |
| 139 | for i = 1, size, 1 do |
| 140 | self:skip(kttype) |
| 141 | self:skip(vttype) |
| 142 | end |
| 143 | self:readMapEnd() |
| 144 | elseif ttype == TType.SET then |
| 145 | local ettype, size = self:readSetBegin() |
| 146 | for i = 1, size, 1 do |
| 147 | self:skip(ettype) |
| 148 | end |
| 149 | self:readSetEnd() |
| 150 | elseif ttype == TType.LIST then |
| 151 | local ettype, size = self:readListBegin() |
| 152 | for i = 1, size, 1 do |
| 153 | self:skip(ettype) |
| 154 | end |
| 155 | self:readListEnd() |
| 156 | end |
| 157 | end |
| 158 | |
| 159 | TProtocolFactory = __TObject:new{ |
| 160 | __type = 'TProtocolFactory', |
| 161 | } |
| 162 | function TProtocolFactory:getProtocol(trans) end |