websocket: make compile with autofree (#8023)

pull/8030/head
Tomas Hellström 2021-01-11 09:03:10 +01:00 committed by GitHub
parent 67d7b87d28
commit cc17f145c5
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 19 additions and 7 deletions

View File

@ -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 {

View File

@ -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))

View File

@ -1,3 +1,4 @@
[manualfree]
module websocket module websocket
import encoding.base64 import encoding.base64

View File

@ -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()