websocket: minor improvements in the server example

pull/8479/head
Alexander Medvednikov 2021-01-31 15:18:04 +01:00
parent 9638013203
commit c91f7746fd
1 changed files with 7 additions and 13 deletions

View File

@ -1,14 +1,12 @@
module main module main
import os
import x.websocket import x.websocket
import term import term
// this server accepts client connections and broadcast all messages to other connected clients // this server accepts client connections and broadcast all messages to other connected clients
fn main() { fn main() {
go start_server() println('press ctrl-c to quit...')
println('press enter to quit...') start_server() ?
os.get_line()
} }
fn start_server() ? { fn start_server() ? {
@ -22,17 +20,15 @@ fn start_server() ? {
return false return false
} }
return true return true
})? }) ?
// on_message_ref, broadcast all incoming messages to all clients except the one sent it // on_message_ref, broadcast all incoming messages to all clients except the one sent it
s.on_message_ref(fn (mut ws websocket.Client, msg &websocket.Message, mut m websocket.Server) ? { s.on_message_ref(fn (mut ws websocket.Client, msg &websocket.Message, mut m websocket.Server) ? {
// for _, cli in m.clients { // for _, cli in m.clients {
for i, _ in m.clients { for i, _ in m.clients {
mut c := m.clients[i] mut c := m.clients[i]
if c.client.state == .open && c.client.id != ws.id { if c.client.state == .open && c.client.id != ws.id {
c.client.write(msg.payload, websocket.OPCode.text_frame) or { c.client.write(msg.payload, websocket.OPCode.text_frame) or { panic(err) }
panic(err)
}
} }
} }
}, s) }, s)
@ -40,9 +36,7 @@ fn start_server() ? {
s.on_close(fn (mut ws websocket.Client, code int, reason string) ? { s.on_close(fn (mut ws websocket.Client, code int, reason string) ? {
println(term.green('client ($ws.id) closed connection')) println(term.green('client ($ws.id) closed connection'))
}) })
s.listen() or { s.listen() or { println(term.red('error on server listen: $err')) }
println(term.red('error on server listen: $err'))
}
unsafe { unsafe {
s.free() s.free()
} }