X-Git-Url: https://git.m6w6.name/?p=m6w6%2Fext-http;a=blobdiff_plain;f=php_http_message_body.c;h=6129caff1a9bc4eb2e4af7171eb267f87f8ed196;hp=84e84e4abece2361aef9bd0727dd87bd9153b3b0;hb=629c7b270b047582160c87b7c688c2b942a75d60;hpb=8573aba3509b1b6eb197ae59d32ca7c81bfe957e diff --git a/php_http_message_body.c b/php_http_message_body.c index 84e84e4..6129caf 100644 --- a/php_http_message_body.c +++ b/php_http_message_body.c @@ -482,9 +482,11 @@ static size_t splitbody(void *opaque, char *buf, size_t len TSRMLS_DC) } if (!first_boundary) { + int st; /* this is not the first boundary, read rest of this message */ php_http_buffer_append(&arg->buf, buf, real_boundary - buf); - php_http_message_parser_parse(arg->parser, &arg->buf, 0, &arg->parser->message); + st=php_http_message_parser_parse(arg->parser, &arg->buf, 0, &arg->parser->message); + //fprintf(stderr, "1 st=%d\n",st); } /* move after the boundary */ @@ -524,9 +526,11 @@ static size_t splitbody(void *opaque, char *buf, size_t len TSRMLS_DC) /* let there be room for the next boundary */ if (len > arg->boundary_len) { + int st; consumed += len - arg->boundary_len; php_http_buffer_append(&arg->buf, buf, len - arg->boundary_len); - php_http_message_parser_parse(arg->parser, &arg->buf, 0, &arg->parser->message); + st=php_http_message_parser_parse(arg->parser, &arg->buf, 0, &arg->parser->message); + //fprintf(stderr, "2 st=%d\n", st); } arg->consumed += consumed;