wininet: Store status code in http_request_t and use it in set_content_length.
diff --git a/dlls/wininet/http.c b/dlls/wininet/http.c
index 54db118..fae4543 100644
--- a/dlls/wininet/http.c
+++ b/dlls/wininet/http.c
@@ -2585,13 +2585,13 @@
};
/* set the request content length based on the headers */
-static DWORD set_content_length(http_request_t *request, DWORD status_code)
+static DWORD set_content_length(http_request_t *request)
{
static const WCHAR szChunked[] = {'c','h','u','n','k','e','d',0};
WCHAR encoding[20];
DWORD size;
- if(status_code == HTTP_STATUS_NO_CONTENT) {
+ if(request->status_code == HTTP_STATUS_NO_CONTENT) {
request->contentLength = request->netconn_stream.content_length = 0;
return ERROR_SUCCESS;
}
@@ -4826,7 +4826,7 @@
&dwStatusCode,&dwBufferSize,NULL) != ERROR_SUCCESS)
dwStatusCode = 0;
- res = set_content_length(request, dwStatusCode);
+ res = set_content_length(request);
if(res != ERROR_SUCCESS)
goto lend;
if(!request->contentLength)
@@ -5000,7 +5000,7 @@
&dwCode,&dwCodeLength,NULL) != ERROR_SUCCESS)
dwCode = 0;
- if ((res = set_content_length( request, dwCode )) == ERROR_SUCCESS) {
+ if ((res = set_content_length(request)) == ERROR_SUCCESS) {
if(!request->contentLength)
http_release_netconn(request, TRUE);
}
@@ -5692,6 +5692,8 @@
goto lend;
*status_text++=0;
+ request->status_code = atoiW(status_code);
+
TRACE("version [%s] status code [%s] status text [%s]\n",
debugstr_w(buffer), debugstr_w(status_code), debugstr_w(status_text) );