websocket: make compile with autofree (#8023)
parent
67d7b87d28
commit
cc17f145c5
|
@ -54,6 +54,7 @@ pub fn new() &Digest {
|
||||||
return d
|
return d
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[manualfree]
|
||||||
pub fn (mut d Digest) write(p_ []byte) int {
|
pub fn (mut d Digest) write(p_ []byte) int {
|
||||||
nn := p_.len
|
nn := p_.len
|
||||||
unsafe {
|
unsafe {
|
||||||
|
|
|
@ -451,6 +451,7 @@ fn parse_request_uri(rawurl string) ?URL {
|
||||||
// via_request is true, the URL is assumed to have arrived via an HTTP request,
|
// via_request is true, the URL is assumed to have arrived via an HTTP request,
|
||||||
// in which case only absolute URLs or path-absolute relative URLs are allowed.
|
// in which case only absolute URLs or path-absolute relative URLs are allowed.
|
||||||
// If via_request is false, all forms of relative URLs are allowed.
|
// If via_request is false, all forms of relative URLs are allowed.
|
||||||
|
[manualfree]
|
||||||
fn parse_url(rawurl string, via_request bool) ?URL {
|
fn parse_url(rawurl string, via_request bool) ?URL {
|
||||||
if string_contains_ctl_byte(rawurl) {
|
if string_contains_ctl_byte(rawurl) {
|
||||||
return error(error_msg('parse_url: invalid control character in URL', rawurl))
|
return error(error_msg('parse_url: invalid control character in URL', rawurl))
|
||||||
|
|
|
@ -1,3 +1,4 @@
|
||||||
|
[manualfree]
|
||||||
module websocket
|
module websocket
|
||||||
|
|
||||||
import encoding.base64
|
import encoding.base64
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
// websocket module implements websocket client and a websocket server
|
// websocket module implements websocket client and a websocket server
|
||||||
// attribution: @thecoderr the author of original websocket client
|
// attribution: @thecoderr the author of original websocket client
|
||||||
|
[manualfree]
|
||||||
module websocket
|
module websocket
|
||||||
|
|
||||||
import net
|
import net
|
||||||
|
@ -103,7 +104,9 @@ pub fn (mut ws Client) connect() ? {
|
||||||
|
|
||||||
// listen listens and processes incoming messages
|
// listen listens and processes incoming messages
|
||||||
pub fn (mut ws Client) listen() ? {
|
pub fn (mut ws Client) listen() ? {
|
||||||
ws.logger.info('Starting client listener, server($ws.is_server)...')
|
mut log := 'Starting client listener, server($ws.is_server)...'
|
||||||
|
ws.logger.info(log)
|
||||||
|
log.free()
|
||||||
defer {
|
defer {
|
||||||
ws.logger.info('Quit client listener, server($ws.is_server)...')
|
ws.logger.info('Quit client listener, server($ws.is_server)...')
|
||||||
if ws.state == .open {
|
if ws.state == .open {
|
||||||
|
@ -125,7 +128,9 @@ pub fn (mut ws Client) listen() ? {
|
||||||
ws.debug_log('got message: $msg.opcode')
|
ws.debug_log('got message: $msg.opcode')
|
||||||
match msg.opcode {
|
match msg.opcode {
|
||||||
.text_frame {
|
.text_frame {
|
||||||
ws.debug_log('read: text')
|
log = 'read: text'
|
||||||
|
ws.debug_log(log)
|
||||||
|
log.free()
|
||||||
ws.send_message_event(msg)
|
ws.send_message_event(msg)
|
||||||
unsafe { msg.free() }
|
unsafe { msg.free() }
|
||||||
}
|
}
|
||||||
|
@ -157,7 +162,9 @@ pub fn (mut ws Client) listen() ? {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
.close {
|
.close {
|
||||||
ws.debug_log('read: close')
|
log = 'read: close'
|
||||||
|
ws.debug_log(log)
|
||||||
|
log.free()
|
||||||
defer {
|
defer {
|
||||||
ws.manage_clean_close()
|
ws.manage_clean_close()
|
||||||
}
|
}
|
||||||
|
@ -219,7 +226,7 @@ pub fn (mut ws Client) pong() ? {
|
||||||
|
|
||||||
// write_ptr writes len bytes provided a byteptr with a websocket messagetype
|
// write_ptr writes len bytes provided a byteptr with a websocket messagetype
|
||||||
pub fn (mut ws Client) write_ptr(bytes byteptr, payload_len int, code OPCode) ? {
|
pub fn (mut ws Client) write_ptr(bytes byteptr, payload_len int, code OPCode) ? {
|
||||||
ws.debug_log('write_ptr code: $code')
|
// ws.debug_log('write_ptr code: $code')
|
||||||
if ws.state != .open || ws.conn.sock.handle < 1 {
|
if ws.state != .open || ws.conn.sock.handle < 1 {
|
||||||
// todo: send error here later
|
// todo: send error here later
|
||||||
return error('trying to write on a closed socket!')
|
return error('trying to write on a closed socket!')
|
||||||
|
@ -402,12 +409,14 @@ fn (mut ws Client) send_control_frame(code OPCode, frame_typ string, payload []b
|
||||||
// parse_uri parses the url to a Uri
|
// parse_uri parses the url to a Uri
|
||||||
fn parse_uri(url string) ?&Uri {
|
fn parse_uri(url string) ?&Uri {
|
||||||
u := urllib.parse(url) ?
|
u := urllib.parse(url) ?
|
||||||
v := u.request_uri().split('?')
|
request_uri := u.request_uri()
|
||||||
|
v := request_uri.split('?')
|
||||||
mut port := u.port()
|
mut port := u.port()
|
||||||
|
uri := u.str()
|
||||||
if port == '' {
|
if port == '' {
|
||||||
port = if u.str().starts_with('ws://') {
|
port = if uri.starts_with('ws://') {
|
||||||
'80'
|
'80'
|
||||||
} else if u.str().starts_with('wss://') {
|
} else if uri.starts_with('wss://') {
|
||||||
'443'
|
'443'
|
||||||
} else {
|
} else {
|
||||||
u.port()
|
u.port()
|
||||||
|
|
Loading…
Reference in New Issue