Stefan Dösinger : wined3d: Move WINED3DRS_PATCHSEGMENTS to the state table.
Alexandre Julliard
julliard at wine.codeweavers.com
Mon Dec 11 10:34:58 CST 2006
Module: wine
Branch: master
Commit: 8197470d67a4a608f4d0a9ef6de15e4e5f3a51da
URL: http://source.winehq.org/git/wine.git/?a=commit;h=8197470d67a4a608f4d0a9ef6de15e4e5f3a51da
Author: Stefan Dösinger <stefan at 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 },
More information about the wine-cvs
mailing list