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

checker: check struct field's fn call (fix #15249) (#15257)

This commit is contained in:
yuyi
2022-07-30 00:00:51 +08:00
committed by GitHub
parent 927ec1fadb
commit 0bf23488dc
6 changed files with 81 additions and 13 deletions

View File

@ -66,14 +66,14 @@ struct Picoev {
loop &C.picoev_loop
cb fn (voidptr, picohttpparser.Request, mut picohttpparser.Response)
err_cb fn (voidptr, picohttpparser.Request, mut picohttpparser.Response, IError)
user_data voidptr
timeout_secs int
max_headers int
mut:
date &u8
buf &u8
idx [1024]int
out &u8
user_data voidptr
date &u8
buf &u8
idx [1024]int
out &u8
}
[inline]
@ -158,20 +158,20 @@ fn rw_callback(loop &C.picoev_loop, fd int, events int, context voidptr) {
if pret > 0 { // Success
break
} else if pret == -1 { // Parse error
p.err_cb(mut p.user_data, req, mut &res, error('ParseError'))
p.err_cb(p.user_data, req, mut &res, error('ParseError'))
return
}
assert pret == -2
// request is incomplete, continue the loop
if p.idx[fd] == sizeof(buf) {
p.err_cb(mut p.user_data, req, mut &res, error('RequestIsTooLongError'))
p.err_cb(p.user_data, req, mut &res, error('RequestIsTooLongError'))
return
}
}
// Callback (should call .end() itself)
p.cb(mut p.user_data, req, mut &res)
p.cb(p.user_data, req, mut &res)
}
}
@ -180,7 +180,7 @@ fn accept_callback(loop &C.picoev_loop, fd int, events int, cb_arg voidptr) {
newfd := C.accept(fd, 0, 0)
if newfd != -1 {
setup_sock(newfd) or {
p.err_cb(mut p.user_data, picohttpparser.Request{}, mut &picohttpparser.Response{},
p.err_cb(p.user_data, picohttpparser.Request{}, mut &picohttpparser.Response{},
err)
}
C.picoev_add(voidptr(loop), newfd, int(Event.read), p.timeout_secs, rw_callback,
@ -221,7 +221,7 @@ pub fn new(config Config) &Picoev {
listen_res := C.listen(fd, C.SOMAXCONN)
assert listen_res == 0
setup_sock(fd) or {
config.err_cb(mut config.user_data, picohttpparser.Request{}, mut &picohttpparser.Response{},
config.err_cb(config.user_data, picohttpparser.Request{}, mut &picohttpparser.Response{},
err)
}