1
0
mirror of https://github.com/vlang/v.git synced 2023-08-10 21:13:21 +03:00

websocket: minor improvements in the server example

This commit is contained in:
Alexander Medvednikov 2021-01-31 15:18:04 +01:00
parent 9638013203
commit c91f7746fd

View File

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