Commit d82c456e authored by Rob Shearman's avatar Rob Shearman Committed by Alexandre Julliard

urlmon: The persisted version of URL monikers should be size of URL

including nul-terminating character (4-bytes), followed by the URL string including nul-terminating character.
parent d76a15a3
...@@ -410,23 +410,23 @@ static HRESULT WINAPI URLMonikerImpl_Load(IMoniker* iface,IStream* pStm) ...@@ -410,23 +410,23 @@ static HRESULT WINAPI URLMonikerImpl_Load(IMoniker* iface,IStream* pStm)
URLMonikerImpl *This = (URLMonikerImpl *)iface; URLMonikerImpl *This = (URLMonikerImpl *)iface;
HRESULT res; HRESULT res;
ULONG len; ULONG size;
ULONG got; ULONG got;
TRACE("(%p,%p)\n",This,pStm); TRACE("(%p,%p)\n",This,pStm);
if(!pStm) if(!pStm)
return E_INVALIDARG; return E_INVALIDARG;
res = IStream_Read(pStm, &len, sizeof(ULONG), &got); res = IStream_Read(pStm, &size, sizeof(ULONG), &got);
if(SUCCEEDED(res)) { if(SUCCEEDED(res)) {
if(got == sizeof(ULONG)) { if(got == sizeof(ULONG)) {
HeapFree(GetProcessHeap(), 0, This->URLName); HeapFree(GetProcessHeap(), 0, This->URLName);
This->URLName=HeapAlloc(GetProcessHeap(),0,sizeof(WCHAR)*(len+1)); This->URLName=HeapAlloc(GetProcessHeap(),0,size);
if(!This->URLName) if(!This->URLName)
res = E_OUTOFMEMORY; res = E_OUTOFMEMORY;
else { else {
res = IStream_Read(pStm, This->URLName, len, NULL); res = IStream_Read(pStm, This->URLName, size, NULL);
This->URLName[len] = 0; This->URLName[size/sizeof(WCHAR) - 1] = 0;
} }
} }
else else
...@@ -445,16 +445,16 @@ static HRESULT WINAPI URLMonikerImpl_Save(IMoniker* iface, ...@@ -445,16 +445,16 @@ static HRESULT WINAPI URLMonikerImpl_Save(IMoniker* iface,
URLMonikerImpl *This = (URLMonikerImpl *)iface; URLMonikerImpl *This = (URLMonikerImpl *)iface;
HRESULT res; HRESULT res;
ULONG len; ULONG size;
TRACE("(%p,%p,%d)\n",This,pStm,fClearDirty); TRACE("(%p,%p,%d)\n",This,pStm,fClearDirty);
if(!pStm) if(!pStm)
return E_INVALIDARG; return E_INVALIDARG;
len = strlenW(This->URLName); size = (strlenW(This->URLName) + 1)*sizeof(WCHAR);
res=IStream_Write(pStm,&len,sizeof(ULONG),NULL); res=IStream_Write(pStm,&size,sizeof(ULONG),NULL);
if(SUCCEEDED(res)) if(SUCCEEDED(res))
res=IStream_Write(pStm,This->URLName,len*sizeof(WCHAR),NULL); res=IStream_Write(pStm,This->URLName,size,NULL);
return res; return res;
} }
...@@ -472,8 +472,7 @@ static HRESULT WINAPI URLMonikerImpl_GetSizeMax(IMoniker* iface, ...@@ -472,8 +472,7 @@ static HRESULT WINAPI URLMonikerImpl_GetSizeMax(IMoniker* iface,
if(!pcbSize) if(!pcbSize)
return E_INVALIDARG; return E_INVALIDARG;
pcbSize->u.LowPart = sizeof(ULONG) + (strlenW(This->URLName) * sizeof(WCHAR)); pcbSize->QuadPart = sizeof(ULONG) + ((strlenW(This->URLName)+1) * sizeof(WCHAR));
pcbSize->u.HighPart = 0;
return S_OK; return S_OK;
} }
......
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