mirror of https://github.com/mgba-emu/mgba.git
Res: sample socket client and socket server scripts
This commit is contained in:
parent
d852c7c8f0
commit
6822e04c08
|
@ -0,0 +1,103 @@
|
||||||
|
lastkeys = nil
|
||||||
|
server = nil
|
||||||
|
ST_sockets = {}
|
||||||
|
nextID = 1
|
||||||
|
|
||||||
|
local KEY_NAMES = { "A", "B", "s", "S", "<", ">", "^", "v", "R", "L" }
|
||||||
|
|
||||||
|
function ST_stop(id)
|
||||||
|
local sock = ST_sockets[id]
|
||||||
|
ST_sockets[id] = nil
|
||||||
|
sock:close()
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_format(id, msg, isError)
|
||||||
|
local prefix = "Socket " .. id
|
||||||
|
if isError then
|
||||||
|
prefix = prefix .. " Error: "
|
||||||
|
else
|
||||||
|
prefix = prefix .. " Received: "
|
||||||
|
end
|
||||||
|
return prefix .. msg
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_error(id, err)
|
||||||
|
console:error(ST_format(id, err, true))
|
||||||
|
ST_stop(id)
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_received(id)
|
||||||
|
local sock = ST_sockets[id]
|
||||||
|
if not sock then return end
|
||||||
|
while true do
|
||||||
|
local p, err = sock:receive(1024)
|
||||||
|
if p then
|
||||||
|
console:log(ST_format(id, p:match("^(.-)%s*$")))
|
||||||
|
else
|
||||||
|
if err ~= socket.ERRORS.AGAIN then
|
||||||
|
console:error(ST_format(id, err, true))
|
||||||
|
ST_stop(id)
|
||||||
|
end
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_scankeys()
|
||||||
|
local keys = emu:getKeys()
|
||||||
|
if keys ~= lastkeys then
|
||||||
|
lastkeys = keys
|
||||||
|
local msg = "["
|
||||||
|
for i, k in ipairs(KEY_NAMES) do
|
||||||
|
if (keys & (1 << (i - 1))) == 0 then
|
||||||
|
msg = msg .. " "
|
||||||
|
else
|
||||||
|
msg = msg .. k;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
msg = msg .. "]\n"
|
||||||
|
for id, sock in pairs(ST_sockets) do
|
||||||
|
if sock then sock:send(msg) end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_accept()
|
||||||
|
local sock, err = server:accept()
|
||||||
|
if err then
|
||||||
|
console:error(ST_format("Accept", err, true))
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local id = nextID
|
||||||
|
nextID = id + 1
|
||||||
|
ST_sockets[id] = sock
|
||||||
|
sock:add("received", function() ST_received(id) end)
|
||||||
|
sock:add("error", function() ST_error(id) end)
|
||||||
|
console:log(ST_format(id, "Connected"))
|
||||||
|
end
|
||||||
|
|
||||||
|
callbacks:add("keysRead", ST_scankeys)
|
||||||
|
|
||||||
|
local port = 8888
|
||||||
|
server = nil
|
||||||
|
while not server do
|
||||||
|
server, err = socket.bind(nil, port)
|
||||||
|
if err then
|
||||||
|
if err == "address in use" then
|
||||||
|
port = port + 1
|
||||||
|
else
|
||||||
|
console:error(ST_format("Bind", err, true))
|
||||||
|
break
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local ok
|
||||||
|
ok, err = server:listen()
|
||||||
|
if err then
|
||||||
|
server:close()
|
||||||
|
console:error(ST_format("Listen", err, true))
|
||||||
|
else
|
||||||
|
console:log("Socket Server Test: Listening on port " .. port)
|
||||||
|
server:add("received", ST_accept)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
|
@ -0,0 +1,69 @@
|
||||||
|
sockettest = nil
|
||||||
|
lastkeys = nil
|
||||||
|
|
||||||
|
local KEY_NAMES = { "A", "B", "s", "S", "<", ">", "^", "v", "R", "L" }
|
||||||
|
|
||||||
|
function ST_stop()
|
||||||
|
if not sockettest then return end
|
||||||
|
console:log("Socket Test: Shutting down")
|
||||||
|
sockettest:close()
|
||||||
|
sockettest = nil
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_start()
|
||||||
|
ST_stop()
|
||||||
|
console:log("Socket Test: Connecting to 127.0.0.1:8888...")
|
||||||
|
sockettest = socket.tcp()
|
||||||
|
sockettest:add("received", ST_received)
|
||||||
|
sockettest:add("error", ST_error)
|
||||||
|
if sockettest:connect("127.0.0.1", 8888) then
|
||||||
|
console:log("Socket Test: Connected")
|
||||||
|
lastkeys = nil
|
||||||
|
else
|
||||||
|
console:log("Socket Test: Failed to connect")
|
||||||
|
ST_stop()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_error(err)
|
||||||
|
console:error("Socket Test Error: " .. err)
|
||||||
|
ST_stop()
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_received()
|
||||||
|
while true do
|
||||||
|
local p, err = sockettest:receive(1024)
|
||||||
|
if p then
|
||||||
|
console:log("Socket Test Received: " .. p:match("^(.-)%s*$"))
|
||||||
|
else
|
||||||
|
if err ~= socket.ERRORS.AGAIN then
|
||||||
|
console:error("Socket Test Error: " .. err)
|
||||||
|
ST_stop()
|
||||||
|
end
|
||||||
|
return
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function ST_scankeys()
|
||||||
|
if not sockettest then return end
|
||||||
|
local keys = emu:getKeys()
|
||||||
|
if keys ~= lastkeys then
|
||||||
|
lastkeys = keys
|
||||||
|
local msg = "["
|
||||||
|
for i, k in ipairs(KEY_NAMES) do
|
||||||
|
if (keys & (1 << (i - 1))) == 0 then
|
||||||
|
msg = msg .. " "
|
||||||
|
else
|
||||||
|
msg = msg .. k;
|
||||||
|
end
|
||||||
|
end
|
||||||
|
sockettest:send(msg .. "]\n")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
callbacks:add("start", ST_start)
|
||||||
|
callbacks:add("stop", ST_stop)
|
||||||
|
callbacks:add("crashed", ST_stop)
|
||||||
|
callbacks:add("reset", ST_start)
|
||||||
|
callbacks:add("keysRead", ST_scankeys)
|
Loading…
Reference in New Issue