/
response.rb
84 lines (69 loc) · 1.89 KB
/
response.rb
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
module Riddle
class Client
# Used to interrogate responses from the Sphinx daemon. Keep in mind none
# of the methods here check whether the data they're grabbing are what the
# user expects - it just assumes the user knows what the data stream is
# made up of.
class Response
# Create with the data to interpret
def initialize(str)
@str = str
@marker = 0
end
# Return the next string value in the stream
def next
len = next_int
result = @str[@marker, len]
@marker += len
return result
end
# Return the next integer value from the stream
def next_int
int = @str[@marker, 4].unpack('N*').first
@marker += 4
return int
end
def next_64bit_int
high, low = @str[@marker, 8].unpack('N*N*')[0..1]
@marker += 8
return (high << 32) + low
end
# Return the next float value from the stream
def next_float
float = @str[@marker, 4].unpack('N*').pack('L').unpack('f*').first
@marker += 4
return float
end
# Returns an array of string items
def next_array
count = next_int
items = []
for i in 0...count
items << self.next
end
return items
end
# Returns an array of int items
def next_int_array
count = next_int
items = []
for i in 0...count
items << self.next_int
end
return items
end
def next_float_array
count = next_int
items = []
for i in 0...count
items << self.next_float
end
return items
end
# Returns the length of the streamed data
def length
@str.length
end
end
end
end