HttpSendRequestExA/W doesn't touch lpBuffersIn->Next, so simplify the
code a bit. Modify test case to demonstrate this.
This commit is contained in:
parent
dd3e1dc525
commit
4350357634
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
Loading…
Reference in New Issue