From: Aric Stewart Date: Thu, 17 Apr 2008 18:05:41 +0000 (-0500) Subject: wininet: Correct the case where Content-Length is set as well as Transfer-Encoding... X-Git-Tag: wine-0.9.60~22 X-Git-Url: http://git.etersoft.ru/projects/?a=commitdiff_plain;h=bade2a31a60af7e9520b89aa5c3491eae19b2c22;p=wine%2Feterwine.git wininet: Correct the case where Content-Length is set as well as Transfer-Encoding == chunked. --- diff --git a/dlls/wininet/http.c b/dlls/wininet/http.c index e2ee9af073..53e033197f 100644 --- a/dlls/wininet/http.c +++ b/dlls/wininet/http.c @@ -3239,6 +3239,8 @@ BOOL WINAPI HTTP_HttpSendRequestW(LPWININETHTTPREQW lpwhr, LPCWSTR lpszHeaders, { DWORD dwBufferSize; DWORD dwStatusCode; + WCHAR encoding[20]; + static const WCHAR szChunked[] = {'c','h','u','n','k','e','d',0}; INTERNET_SendCallback(&lpwhr->hdr, lpwhr->hdr.dwContext, INTERNET_STATUS_RECEIVING_RESPONSE, NULL, 0); @@ -3264,6 +3266,15 @@ BOOL WINAPI HTTP_HttpSendRequestW(LPWININETHTTPREQW lpwhr, LPCWSTR lpszHeaders, if (lpwhr->dwContentLength == 0) HTTP_FinishedReading(lpwhr); + /* Correct the case where both a Content-Length and Transfer-encoding = chuncked are set */ + + dwBufferSize = sizeof(encoding); + if (HTTP_HttpQueryInfoW(lpwhr, HTTP_QUERY_TRANSFER_ENCODING, encoding, &dwBufferSize, NULL) && + !strcmpiW(encoding, szChunked)) + { + lpwhr->dwContentLength = -1; + } + dwBufferSize = sizeof(dwStatusCode); if (!HTTP_HttpQueryInfoW(lpwhr,HTTP_QUERY_FLAG_NUMBER|HTTP_QUERY_STATUS_CODE, &dwStatusCode,&dwBufferSize,NULL))