feat: handle error()s from buffer:read
This commit is contained in:
parent
26c6b24c78
commit
67e9e50339
35
mqtt.lua
35
mqtt.lua
|
@ -1,26 +1,36 @@
|
||||||
local mqtt = {}
|
local mqtt = {}
|
||||||
|
|
||||||
|
local safeRead = function (conn, n)
|
||||||
|
local success, result, err = pcall(conn.read, conn, n)
|
||||||
|
if success then
|
||||||
|
return result, err
|
||||||
|
end
|
||||||
|
|
||||||
|
return nil, result
|
||||||
|
end
|
||||||
|
|
||||||
local readVarint = function (conn, first_byte)
|
local readVarint = function (conn, first_byte)
|
||||||
local b
|
local b, err
|
||||||
if first_byte == nil then
|
if first_byte == nil then
|
||||||
b = conn:read(1)
|
b, err = safeRead(conn, 1)
|
||||||
else
|
else
|
||||||
b = first_byte
|
b = first_byte
|
||||||
end
|
end
|
||||||
|
|
||||||
local n, s = 0, 0
|
local n, s = 0, 0
|
||||||
while b ~= nil and b & 0x80 == 0x80 do
|
while err == nil and b & 0x80 == 0x80 do
|
||||||
if s > 21 then
|
if s > 21 then
|
||||||
return 0, "number too large"
|
return 0, "number too large"
|
||||||
end
|
end
|
||||||
|
|
||||||
n = n + ((b & 0x7F) << s)
|
n = n + ((b & 0x7F) << s)
|
||||||
s = s + 7
|
s = s + 7
|
||||||
b = conn:read(1)
|
|
||||||
|
b, err = safeRead(conn, 1)
|
||||||
end
|
end
|
||||||
|
|
||||||
if b == nil then
|
if err ~= nil then
|
||||||
return n, "eof"
|
return n, err
|
||||||
end
|
end
|
||||||
|
|
||||||
return n + (b << s), nil
|
return n + (b << s), nil
|
||||||
|
@ -43,6 +53,7 @@ function MqttClient:new (conn)
|
||||||
self.__index = self
|
self.__index = self
|
||||||
|
|
||||||
conn.readVarint = readVarint
|
conn.readVarint = readVarint
|
||||||
|
conn.safeRead = safeRead
|
||||||
conn:setTimeout(1)
|
conn:setTimeout(1)
|
||||||
|
|
||||||
c.conn = conn
|
c.conn = conn
|
||||||
|
@ -53,9 +64,9 @@ function MqttClient:new (conn)
|
||||||
end
|
end
|
||||||
|
|
||||||
function MqttClient:handle ()
|
function MqttClient:handle ()
|
||||||
local data = self.conn:read(2)
|
local data, err = self.conn:safeRead(2)
|
||||||
if data == nil then
|
if err ~= nil then
|
||||||
return "eof"
|
return err
|
||||||
end
|
end
|
||||||
|
|
||||||
local ptype, length, _ = string.unpack("B B", s)
|
local ptype, length, _ = string.unpack("B B", s)
|
||||||
|
@ -66,9 +77,9 @@ function MqttClient:handle ()
|
||||||
end
|
end
|
||||||
|
|
||||||
if length > 0 then
|
if length > 0 then
|
||||||
data = self.conn:read(length)
|
data, err = self.conn:safeRead(length)
|
||||||
if data == nil then
|
if err ~= nil then
|
||||||
return "eof"
|
return err
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
data = ""
|
data = ""
|
||||||
|
|
Loading…
Reference in New Issue