HttpSendRequestExA/W doesn't touch lpBuffersIn->Next, so simplify the

code a bit.
Modify test case to demonstrate this.
This commit is contained in:
Robert Shearman 2005-11-29 11:42:23 +01:00 committed by Alexandre Julliard
parent dd3e1dc525
commit 4350357634
2 changed files with 33 additions and 63 deletions

View File

@ -1506,62 +1506,43 @@ BOOL WINAPI HttpSendRequestExA(HINTERNET hRequest,
LPINTERNET_BUFFERSA lpBuffersOut, LPINTERNET_BUFFERSA lpBuffersOut,
DWORD dwFlags, DWORD dwContext) DWORD dwFlags, DWORD dwContext)
{ {
LPINTERNET_BUFFERSA ptr; INTERNET_BUFFERSW BuffersInW;
LPINTERNET_BUFFERSW lpBuffersInW,ptrW;
BOOL rc = FALSE; BOOL rc = FALSE;
DWORD headerlen;
TRACE("(%p, %p, %p, %08lx, %08lx): stub\n", hRequest, lpBuffersIn, TRACE("(%p, %p, %p, %08lx, %08lx): stub\n", hRequest, lpBuffersIn,
lpBuffersOut, dwFlags, dwContext); lpBuffersOut, dwFlags, dwContext);
ptr = lpBuffersIn; if (lpBuffersIn)
if (ptr)
lpBuffersInW = (LPINTERNET_BUFFERSW)HeapAlloc(GetProcessHeap(),
HEAP_ZERO_MEMORY, sizeof(INTERNET_BUFFERSW));
else
lpBuffersInW = NULL;
ptrW = lpBuffersInW;
while (ptr)
{ {
DWORD headerlen; BuffersInW.dwStructSize = sizeof(LPINTERNET_BUFFERSW);
ptrW->dwStructSize = sizeof(LPINTERNET_BUFFERSW); if (lpBuffersIn->lpcszHeader)
if (ptr->lpcszHeader)
{ {
headerlen = MultiByteToWideChar(CP_ACP,0,ptr->lpcszHeader, headerlen = MultiByteToWideChar(CP_ACP,0,lpBuffersIn->lpcszHeader,
ptr->dwHeadersLength,0,0); lpBuffersIn->dwHeadersLength,0,0);
headerlen++; BuffersInW.lpcszHeader = HeapAlloc(GetProcessHeap(),0,headerlen*
ptrW->lpcszHeader = HeapAlloc(GetProcessHeap(),0,headerlen*
sizeof(WCHAR)); sizeof(WCHAR));
ptrW->dwHeadersLength = MultiByteToWideChar(CP_ACP, 0, if (!BuffersInW.lpcszHeader)
ptr->lpcszHeader, ptr->dwHeadersLength,
(LPWSTR)ptrW->lpcszHeader, headerlen);
}
ptrW->dwHeadersTotal = ptr->dwHeadersTotal;
ptrW->lpvBuffer = ptr->lpvBuffer;
ptrW->dwBufferLength = ptr->dwBufferLength;
ptrW->dwBufferTotal= ptr->dwBufferTotal;
if (ptr->Next)
ptrW->Next = HeapAlloc(GetProcessHeap(),HEAP_ZERO_MEMORY,
sizeof(INTERNET_BUFFERSW));
ptr = ptr->Next;
ptrW = ptrW->Next;
}
rc = HttpSendRequestExW(hRequest, lpBuffersInW, NULL, dwFlags, dwContext);
if (lpBuffersInW)
{ {
ptrW = lpBuffersInW; SetLastError(ERROR_OUTOFMEMORY);
while (ptrW) return FALSE;
{
LPINTERNET_BUFFERSW ptrW2;
HeapFree(GetProcessHeap(),0,(LPVOID)ptrW->lpcszHeader);
ptrW2 = ptrW->Next;
HeapFree(GetProcessHeap(),0,ptrW);
ptrW = ptrW2;
} }
BuffersInW.dwHeadersLength = MultiByteToWideChar(CP_ACP, 0,
lpBuffersIn->lpcszHeader, lpBuffersIn->dwHeadersLength,
(LPWSTR)BuffersInW.lpcszHeader, headerlen);
} }
BuffersInW.dwHeadersTotal = lpBuffersIn->dwHeadersTotal;
BuffersInW.lpvBuffer = lpBuffersIn->lpvBuffer;
BuffersInW.dwBufferLength = lpBuffersIn->dwBufferLength;
BuffersInW.dwBufferTotal = lpBuffersIn->dwBufferTotal;
BuffersInW.Next = NULL;
}
rc = HttpSendRequestExW(hRequest, lpBuffersIn ? &BuffersInW : NULL, NULL, dwFlags, dwContext);
if (lpBuffersIn)
HeapFree(GetProcessHeap(),0,(LPVOID)BuffersInW.lpcszHeader);
return rc; return rc;
} }
@ -1576,8 +1557,6 @@ BOOL WINAPI HttpSendRequestExW(HINTERNET hRequest,
LPINTERNET_BUFFERSW lpBuffersOut, LPINTERNET_BUFFERSW lpBuffersOut,
DWORD dwFlags, DWORD dwContext) DWORD dwFlags, DWORD dwContext)
{ {
LPINTERNET_BUFFERSW buf_ptr;
DWORD bufferlen = 0;
BOOL rc; BOOL rc;
LPWININETHTTPREQW lpwhr; LPWININETHTTPREQW lpwhr;
LPWSTR requestString = NULL; LPWSTR requestString = NULL;
@ -1599,30 +1578,21 @@ BOOL WINAPI HttpSendRequestExW(HINTERNET hRequest,
HTTP_FixVerb(lpwhr); HTTP_FixVerb(lpwhr);
/* add headers */ /* add headers */
buf_ptr = lpBuffersIn; if (lpBuffersIn->lpcszHeader)
while(buf_ptr)
{ {
if (buf_ptr->lpcszHeader) HTTP_HttpAddRequestHeadersW(lpwhr, lpBuffersIn->lpcszHeader,
{ lpBuffersIn->dwHeadersLength, HTTP_ADDREQ_FLAG_ADD |
HTTP_HttpAddRequestHeadersW(lpwhr, buf_ptr->lpcszHeader,
buf_ptr->dwHeadersLength, HTTP_ADDREQ_FLAG_ADD |
HTTP_ADDHDR_FLAG_REPLACE); HTTP_ADDHDR_FLAG_REPLACE);
} }
bufferlen += buf_ptr->dwBufferTotal;
buf_ptr = buf_ptr->Next;
}
lpwhr->hdr.dwFlags |= dwFlags; if (lpBuffersIn->dwBufferTotal > 0)
lpwhr->hdr.dwContext = dwContext;
if (bufferlen > 0)
{ {
static const WCHAR szContentLength[] = { static const WCHAR szContentLength[] = {
'C','o','n','t','e','n','t','-','L','e','n','g','t','h',':',' ', 'C','o','n','t','e','n','t','-','L','e','n','g','t','h',':',' ',
'%','l','i','\r','\n',0}; '%','l','i','\r','\n',0};
WCHAR contentLengthStr[sizeof szContentLength/2 /* includes \n\r */ + WCHAR contentLengthStr[sizeof szContentLength/2 /* includes \n\r */ +
20 /* int */ ]; 20 /* int */ ];
sprintfW(contentLengthStr, szContentLength, bufferlen); sprintfW(contentLengthStr, szContentLength, lpBuffersIn->dwBufferTotal);
HTTP_HttpAddRequestHeadersW(lpwhr, contentLengthStr, -1L, HTTP_HttpAddRequestHeadersW(lpwhr, contentLengthStr, -1L,
HTTP_ADDREQ_FLAG_ADD); HTTP_ADDREQ_FLAG_ADD);
} }

View File

@ -1083,7 +1083,7 @@ static void HttpSendRequestEx_test(void)
BufferIn.dwStructSize = sizeof( INTERNET_BUFFERS); BufferIn.dwStructSize = sizeof( INTERNET_BUFFERS);
BufferIn.Next = NULL; BufferIn.Next = (LPINTERNET_BUFFERS)0xdeadcab;
BufferIn.lpcszHeader = szContentType; BufferIn.lpcszHeader = szContentType;
BufferIn.dwHeadersLength = sizeof(szContentType); BufferIn.dwHeadersLength = sizeof(szContentType);
BufferIn.dwHeadersTotal = sizeof(szContentType); BufferIn.dwHeadersTotal = sizeof(szContentType);