From ff16f3067716b39b3a7f6112d409f8d006fdb568 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Stefan=20D=C3=B6singer?= Date: Mon, 6 Apr 2009 14:10:29 +0200 Subject: [PATCH] d3d8: Store the fvf in the d3d8 vertex buffer. --- dlls/d3d8/d3d8_private.h | 2 ++ dlls/d3d8/device.c | 1 + dlls/d3d8/vertexbuffer.c | 2 +- 3 files changed, 4 insertions(+), 1 deletion(-) diff --git a/dlls/d3d8/d3d8_private.h b/dlls/d3d8/d3d8_private.h index 1464588e9eb..01a475e4152 100644 --- a/dlls/d3d8/d3d8_private.h +++ b/dlls/d3d8/d3d8_private.h @@ -326,6 +326,8 @@ struct IDirect3DVertexBuffer8Impl /* Parent reference */ LPDIRECT3DDEVICE8 parentDevice; + + DWORD fvf; }; /* --------------------- */ diff --git a/dlls/d3d8/device.c b/dlls/d3d8/device.c index 42c6c819665..352018f90e0 100644 --- a/dlls/d3d8/device.c +++ b/dlls/d3d8/device.c @@ -739,6 +739,7 @@ static HRESULT WINAPI IDirect3DDevice8Impl_CreateVertexBuffer(LPDIRECT3DDEVICE8 EnterCriticalSection(&d3d8_cs); hrc = IWineD3DDevice_CreateVertexBuffer(This->WineD3DDevice, Size, Usage & WINED3DUSAGE_MASK, FVF, (WINED3DPOOL) Pool, &(object->wineD3DVertexBuffer), NULL, (IUnknown *)object); LeaveCriticalSection(&d3d8_cs); + object->fvf = FVF; if (D3D_OK != hrc) { diff --git a/dlls/d3d8/vertexbuffer.c b/dlls/d3d8/vertexbuffer.c index bcbb47f6e2a..569efa2a255 100644 --- a/dlls/d3d8/vertexbuffer.c +++ b/dlls/d3d8/vertexbuffer.c @@ -194,7 +194,7 @@ static HRESULT WINAPI IDirect3DVertexBuffer8Impl_GetDesc(LPDIRECT3DVERTEXBUFFER8 pDesc->Usage = desc.Usage; pDesc->Pool = desc.Pool; pDesc->Size = desc.Size; - pDesc->FVF = desc.FVF; + pDesc->FVF = This->fvf; pDesc->Format = d3dformat_from_wined3dformat(desc.Format); } -- 2.11.4.GIT