summaryrefslogtreecommitdiff
path: root/tcpip/test_server.icl
diff options
context:
space:
mode:
Diffstat (limited to 'tcpip/test_server.icl')
-rw-r--r--tcpip/test_server.icl28
1 files changed, 28 insertions, 0 deletions
diff --git a/tcpip/test_server.icl b/tcpip/test_server.icl
new file mode 100644
index 0000000..c5cf11f
--- /dev/null
+++ b/tcpip/test_server.icl
@@ -0,0 +1,28 @@
+module test_server
+
+import StdEnv
+import StdLib
+import TCPIP
+
+Start w
+# (ok, mbListener, w) = openTCP_Listener 12345 w
+| not ok = abort "Couldn't open port 12345\n"
+# listener = fromJust mbListener
+# (listener, w) = loop listener w //((_,duplexChannel),listener,w) = receive listener w
+# w = closeRChannel listener w
+= w
+where
+ loop :: !TCP_Listener !*World -> (TCP_Listener, *World)
+ loop li w
+ # ((ip,dupChan),li,w) = receive li w
+ # (msg, rChan, w) = receive dupChan.rChannel w
+ dupChan = {dupChan & rChannel=rChan}
+ # (sChan, w) = send msg dupChan.sChannel w
+ dupChan = {dupChan & sChannel=sChan}
+ # w = closeRChannel dupChan.rChannel w
+ # w = closeChannel dupChan.sChannel w
+ # (io, w) = stdio w
+ # io = fwrites (toString ip +++ ": " +++ toString msg) io
+ # (_, w) = fclose io w
+ | length [1..999999999] == 999999999 = loop li w
+