Fine tuning the "require" business.

This commit is contained in:
Diego Nehab 2004-05-30 21:36:22 +00:00
parent c23240726e
commit 5ca1049ab4
17 changed files with 133 additions and 116 deletions

View file

@ -4,6 +4,7 @@
-- Author: Diego Nehab
-- RCS ID: $Id$
-----------------------------------------------------------------------------
require("socket")
host = host or "*"
port = port or 8080
if arg then
@ -11,18 +12,10 @@ if arg then
port = arg[2] or port
end
print("Binding to host '" ..host.. "' and port " ..port.. "...")
s, e = socket.bind(host, port)
if not s then
print(e)
exit()
end
i, p = s:getsockname()
s = socket.try(socket.bind(host, port))
i, p = socket.try(s:getsockname())
print("Waiting connection from talker on " .. i .. ":" .. p .. "...")
c, e = s:accept()
if not c then
print(e)
exit()
end
c = socket.try(s:accept())
print("Connected. Here is the stuff:")
l, e = c:receive()
while not e do

View file

@ -4,6 +4,7 @@
-- Author: Diego Nehab
-- RCS ID: $Id$
-----------------------------------------------------------------------------
require("socket")
host = host or "localhost"
port = port or 8080
if arg then
@ -11,18 +12,10 @@ if arg then
port = arg[2] or port
end
print("Attempting connection to host '" ..host.. "' and port " ..port.. "...")
c, e = socket.connect(host, port)
if not c then
print(e)
os.exit()
end
c = socket.try(socket.connect(host, port))
print("Connected! Please type stuff (empty line to stop):")
l = io.read()
while l and l ~= "" and not e do
t, e = c:send(l, "\n")
if e then
print(e)
os.exit()
end
socket.try(c:send(l, "\n"))
l = io.read()
end

View file

@ -4,6 +4,7 @@
-- Author: Diego Nehab
-- RCS ID: $Id$
-----------------------------------------------------------------------------
require("socket")
host = host or "*"
port1 = port1 or 8080
port2 = port2 or 8181
@ -13,12 +14,10 @@ if arg then
port2 = arg[3] or port2
end
server1, error = socket.bind(host, port1)
assert(server1, error)
server1 = socket.try(socket.bind(host, port1))
server2 = socket.try(socket.bind(host, port2))
server1:settimeout(1) -- make sure we don't block in accept
server2, error = socket.bind(host, port2)
assert(server2, error)
server2:settimeout(1) -- make sure we don't block in accept
server2:settimeout(1)
io.write("Servers bound\n")
@ -49,7 +48,7 @@ set:insert(server2)
while 1 do
local readable, _, error = socket.select(set, nil)
for _, input in readable do
for _, input in ipairs(readable) do
-- is it a server socket?
if input == server1 or input == server2 then
io.write("Waiting for clients\n")
@ -68,10 +67,12 @@ while 1 do
set:remove(input)
else
io.write("Broadcasting line '", line, "'\n")
__, writable, error = socket.select(nil, set, 1)
writable, error = socket.skip(1, socket.select(nil, set, 1))
if not error then
for ___, output in writable do
output:send(line .. "\n")
for __, output in ipairs(writable) do
if output ~= input then
output:send(line .. "\n")
end
end
else io.write("No client ready to receive!!!\n") end
end