Class: Thrift::CompactProtocol
Defined Under Namespace
Classes: CompactTypes
Constant Summary
collapse
- PROTOCOL_ID =
[0x82].pack('c').unpack('c').first
- VERSION =
1
- VERSION_MASK =
0x1f
- TYPE_MASK =
0xE0
- TYPE_SHIFT_AMOUNT =
5
- TSTOP =
["", Types::STOP, 0]
Instance Attribute Summary
Attributes inherited from BaseProtocol
#trans
Instance Method Summary
collapse
-
#initialize(transport) ⇒ CompactProtocol
constructor
A new instance of CompactProtocol.
-
#read_bool ⇒ Object
-
#read_byte ⇒ Object
-
#read_double ⇒ Object
-
#read_field_begin ⇒ Object
-
#read_i16 ⇒ Object
-
#read_i32 ⇒ Object
-
#read_i64 ⇒ Object
-
#read_list_begin ⇒ Object
-
#read_map_begin ⇒ Object
-
#read_message_begin ⇒ Object
-
#read_set_begin ⇒ Object
-
#read_string ⇒ Object
-
#read_struct_begin ⇒ Object
-
#read_struct_end ⇒ Object
-
#write_bool(bool) ⇒ Object
-
#write_byte(byte) ⇒ Object
-
#write_double(dub) ⇒ Object
-
#write_field_begin(name, type, id) ⇒ Object
-
#write_field_begin_internal(type, id, type_override = nil) ⇒ Object
The workhorse of writeFieldBegin.
-
#write_field_stop ⇒ Object
-
#write_i16(i16) ⇒ Object
-
#write_i32(i32) ⇒ Object
-
#write_i64(i64) ⇒ Object
-
#write_list_begin(etype, size) ⇒ Object
-
#write_map_begin(ktype, vtype, size) ⇒ Object
-
#write_message_begin(name, type, seqid) ⇒ Object
-
#write_set_begin(etype, size) ⇒ Object
-
#write_string(str) ⇒ Object
-
#write_struct_begin(name) ⇒ Object
-
#write_struct_end ⇒ Object
#native?, #read_field_end, #read_list_end, #read_map_end, #read_message_end, #read_set_end, #read_type, #skip, #write_field, #write_field_end, #write_list_end, #write_map_end, #write_message_end, #write_set_end, #write_type
Constructor Details
Returns a new instance of CompactProtocol.
96
97
98
99
100
101
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 96
def initialize(transport)
super(transport)
@last_field = [0]
@boolean_value = nil
end
|
Instance Method Details
#read_bool ⇒ Object
293
294
295
296
297
298
299
300
301
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 293
def read_bool
unless @bool_value.nil?
bv = @bool_value
@bool_value = nil
bv
else
read_byte() == CompactTypes::BOOLEAN_TRUE
end
end
|
#read_byte ⇒ Object
303
304
305
306
307
308
309
310
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 303
def read_byte
dat = trans.read_all(1)
val = dat[0]
if (val > 0x7f)
val = 0 - ((val - 1) ^ 0xff)
end
val
end
|
#read_double ⇒ Object
324
325
326
327
328
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 324
def read_double
dat = trans.read_all(8)
val = dat.reverse.unpack('G').first
val
end
|
#read_field_begin ⇒ Object
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 242
def read_field_begin
type = read_byte()
if (type & 0x0f) == Types::STOP
TSTOP
else
field_id = nil
modifier = (type & 0xf0) >> 4
if modifier == 0
field_id = read_i16()
else
field_id = @last_field.pop + modifier
end
if CompactTypes.is_bool_type?(type)
@bool_value = (type & 0x0f) == CompactTypes::BOOLEAN_TRUE
end
@last_field.push(field_id)
["", CompactTypes.get_ttype(type & 0x0f), field_id]
end
end
|
#read_i16 ⇒ Object
312
313
314
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 312
def read_i16
zig_zag_to_int(read_varint32())
end
|
#read_i32 ⇒ Object
316
317
318
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 316
def read_i32
zig_zag_to_int(read_varint32())
end
|
#read_i64 ⇒ Object
320
321
322
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 320
def read_i64
zig_zag_to_long(read_varint64())
end
|
#read_list_begin ⇒ Object
279
280
281
282
283
284
285
286
287
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 279
def read_list_begin
size_and_type = read_byte()
size = (size_and_type >> 4) & 0x0f
if size == 15
size = read_varint32()
end
type = CompactTypes.get_ttype(size_and_type)
[type, size]
end
|
#read_map_begin ⇒ Object
273
274
275
276
277
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 273
def read_map_begin
size = read_varint32()
key_and_value_type = size == 0 ? 0 : read_byte()
[CompactTypes.get_ttype(key_and_value_type >> 4), CompactTypes.get_ttype(key_and_value_type & 0xf), size]
end
|
#read_message_begin ⇒ Object
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 214
def read_message_begin
protocol_id = read_byte()
if protocol_id != PROTOCOL_ID
raise ProtocolException.new("Expected protocol id #{PROTOCOL_ID} but got #{protocol_id}")
end
version_and_type = read_byte()
version = version_and_type & VERSION_MASK
if (version != VERSION)
raise ProtocolException.new("Expected version #{VERSION} but got #{version}");
end
type = (version_and_type >> TYPE_SHIFT_AMOUNT) & 0x03
seqid = read_varint32()
messageName = read_string()
[messageName, type, seqid]
end
|
#read_set_begin ⇒ Object
289
290
291
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 289
def read_set_begin
read_list_begin
end
|
#read_string ⇒ Object
330
331
332
333
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 330
def read_string
size = read_varint32()
trans.read_all(size)
end
|
#read_struct_begin ⇒ Object
232
233
234
235
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 232
def read_struct_begin
@last_field.push(0)
""
end
|
#read_struct_end ⇒ Object
237
238
239
240
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 237
def read_struct_end
@last_field.pop()
nil
end
|
#write_bool(bool) ⇒ Object
177
178
179
180
181
182
183
184
185
186
187
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 177
def write_bool(bool)
type = bool ? CompactTypes::BOOLEAN_TRUE : CompactTypes::BOOLEAN_FALSE
unless @boolean_field.nil?
write_field_begin_internal(@boolean_field.first, @boolean_field.last, type)
@boolean_field = nil
else
write_byte(type)
end
end
|
#write_byte(byte) ⇒ Object
189
190
191
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 189
def write_byte(byte)
@trans.write([byte].pack('c'))
end
|
#write_double(dub) ⇒ Object
205
206
207
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 205
def write_double(dub)
@trans.write([dub].pack("G").reverse)
end
|
#write_field_begin(name, type, id) ⇒ Object
121
122
123
124
125
126
127
128
129
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 121
def write_field_begin(name, type, id)
if type == Types::BOOL
@boolean_field = [type, id]
else
write_field_begin_internal(type, id)
end
nil
end
|
#write_field_begin_internal(type, id, type_override = nil) ⇒ Object
The workhorse of writeFieldBegin. It has the option of doing a ‘type override’ of the type header. This is used specifically in the boolean field case.
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 136
def write_field_begin_internal(type, id, type_override=nil)
last_id = @last_field.pop
typeToWrite = type_override || CompactTypes.get_compact_type(type)
if id > last_id && id - last_id <= 15
write_byte((id - last_id) << 4 | typeToWrite)
else
write_byte(typeToWrite)
write_i16(id)
end
@last_field.push(id)
nil
end
|
#write_field_stop ⇒ Object
156
157
158
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 156
def write_field_stop
write_byte(Types::STOP)
end
|
#write_i16(i16) ⇒ Object
193
194
195
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 193
def write_i16(i16)
write_varint32(int_to_zig_zag(i16))
end
|
#write_i32(i32) ⇒ Object
197
198
199
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 197
def write_i32(i32)
write_varint32(int_to_zig_zag(i32))
end
|
#write_i64(i64) ⇒ Object
201
202
203
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 201
def write_i64(i64)
write_varint64(long_to_zig_zag(i64))
end
|
#write_list_begin(etype, size) ⇒ Object
169
170
171
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 169
def write_list_begin(etype, size)
write_collection_begin(etype, size)
end
|
#write_map_begin(ktype, vtype, size) ⇒ Object
160
161
162
163
164
165
166
167
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 160
def write_map_begin(ktype, vtype, size)
if (size == 0)
write_byte(0)
else
write_varint32(size)
write_byte(CompactTypes.get_compact_type(ktype) << 4 | CompactTypes.get_compact_type(vtype))
end
end
|
#write_message_begin(name, type, seqid) ⇒ Object
103
104
105
106
107
108
109
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 103
def write_message_begin(name, type, seqid)
write_byte(PROTOCOL_ID)
write_byte((VERSION & VERSION_MASK) | ((type << TYPE_SHIFT_AMOUNT) & TYPE_MASK))
write_varint32(seqid)
write_string(name)
nil
end
|
#write_set_begin(etype, size) ⇒ Object
173
174
175
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 173
def write_set_begin(etype, size)
write_collection_begin(etype, size);
end
|
#write_string(str) ⇒ Object
209
210
211
212
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 209
def write_string(str)
write_varint32(str.length)
@trans.write(str)
end
|
#write_struct_begin(name) ⇒ Object
111
112
113
114
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 111
def write_struct_begin(name)
@last_field.push(0)
nil
end
|
#write_struct_end ⇒ Object
116
117
118
119
|
# File 'lib/thrift/protocol/compact_protocol.rb', line 116
def write_struct_end
@last_field.pop
nil
end
|