[2/5] d3drm: Add IDirect3DRMDevice3 interface

André Hentschel nerv at dawncrow.de
Sun Jan 15 10:01:09 CST 2012


---
 dlls/d3drm/d3drm.c         |   32 ++--
 dlls/d3drm/d3drm_private.h |    2 +-
 dlls/d3drm/device.c        |  535 +++++++++++++++++++++++++++++++++++++++++++-
 3 files changed, 542 insertions(+), 27 deletions(-)

diff --git a/dlls/d3drm/d3drm.c b/dlls/d3drm/d3drm.c
index 959c1cb..5fc32cc 100644
--- a/dlls/d3drm/d3drm.c
+++ b/dlls/d3drm/d3drm.c
@@ -242,7 +242,7 @@ static HRESULT WINAPI IDirect3DRMImpl_CreateDevice(IDirect3DRM* iface, DWORD wid
 
     FIXME("(%p/%p)->(%u,%u,%p): partial stub\n", iface, This, width, height, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromSurface(IDirect3DRM* iface, LPGUID pGUID, LPDIRECTDRAW pDD, LPDIRECTDRAWSURFACE pDDSBack, LPDIRECT3DRMDEVICE * ppDevice)
@@ -252,7 +252,7 @@ static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromSurface(IDirect3DRM* iface
     FIXME("(%p/%p)->(%s,%p,%p,%p): partial stub\n", iface, This, debugstr_guid(pGUID), pDD,
           pDDSBack, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromD3D(IDirect3DRM* iface, LPDIRECT3D pD3D, LPDIRECT3DDEVICE pD3DDev, LPDIRECT3DRMDEVICE * ppDevice)
@@ -261,7 +261,7 @@ static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromD3D(IDirect3DRM* iface, LP
 
     FIXME("(%p/%p)->(%p,%p,%p): partial stub\n", iface, This, pD3D, pD3DDev, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromClipper(IDirect3DRM* iface, LPDIRECTDRAWCLIPPER pDDClipper, LPGUID pGUID, int width, int height, LPDIRECT3DRMDEVICE * ppDevice)
@@ -271,7 +271,7 @@ static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromClipper(IDirect3DRM* iface
     FIXME("(%p/%p)->(%p,%s,%d,%d,%p): partial stub\n", iface, This, pDDClipper,
           debugstr_guid(pGUID), width, height, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRMImpl_CreateTextureFromSurface(IDirect3DRM* iface, LPDIRECTDRAWSURFACE pDDS, LPDIRECT3DRMTEXTURE * ppTexture)
@@ -621,7 +621,7 @@ static HRESULT WINAPI IDirect3DRM2Impl_CreateDevice(IDirect3DRM2* iface, DWORD w
 
     FIXME("(%p/%p)->(%u,%u,%p): partial stub\n", iface, This, width, height, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice2, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromSurface(IDirect3DRM2* iface, LPGUID pGUID,
@@ -634,7 +634,7 @@ static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromSurface(IDirect3DRM2* ifa
     FIXME("(%p/%p)->(%s,%p,%p,%p): partial stub\n", iface, This, debugstr_guid(pGUID),
           pDD, pDDSBack, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice2, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromD3D(IDirect3DRM2* iface, LPDIRECT3D2 pD3D,
@@ -645,7 +645,7 @@ static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromD3D(IDirect3DRM2* iface,
 
     FIXME("(%p/%p)->(%p,%p,%p): partial stub\n", iface, This, pD3D, pD3DDev, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice2, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromClipper(IDirect3DRM2* iface,
@@ -658,7 +658,7 @@ static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromClipper(IDirect3DRM2* ifa
     FIXME("(%p/%p)->(%p,%s,%d,%d,%p): partial stub\n", iface, This, pDDClipper,
           debugstr_guid(pGUID), width, height, ppDevice);
 
-    return Direct3DRMDevice_create((IUnknown**)ppDevice);
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice2, (IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRM2Impl_CreateTextureFromSurface(IDirect3DRM2* iface,
@@ -1049,9 +1049,9 @@ static HRESULT WINAPI IDirect3DRM3Impl_CreateDevice(IDirect3DRM3* iface, DWORD w
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM3(iface);
 
-    FIXME("(%p/%p)->(%d,%d,%p): stub\n", iface, This, width, height, device);
+    FIXME("(%p/%p)->(%d,%d,%p): partial stub\n", iface, This, width, height, device);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice3, (IUnknown**)device);
 }
 
 static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromSurface(IDirect3DRM3* iface, LPGUID pGUID,
@@ -1061,9 +1061,9 @@ static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromSurface(IDirect3DRM3* ifa
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM3(iface);
 
-    FIXME("(%p/%p)->(%s,%p,%p,%p): stub\n", iface, This, debugstr_guid(pGUID), dd, back, device);
+    FIXME("(%p/%p)->(%s,%p,%p,%p): partial stub\n", iface, This, debugstr_guid(pGUID), dd, back, device);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice3, (IUnknown**)device);
 }
 
 static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromD3D(IDirect3DRM3* iface, LPDIRECT3D2 d3d,
@@ -1072,9 +1072,9 @@ static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromD3D(IDirect3DRM3* iface,
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM3(iface);
 
-    FIXME("(%p/%p)->(%p,%p,%p): stub\n", iface, This, d3d, d3ddev, device);
+    FIXME("(%p/%p)->(%p,%p,%p): partial stub\n", iface, This, d3d, d3ddev, device);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice3, (IUnknown**)device);
 }
 
 static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromClipper(IDirect3DRM3* iface,
@@ -1084,10 +1084,10 @@ static HRESULT WINAPI IDirect3DRM3Impl_CreateDeviceFromClipper(IDirect3DRM3* ifa
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM3(iface);
 
-    FIXME("(%p/%p)->(%p,%s,%d,%d,%p): stub\n", iface, This, clipper, debugstr_guid(GUID),
+    FIXME("(%p/%p)->(%p,%s,%d,%d,%p): partial stub\n", iface, This, clipper, debugstr_guid(GUID),
           width, height, device);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create(&IID_IDirect3DRMDevice3, (IUnknown**)device);
 }
 
 static HRESULT WINAPI IDirect3DRM3Impl_CreateShadow(IDirect3DRM3* iface, LPUNKNOWN Visual1,
diff --git a/dlls/d3drm/d3drm_private.h b/dlls/d3drm/d3drm_private.h
index 068200b..443d812 100644
--- a/dlls/d3drm/d3drm_private.h
+++ b/dlls/d3drm/d3drm_private.h
@@ -24,7 +24,7 @@
 #include "d3drm.h"
 
 HRESULT Direct3DRM_create(IUnknown** ppObj) DECLSPEC_HIDDEN;
-HRESULT Direct3DRMDevice_create(IUnknown** ppObj) DECLSPEC_HIDDEN;
+HRESULT Direct3DRMDevice_create(REFIID riid, IUnknown** ppObj) DECLSPEC_HIDDEN;
 HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown** ppObj) DECLSPEC_HIDDEN;
 HRESULT Direct3DRMMeshBuilder_create(REFIID riid, IUnknown** ppObj) DECLSPEC_HIDDEN;
 HRESULT Direct3DRMViewport_create(IUnknown** ppObj) DECLSPEC_HIDDEN;
diff --git a/dlls/d3drm/device.c b/dlls/d3drm/device.c
index 579edef..f02ce33 100644
--- a/dlls/d3drm/device.c
+++ b/dlls/d3drm/device.c
@@ -34,17 +34,24 @@ WINE_DEFAULT_DEBUG_CHANNEL(d3drm);
 
 typedef struct {
     IDirect3DRMDevice2 IDirect3DRMDevice2_iface;
+    IDirect3DRMDevice3 IDirect3DRMDevice3_iface;
     LONG ref;
 } IDirect3DRMDeviceImpl;
 
 static const struct IDirect3DRMDevice2Vtbl Direct3DRMDevice2_Vtbl;
+static const struct IDirect3DRMDevice3Vtbl Direct3DRMDevice3_Vtbl;
 
 static inline IDirect3DRMDeviceImpl *impl_from_IDirect3DRMDevice2(IDirect3DRMDevice2 *iface)
 {
     return CONTAINING_RECORD(iface, IDirect3DRMDeviceImpl, IDirect3DRMDevice2_iface);
 }
 
-HRESULT Direct3DRMDevice_create(IUnknown** ppObj)
+static inline IDirect3DRMDeviceImpl *impl_from_IDirect3DRMDevice3(IDirect3DRMDevice3 *iface)
+{
+    return CONTAINING_RECORD(iface, IDirect3DRMDeviceImpl, IDirect3DRMDevice3_iface);
+}
+
+HRESULT Direct3DRMDevice_create(REFIID riid, IUnknown** ppObj)
 {
     IDirect3DRMDeviceImpl* object;
 
@@ -58,9 +65,13 @@ HRESULT Direct3DRMDevice_create(IUnknown** ppObj)
     }
 
     object->IDirect3DRMDevice2_iface.lpVtbl = &Direct3DRMDevice2_Vtbl;
+    object->IDirect3DRMDevice3_iface.lpVtbl = &Direct3DRMDevice3_Vtbl;
     object->ref = 1;
 
-    *ppObj = (IUnknown*)object;
+    if (IsEqualGUID(riid, &IID_IDirect3DRMFrame3))
+        *ppObj = (IUnknown*)&object->IDirect3DRMDevice3_iface;
+    else
+        *ppObj = (IUnknown*)&object->IDirect3DRMDevice2_iface;
 
     return S_OK;
 }
@@ -73,17 +84,26 @@ static HRESULT WINAPI IDirect3DRMDevice2Impl_QueryInterface(IDirect3DRMDevice2*
 
     TRACE("(%p/%p)->(%s, %p)\n", iface, This, debugstr_guid(riid), object);
 
+    *object = NULL;
+
     if (IsEqualGUID(riid, &IID_IUnknown) ||
         IsEqualGUID(riid, &IID_IDirect3DRMDevice) ||
         IsEqualGUID(riid, &IID_IDirect3DRMDevice2))
     {
-        IClassFactory_AddRef(iface);
-        *object = This;
-        return S_OK;
+        *object = &This->IDirect3DRMDevice2_iface;
+    }
+    else if(IsEqualGUID(riid, &IID_IDirect3DRMDevice3))
+    {
+        *object = &This->IDirect3DRMDevice3_iface;
+    }
+    else
+    {
+        FIXME("interface %s not implemented\n", debugstr_guid(riid));
+        return E_NOINTERFACE;
     }
 
-    ERR("(%p/%p)->(%s, %p),not found\n", iface, This, debugstr_guid(riid), object);
-    return E_NOINTERFACE;
+    IDirect3DRMDevice2_AddRef(iface);
+    return S_OK;
 }
 
 static ULONG WINAPI IDirect3DRMDevice2Impl_AddRef(IDirect3DRMDevice2* iface)
@@ -201,6 +221,7 @@ static HRESULT WINAPI IDirect3DRMDevice2Impl_Init(IDirect3DRMDevice2* iface, ULO
     return E_NOTIMPL;
 }
 
+/*** IDirect3DRMDevice2 methods ***/
 static HRESULT WINAPI IDirect3DRMDevice2Impl_InitFromD3D(IDirect3DRMDevice2* iface,
                                                          LPDIRECT3D lpD3D,
                                                          LPDIRECT3DDEVICE lpD3DDev)
@@ -277,7 +298,7 @@ static HRESULT WINAPI IDirect3DRMDevice2Impl_SetDither(IDirect3DRMDevice2* iface
 
     FIXME("(%p/%p)->(%d): stub\n", iface, This, enable);
 
-    return S_OK;
+    return E_NOTIMPL;
 }
 
 static HRESULT WINAPI IDirect3DRMDevice2Impl_SetShades(IDirect3DRMDevice2* iface, DWORD count)
@@ -296,7 +317,7 @@ static HRESULT WINAPI IDirect3DRMDevice2Impl_SetQuality(IDirect3DRMDevice2* ifac
 
     FIXME("(%p/%p)->(%u): stub\n", iface, This, quality);
 
-    return S_OK;
+    return E_NOTIMPL;
 }
 
 static HRESULT WINAPI IDirect3DRMDevice2Impl_SetTextureQuality(IDirect3DRMDevice2* iface,
@@ -438,7 +459,7 @@ static HRESULT WINAPI IDirect3DRMDevice2Impl_SetRenderMode(IDirect3DRMDevice2* i
 
     FIXME("(%p/%p)->(%u): stub\n", iface, This, dwFlags);
 
-    return S_OK;
+    return E_NOTIMPL;
 }
 
 static DWORD WINAPI IDirect3DRMDevice2Impl_GetRenderMode(IDirect3DRMDevice2* iface)
@@ -506,3 +527,497 @@ static const struct IDirect3DRMDevice2Vtbl Direct3DRMDevice2_Vtbl =
     IDirect3DRMDevice2Impl_GetRenderMode,
     IDirect3DRMDevice2Impl_GetDirect3DDevice2
 };
+
+
+/*** IUnknown methods ***/
+static HRESULT WINAPI IDirect3DRMDevice3Impl_QueryInterface(IDirect3DRMDevice3* iface,
+                                                            REFIID riid, void** object)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+    return IDirect3DRMDevice2_QueryInterface(&This->IDirect3DRMDevice2_iface, riid, object);
+}
+
+static ULONG WINAPI IDirect3DRMDevice3Impl_AddRef(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    TRACE("(%p)\n", This);
+
+    return InterlockedIncrement(&This->ref);
+}
+
+static ULONG WINAPI IDirect3DRMDevice3Impl_Release(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+    ULONG ref = InterlockedDecrement(&This->ref);
+
+    TRACE("(%p)\n", This);
+
+    if (!ref)
+        HeapFree(GetProcessHeap(), 0, This);
+
+    return ref;
+}
+
+/*** IDirect3DRMObject methods ***/
+static HRESULT WINAPI IDirect3DRMDevice3Impl_Clone(IDirect3DRMDevice3* iface,
+                                                        LPUNKNOWN unkwn, REFIID riid,
+                                                        LPVOID* object)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %s, %p): stub\n", iface, This, unkwn, debugstr_guid(riid), object);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_AddDestroyCallback(IDirect3DRMDevice3* iface,
+                                                                     D3DRMOBJECTCALLBACK cb,
+                                                                     LPVOID argument)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, argument);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_DeleteDestroyCallback(IDirect3DRMDevice3* iface,
+                                                                        D3DRMOBJECTCALLBACK cb,
+                                                                        LPVOID argument)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, argument);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetAppData(IDirect3DRMDevice3* iface,
+                                                             DWORD data)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, data);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetAppData(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return 0;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetName(IDirect3DRMDevice3* iface, LPCSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%s): stub\n", iface, This, name);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetName(IDirect3DRMDevice3* iface,
+                                                          LPDWORD size, LPSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, size, name);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetClassName(IDirect3DRMDevice3* iface,
+                                                               LPDWORD size, LPSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, size, name);
+
+    return E_NOTIMPL;
+}
+
+/*** IDirect3DRMDevice methods ***/
+static HRESULT WINAPI IDirect3DRMDevice3Impl_Init(IDirect3DRMDevice3* iface, ULONG width,
+                                                  ULONG height)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u): stub\n", iface, This, width, height);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_InitFromD3D(IDirect3DRMDevice3* iface,
+                                                         LPDIRECT3D lpD3D,
+                                                         LPDIRECT3DDEVICE lpD3DDev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, lpD3D, lpD3DDev);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_InitFromClipper(IDirect3DRMDevice3* iface,
+                                                             LPDIRECTDRAWCLIPPER lpDDClipper,
+                                                             LPGUID lpGUID, int width, int height)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p, %u, %u): stub\n", iface, This, lpDDClipper, lpGUID, width, height);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_Update(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_AddUpdateCallback(IDirect3DRMDevice3* iface,
+                                                               D3DRMUPDATECALLBACK cb, LPVOID arg)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, arg);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_DeleteUpdateCallback(IDirect3DRMDevice3* iface,
+                                                                  D3DRMUPDATECALLBACK cb,
+                                                                  LPVOID arg)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, arg);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetBufferCount(IDirect3DRMDevice3* iface, DWORD count)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, count);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetBufferCount(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetDither(IDirect3DRMDevice3* iface, BOOL enable)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%d): stub\n", iface, This, enable);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetShades(IDirect3DRMDevice3* iface, DWORD count)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, count);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetQuality(IDirect3DRMDevice3* iface,
+                                                        D3DRMRENDERQUALITY quality)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, quality);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetTextureQuality(IDirect3DRMDevice3* iface,
+                                                               D3DRMTEXTUREQUALITY quality)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, quality);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetViewports(IDirect3DRMDevice3* iface,
+                                                          LPDIRECT3DRMVIEWPORTARRAY *return_views)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, return_views);
+
+    return E_NOTIMPL;
+}
+
+static BOOL WINAPI IDirect3DRMDevice3Impl_GetDither(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetShades(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetHeight(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetWidth(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetTrianglesDrawn(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetWireframeOptions(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DRMRENDERQUALITY WINAPI IDirect3DRMDevice3Impl_GetQuality(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DCOLORMODEL WINAPI IDirect3DRMDevice3Impl_GetColorModel(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DRMTEXTUREQUALITY WINAPI IDirect3DRMDevice3Impl_GetTextureQuality(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetDirect3DDevice(IDirect3DRMDevice3* iface,
+                                                               LPDIRECT3DDEVICE * dev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, dev);
+
+    return E_NOTIMPL;
+}
+
+/*** IDirect3DRMDevice2 methods ***/
+static HRESULT WINAPI IDirect3DRMDevice3Impl_InitFromD3D2(IDirect3DRMDevice3* iface,
+                                                          LPDIRECT3D2 lpD3D,
+                                                          LPDIRECT3DDEVICE2 lpD3DDev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, lpD3D, lpD3DDev);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_InitFromSurface(IDirect3DRMDevice3* iface,
+                                                             LPGUID lpGUID, LPDIRECTDRAW lpDD,
+                                                             LPDIRECTDRAWSURFACE lpDDSBack)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p, %p, %p): stub\n", iface, This, lpGUID, lpDD, lpDDSBack);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetRenderMode(IDirect3DRMDevice3* iface, DWORD dwFlags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, dwFlags);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice3Impl_GetRenderMode(IDirect3DRMDevice3* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetDirect3DDevice2(IDirect3DRMDevice3* iface,
+                                                                LPDIRECT3DDEVICE2 * dev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, dev);
+
+    return E_NOTIMPL;
+}
+
+/*** IDirect3DRMDevice3 methods ***/
+static HRESULT WINAPI IDirect3DRMDevice3Impl_FindPreferredTextureFormat(IDirect3DRMDevice3* iface,
+                                                                        DWORD bitdepths,
+                                                                        DWORD flags,
+                                                                        LPDDPIXELFORMAT lpDDPF)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u, %p): stub\n", iface, This, bitdepths, flags, lpDDPF);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_RenderStateChange(IDirect3DRMDevice3* iface,
+                                                               D3DRENDERSTATETYPE type, DWORD val,
+                                                               DWORD flags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u, %u): stub\n", iface, This, type, val, flags);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_LightStateChange(IDirect3DRMDevice3* iface,
+                                                              D3DLIGHTSTATETYPE type, DWORD val,
+                                                              DWORD flags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u, %u): stub\n", iface, This, type, val, flags);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_GetStateChangeOptions(IDirect3DRMDevice3* iface,
+                                                                   DWORD stateclass, DWORD statenum,
+                                                                   LPDWORD flags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u, %p): stub\n", iface, This, stateclass, statenum, flags);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice3Impl_SetStateChangeOptions(IDirect3DRMDevice3* iface,
+                                                                   DWORD stateclass, DWORD statenum,
+                                                                   DWORD flags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice3(iface);
+
+    FIXME("(%p/%p)->(%u, %u, %u): stub\n", iface, This, stateclass, statenum, flags);
+
+    return E_NOTIMPL;
+}
+
+static const struct IDirect3DRMDevice3Vtbl Direct3DRMDevice3_Vtbl =
+{
+    /*** IUnknown methods ***/
+    IDirect3DRMDevice3Impl_QueryInterface,
+    IDirect3DRMDevice3Impl_AddRef,
+    IDirect3DRMDevice3Impl_Release,
+    /*** IDirect3DRMObject methods ***/
+    IDirect3DRMDevice3Impl_Clone,
+    IDirect3DRMDevice3Impl_AddDestroyCallback,
+    IDirect3DRMDevice3Impl_DeleteDestroyCallback,
+    IDirect3DRMDevice3Impl_SetAppData,
+    IDirect3DRMDevice3Impl_GetAppData,
+    IDirect3DRMDevice3Impl_SetName,
+    IDirect3DRMDevice3Impl_GetName,
+    IDirect3DRMDevice3Impl_GetClassName,
+    /*** IDirect3DRMDevice methods ***/
+    IDirect3DRMDevice3Impl_Init,
+    IDirect3DRMDevice3Impl_InitFromD3D,
+    IDirect3DRMDevice3Impl_InitFromClipper,
+    IDirect3DRMDevice3Impl_Update,
+    IDirect3DRMDevice3Impl_AddUpdateCallback,
+    IDirect3DRMDevice3Impl_DeleteUpdateCallback,
+    IDirect3DRMDevice3Impl_SetBufferCount,
+    IDirect3DRMDevice3Impl_GetBufferCount,
+    IDirect3DRMDevice3Impl_SetDither,
+    IDirect3DRMDevice3Impl_SetShades,
+    IDirect3DRMDevice3Impl_SetQuality,
+    IDirect3DRMDevice3Impl_SetTextureQuality,
+    IDirect3DRMDevice3Impl_GetViewports,
+    IDirect3DRMDevice3Impl_GetDither,
+    IDirect3DRMDevice3Impl_GetShades,
+    IDirect3DRMDevice3Impl_GetHeight,
+    IDirect3DRMDevice3Impl_GetWidth,
+    IDirect3DRMDevice3Impl_GetTrianglesDrawn,
+    IDirect3DRMDevice3Impl_GetWireframeOptions,
+    IDirect3DRMDevice3Impl_GetQuality,
+    IDirect3DRMDevice3Impl_GetColorModel,
+    IDirect3DRMDevice3Impl_GetTextureQuality,
+    IDirect3DRMDevice3Impl_GetDirect3DDevice,
+    /*** IDirect3DRMDevice2 methods ***/
+    IDirect3DRMDevice3Impl_InitFromD3D2,
+    IDirect3DRMDevice3Impl_InitFromSurface,
+    IDirect3DRMDevice3Impl_SetRenderMode,
+    IDirect3DRMDevice3Impl_GetRenderMode,
+    IDirect3DRMDevice3Impl_GetDirect3DDevice2,
+    /*** IDirect3DRMDevice3 methods ***/
+    IDirect3DRMDevice3Impl_FindPreferredTextureFormat,
+    IDirect3DRMDevice3Impl_RenderStateChange,
+    IDirect3DRMDevice3Impl_LightStateChange,
+    IDirect3DRMDevice3Impl_GetStateChangeOptions,
+    IDirect3DRMDevice3Impl_SetStateChangeOptions
+};
-- 

Best Regards, André Hentschel
-------------- next part --------------
An embedded and charset-unspecified text was scrubbed...
Name: Nachrichtenteil als Anhang
URL: <http://www.winehq.org/pipermail/wine-patches/attachments/20120115/6519cf3b/attachment-0001.ksh>


More information about the wine-patches mailing list