X-Git-Url: https://gerrit.automotivelinux.org/gerrit/gitweb?a=blobdiff_plain;f=src%2Fafb-ws.c;h=6d488878151169e31f6f552c3d5d096c0c438ca3;hb=197626868aaf84e9a68e8e7e5397ef1c6883a0f1;hp=cc852b20eba19521c866946d450bf68fcdaec507;hpb=2243a0dd1adc75530bed663db808971789729df3;p=src%2Fapp-framework-binder.git diff --git a/src/afb-ws.c b/src/afb-ws.c index cc852b20..6d488878 100644 --- a/src/afb-ws.c +++ b/src/afb-ws.c @@ -395,24 +395,24 @@ static int aws_read(struct afb_ws *ws, size_t size) ssize_t sz; char *buffer; - if (size != 0) { + if (size != 0 || ws->buffer.buffer == NULL) { buffer = realloc(ws->buffer.buffer, ws->buffer.size + size + 1); if (buffer == NULL) return 0; ws->buffer.buffer = buffer; - do { + while (size != 0) { sz = websock_read(ws->ws, &buffer[ws->buffer.size], size); if (sz < 0) { if (errno != EAGAIN) return 0; pfd.fd = ws->fd; pfd.events = POLLIN; - poll(&pfd, 1, 10); + poll(&pfd, 1, 10); /* TODO: make fully asynchronous websockets */ } else { ws->buffer.size += (size_t)sz; size -= (size_t)sz; } - } while (size != 0); + } } return 1; } @@ -498,7 +498,7 @@ static void aws_on_binary(struct afb_ws *ws, int last, size_t size) } /* - * Callback when 'close' command received from 'ws' with 'code' and 'size'. + * Callback when 'continue' command received from 'ws' with 'code' and 'size'. */ static void aws_on_continue(struct afb_ws *ws, int last, size_t size) {