Commit 0aedac34 authored by Huw Davies's avatar Huw Davies Committed by Alexandre Julliard

ole32: Fix CopyTo to work correctly with LARGE_INTEGERs.

parent a555658b
...@@ -467,24 +467,16 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo( ...@@ -467,24 +467,16 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo(
TRACE("(%p, %p, %d, %p, %p)\n", iface, pstm, TRACE("(%p, %p, %d, %p, %p)\n", iface, pstm,
cb.u.LowPart, pcbRead, pcbWritten); cb.u.LowPart, pcbRead, pcbWritten);
/*
* Sanity check
*/
if ( pstm == 0 ) if ( pstm == 0 )
return STG_E_INVALIDPOINTER; return STG_E_INVALIDPOINTER;
totalBytesRead.u.LowPart = totalBytesRead.u.HighPart = 0; totalBytesRead.QuadPart = 0;
totalBytesWritten.u.LowPart = totalBytesWritten.u.HighPart = 0; totalBytesWritten.QuadPart = 0;
/* while ( cb.QuadPart > 0 )
* use stack to store data temporarly
* there is surely more performant way of doing it, for now this basic
* implementation will do the job
*/
while ( cb.u.LowPart > 0 )
{ {
if ( cb.u.LowPart >= 128 ) if ( cb.QuadPart >= sizeof(tmpBuffer) )
copySize = 128; copySize = sizeof(tmpBuffer);
else else
copySize = cb.u.LowPart; copySize = cb.u.LowPart;
...@@ -492,7 +484,7 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo( ...@@ -492,7 +484,7 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo(
if (FAILED(hr)) if (FAILED(hr))
break; break;
totalBytesRead.u.LowPart += bytesRead; totalBytesRead.QuadPart += bytesRead;
if (bytesRead) if (bytesRead)
{ {
...@@ -500,29 +492,18 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo( ...@@ -500,29 +492,18 @@ static HRESULT WINAPI HGLOBALStreamImpl_CopyTo(
if (FAILED(hr)) if (FAILED(hr))
break; break;
totalBytesWritten.u.LowPart += bytesWritten; totalBytesWritten.QuadPart += bytesWritten;
} }
if (bytesRead!=copySize) if (bytesRead!=copySize)
cb.u.LowPart = 0; cb.QuadPart = 0;
else else
cb.u.LowPart -= bytesRead; cb.QuadPart -= bytesRead;
} }
/* if (pcbRead) pcbRead->QuadPart = totalBytesRead.QuadPart;
* Update number of bytes read and written if (pcbWritten) pcbWritten->QuadPart = totalBytesWritten.QuadPart;
*/
if (pcbRead)
{
pcbRead->u.LowPart = totalBytesRead.u.LowPart;
pcbRead->u.HighPart = totalBytesRead.u.HighPart;
}
if (pcbWritten)
{
pcbWritten->u.LowPart = totalBytesWritten.u.LowPart;
pcbWritten->u.HighPart = totalBytesWritten.u.HighPart;
}
return hr; return hr;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment