Module: wine Branch: master Commit: 8197470d67a4a608f4d0a9ef6de15e4e5f3a51da URL: http://source.winehq.org/git/wine.git/?a=commit;h=8197470d67a4a608f4d0a9ef6d...
Author: Stefan Dösinger stefan@codeweavers.com Date: Sun Dec 10 23:21:14 2006 +0100
wined3d: Move WINED3DRS_PATCHSEGMENTS to the state table.
---
dlls/wined3d/device.c | 16 +--------------- dlls/wined3d/state.c | 14 +++++++++++++- 2 files changed, 14 insertions(+), 16 deletions(-)
diff --git a/dlls/wined3d/device.c b/dlls/wined3d/device.c index a52ec26..ed9978d 100644 --- a/dlls/wined3d/device.c +++ b/dlls/wined3d/device.c @@ -3316,12 +3316,6 @@ static HRESULT WINAPI IWineD3DDeviceImpl
IWineD3DDeviceImpl *This = (IWineD3DDeviceImpl *)iface;
- /* Simple way of referring to either a DWORD or a 4 byte float */ - union { - DWORD d; - float f; - } tmpvalue; - TRACE("(%p)->state = %s(%d), value = %d\n", This, debug_d3drenderstate(State), State, Value); This->updateStateBlock->changed.renderState[State] = TRUE; This->updateStateBlock->set.renderState[State] = TRUE; @@ -3432,6 +3426,7 @@ static HRESULT WINAPI IWineD3DDeviceImpl case WINED3DRS_ANTIALIAS : case WINED3DRS_MULTISAMPLEMASK : case WINED3DRS_PATCHEDGESTYLE : + case WINED3DRS_PATCHSEGMENTS : StateTable[STATE_RENDER(State)].apply(STATE_RENDER(State), This->stateBlock); break;
@@ -3442,15 +3437,6 @@ static HRESULT WINAPI IWineD3DDeviceImpl return WINED3DERR_INVALIDCALL; }
- case WINED3DRS_PATCHSEGMENTS : - { - /* available in d3d8 but in d3d9 it was replaced by IDirect3DDevice9::SetNPatchMode */ - tmpvalue.f = 1.0f; - if(tmpvalue.d != Value) - ERR("(%p)->(%s,%d) not yet implemented\n", This, debug_d3drenderstate(State), Value); - break; - } - case WINED3DRS_DEBUGMONITORTOKEN : { /* Only useful for "debug builds". */ diff --git a/dlls/wined3d/state.c b/dlls/wined3d/state.c index 1b1ecf9..71ab64f 100644 --- a/dlls/wined3d/state.c +++ b/dlls/wined3d/state.c @@ -1178,6 +1178,18 @@ static void state_patchededge(DWORD stat ERR("(WINED3DRS_PATCHEDGESTYLE,%d) not yet implemented\n", stateblock->renderState[WINED3DRS_PATCHEDGESTYLE]); }
+static void state_patchsegments(DWORD state, IWineD3DStateBlockImpl *stateblock) { + union { + DWORD d; + float f; + } tmpvalue; + tmpvalue.f = 1.0f; + + TRACE("Stub\n"); + if (stateblock->renderState[WINED3DRS_PATCHSEGMENTS] != tmpvalue.d) + ERR("(WINED3DRS_PATCHSEGMENTS,%d) not yet implemented\n", tmpvalue.d); +} + const struct StateEntry StateTable[] = { /* State name representative, apply function */ @@ -1347,7 +1359,7 @@ const struct StateEntry StateTable[] = { /*161, WINED3DRS_MULTISAMPLEANTIALIAS */ STATE_RENDER(WINED3DRS_MULTISAMPLEANTIALIAS), state_multisampleaa }, { /*162, WINED3DRS_MULTISAMPLEMASK */ STATE_RENDER(WINED3DRS_MULTISAMPLEMASK), state_multisampmask }, { /*163, WINED3DRS_PATCHEDGESTYLE */ STATE_RENDER(WINED3DRS_PATCHEDGESTYLE), state_patchededge }, - { /*164, WINED3DRS_PATCHSEGMENTS */ STATE_RENDER(WINED3DRS_PATCHSEGMENTS), state_unknown }, + { /*164, WINED3DRS_PATCHSEGMENTS */ STATE_RENDER(WINED3DRS_PATCHSEGMENTS), state_patchsegments }, { /*165, WINED3DRS_DEBUGMONITORTOKEN */ STATE_RENDER(WINED3DRS_DEBUGMONITORTOKEN), state_unknown }, { /*166, WINED3DRS_POINTSIZE_MAX */ STATE_RENDER(WINED3DRS_POINTSIZE_MAX), state_psizemax }, { /*167, WINED3DRS_INDEXEDVERTEXBLENDENABLE */ 0, state_nogl },