[5/10] d3drm: Add IDirect3DRMDevice2 interface (try 2)

André Hentschel nerv at dawncrow.de
Thu Jan 12 17:16:02 CST 2012


---
 dlls/d3drm/Makefile.in     |    1 +
 dlls/d3drm/d3drm.c         |    8 +-
 dlls/d3drm/d3drm_private.h |    1 +
 dlls/d3drm/device.c        |  508 ++++++++++++++++++++++++++++++++++++++++++++
 4 files changed, 514 insertions(+), 4 deletions(-)
 create mode 100644 dlls/d3drm/device.c

diff --git a/dlls/d3drm/Makefile.in b/dlls/d3drm/Makefile.in
index 500ccb5..568a41a 100644
--- a/dlls/d3drm/Makefile.in
+++ b/dlls/d3drm/Makefile.in
@@ -5,6 +5,7 @@ IMPORTS   = dxguid uuid d3dxof
 C_SRCS = \
 	d3drm.c \
 	d3drm_main.c \
+	device.c \
 	frame.c \
 	math.c \
 	meshbuilder.c
diff --git a/dlls/d3drm/d3drm.c b/dlls/d3drm/d3drm.c
index 3ce374d..c6ccb2e 100644
--- a/dlls/d3drm/d3drm.c
+++ b/dlls/d3drm/d3drm.c
@@ -240,9 +240,9 @@ static HRESULT WINAPI IDirect3DRMImpl_CreateDevice(IDirect3DRM* iface, DWORD wid
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM(iface);
 
-    FIXME("(%p/%p)->(%d,%d,%p): stub\n", iface, This, width, height, ppDevice);
+    FIXME("(%p/%p)->(%u,%u,%p): partial stub\n", iface, This, width, height, ppDevice);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create((IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRMImpl_CreateDeviceFromSurface(IDirect3DRM* iface, LPGUID pGUID, LPDIRECTDRAW pDD, LPDIRECTDRAWSURFACE pDDSBack, LPDIRECT3DRMDEVICE * ppDevice)
@@ -616,9 +616,9 @@ static HRESULT WINAPI IDirect3DRM2Impl_CreateDevice(IDirect3DRM2* iface, DWORD w
 {
     IDirect3DRMImpl *This = impl_from_IDirect3DRM2(iface);
 
-    FIXME("(%p/%p)->(%d,%d,%p): stub\n", iface, This, width, height, ppDevice);
+    FIXME("(%p/%p)->(%u,%u,%p): partial stub\n", iface, This, width, height, ppDevice);
 
-    return E_NOTIMPL;
+    return Direct3DRMDevice_create((IUnknown**)ppDevice);
 }
 
 static HRESULT WINAPI IDirect3DRM2Impl_CreateDeviceFromSurface(IDirect3DRM2* iface, LPGUID pGUID,
diff --git a/dlls/d3drm/d3drm_private.h b/dlls/d3drm/d3drm_private.h
index 34a32df..6ff885a 100644
--- a/dlls/d3drm/d3drm_private.h
+++ b/dlls/d3drm/d3drm_private.h
@@ -24,6 +24,7 @@
 #include "d3drm.h"
 
 HRESULT Direct3DRM_create(IUnknown** ppObj) DECLSPEC_HIDDEN;
+HRESULT Direct3DRMDevice_create(IUnknown** ppObj) DECLSPEC_HIDDEN;
 HRESULT Direct3DRMFrame_create(REFIID riid, IUnknown** ppObj) DECLSPEC_HIDDEN;
 HRESULT Direct3DRMMeshBuilder_create(REFIID riid, IUnknown** ppObj) DECLSPEC_HIDDEN;
 
diff --git a/dlls/d3drm/device.c b/dlls/d3drm/device.c
new file mode 100644
index 0000000..579edef
--- /dev/null
+++ b/dlls/d3drm/device.c
@@ -0,0 +1,508 @@
+/*
+ * Implementation of IDirect3DRMDevice Interface
+ *
+ * Copyright 2011, 2012 André Hentschel
+ *
+ * This file contains the (internal) driver registration functions,
+ * driver enumeration APIs and DirectDraw creation functions.
+ *
+ * This library is free software; you can redistribute it and/or
+ * modify it under the terms of the GNU Lesser General Public
+ * License as published by the Free Software Foundation; either
+ * version 2.1 of the License, or (at your option) any later version.
+ *
+ * This library is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
+ * Lesser General Public License for more details.
+ *
+ * You should have received a copy of the GNU Lesser General Public
+ * License along with this library; if not, write to the Free Software
+ * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA
+ */
+
+#include "wine/debug.h"
+
+#define COBJMACROS
+
+#include "winbase.h"
+#include "wingdi.h"
+
+#include "d3drm_private.h"
+
+WINE_DEFAULT_DEBUG_CHANNEL(d3drm);
+
+typedef struct {
+    IDirect3DRMDevice2 IDirect3DRMDevice2_iface;
+    LONG ref;
+} IDirect3DRMDeviceImpl;
+
+static const struct IDirect3DRMDevice2Vtbl Direct3DRMDevice2_Vtbl;
+
+static inline IDirect3DRMDeviceImpl *impl_from_IDirect3DRMDevice2(IDirect3DRMDevice2 *iface)
+{
+    return CONTAINING_RECORD(iface, IDirect3DRMDeviceImpl, IDirect3DRMDevice2_iface);
+}
+
+HRESULT Direct3DRMDevice_create(IUnknown** ppObj)
+{
+    IDirect3DRMDeviceImpl* object;
+
+    TRACE("(%p)\n", ppObj);
+
+    object = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY, sizeof(IDirect3DRMDeviceImpl));
+    if (!object)
+    {
+        ERR("Out of memory\n");
+        return E_OUTOFMEMORY;
+    }
+
+    object->IDirect3DRMDevice2_iface.lpVtbl = &Direct3DRMDevice2_Vtbl;
+    object->ref = 1;
+
+    *ppObj = (IUnknown*)object;
+
+    return S_OK;
+}
+
+/*** IUnknown methods ***/
+static HRESULT WINAPI IDirect3DRMDevice2Impl_QueryInterface(IDirect3DRMDevice2* iface,
+                                                            REFIID riid, void** object)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    TRACE("(%p/%p)->(%s, %p)\n", iface, This, debugstr_guid(riid), object);
+
+    if (IsEqualGUID(riid, &IID_IUnknown) ||
+        IsEqualGUID(riid, &IID_IDirect3DRMDevice) ||
+        IsEqualGUID(riid, &IID_IDirect3DRMDevice2))
+    {
+        IClassFactory_AddRef(iface);
+        *object = This;
+        return S_OK;
+    }
+
+    ERR("(%p/%p)->(%s, %p),not found\n", iface, This, debugstr_guid(riid), object);
+    return E_NOINTERFACE;
+}
+
+static ULONG WINAPI IDirect3DRMDevice2Impl_AddRef(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    TRACE("(%p)\n", This);
+
+    return InterlockedIncrement(&This->ref);
+}
+
+static ULONG WINAPI IDirect3DRMDevice2Impl_Release(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+    ULONG ref = InterlockedDecrement(&This->ref);
+
+    TRACE("(%p)\n", This);
+
+    if (!ref)
+        HeapFree(GetProcessHeap(), 0, This);
+
+    return ref;
+}
+
+/*** IDirect3DRMObject methods ***/
+static HRESULT WINAPI IDirect3DRMDevice2Impl_Clone(IDirect3DRMDevice2* iface,
+                                                        LPUNKNOWN unkwn, REFIID riid,
+                                                        LPVOID* object)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %s, %p): stub\n", iface, This, unkwn, debugstr_guid(riid), object);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_AddDestroyCallback(IDirect3DRMDevice2* iface,
+                                                                     D3DRMOBJECTCALLBACK cb,
+                                                                     LPVOID argument)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, argument);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_DeleteDestroyCallback(IDirect3DRMDevice2* iface,
+                                                                        D3DRMOBJECTCALLBACK cb,
+                                                                        LPVOID argument)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, argument);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetAppData(IDirect3DRMDevice2* iface,
+                                                             DWORD data)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, data);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetAppData(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return 0;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetName(IDirect3DRMDevice2* iface, LPCSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%s): stub\n", iface, This, name);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_GetName(IDirect3DRMDevice2* iface,
+                                                          LPDWORD size, LPSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, size, name);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_GetClassName(IDirect3DRMDevice2* iface,
+                                                               LPDWORD size, LPSTR name)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, size, name);
+
+    return E_NOTIMPL;
+}
+
+/*** IDirect3DRMDevice methods ***/
+static HRESULT WINAPI IDirect3DRMDevice2Impl_Init(IDirect3DRMDevice2* iface, ULONG width,
+                                                  ULONG height)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u, %u): stub\n", iface, This, width, height);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_InitFromD3D(IDirect3DRMDevice2* iface,
+                                                         LPDIRECT3D lpD3D,
+                                                         LPDIRECT3DDEVICE lpD3DDev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, lpD3D, lpD3DDev);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_InitFromClipper(IDirect3DRMDevice2* iface,
+                                                             LPDIRECTDRAWCLIPPER lpDDClipper,
+                                                             LPGUID lpGUID, int width, int height)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p, %u, %u): stub\n", iface, This, lpDDClipper, lpGUID, width, height);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_Update(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_AddUpdateCallback(IDirect3DRMDevice2* iface,
+                                                               D3DRMUPDATECALLBACK cb, LPVOID arg)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, arg);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_DeleteUpdateCallback(IDirect3DRMDevice2* iface,
+                                                                  D3DRMUPDATECALLBACK cb,
+                                                                  LPVOID arg)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, cb, arg);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetBufferCount(IDirect3DRMDevice2* iface, DWORD count)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, count);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetBufferCount(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetDither(IDirect3DRMDevice2* iface, BOOL enable)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%d): stub\n", iface, This, enable);
+
+    return S_OK;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetShades(IDirect3DRMDevice2* iface, DWORD count)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, count);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetQuality(IDirect3DRMDevice2* iface,
+                                                        D3DRMRENDERQUALITY quality)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, quality);
+
+    return S_OK;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetTextureQuality(IDirect3DRMDevice2* iface,
+                                                               D3DRMTEXTUREQUALITY quality)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, quality);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_GetViewports(IDirect3DRMDevice2* iface,
+                                                          LPDIRECT3DRMVIEWPORTARRAY *return_views)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, return_views);
+
+    return E_NOTIMPL;
+}
+
+static BOOL WINAPI IDirect3DRMDevice2Impl_GetDither(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetShades(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetHeight(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetWidth(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetTrianglesDrawn(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetWireframeOptions(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DRMRENDERQUALITY WINAPI IDirect3DRMDevice2Impl_GetQuality(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DCOLORMODEL WINAPI IDirect3DRMDevice2Impl_GetColorModel(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static D3DRMTEXTUREQUALITY WINAPI IDirect3DRMDevice2Impl_GetTextureQuality(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_GetDirect3DDevice(IDirect3DRMDevice2* iface,
+                                                               LPDIRECT3DDEVICE * dev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, dev);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_InitFromD3D2(IDirect3DRMDevice2* iface,
+                                                          LPDIRECT3D2 lpD3D,
+                                                          LPDIRECT3DDEVICE2 lpD3DDev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p): stub\n", iface, This, lpD3D, lpD3DDev);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_InitFromSurface(IDirect3DRMDevice2* iface,
+                                                             LPGUID lpGUID, LPDIRECTDRAW lpDD,
+                                                             LPDIRECTDRAWSURFACE lpDDSBack)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p, %p, %p): stub\n", iface, This, lpGUID, lpDD, lpDDSBack);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_SetRenderMode(IDirect3DRMDevice2* iface, DWORD dwFlags)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%u): stub\n", iface, This, dwFlags);
+
+    return S_OK;
+}
+
+static DWORD WINAPI IDirect3DRMDevice2Impl_GetRenderMode(IDirect3DRMDevice2* iface)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(): stub\n", iface, This);
+
+    return E_NOTIMPL;
+}
+
+static HRESULT WINAPI IDirect3DRMDevice2Impl_GetDirect3DDevice2(IDirect3DRMDevice2* iface,
+                                                                LPDIRECT3DDEVICE2 * dev)
+{
+    IDirect3DRMDeviceImpl *This = impl_from_IDirect3DRMDevice2(iface);
+
+    FIXME("(%p/%p)->(%p): stub\n", iface, This, dev);
+
+    return E_NOTIMPL;
+}
+
+static const struct IDirect3DRMDevice2Vtbl Direct3DRMDevice2_Vtbl =
+{
+    /*** IUnknown methods ***/
+    IDirect3DRMDevice2Impl_QueryInterface,
+    IDirect3DRMDevice2Impl_AddRef,
+    IDirect3DRMDevice2Impl_Release,
+    /*** IDirect3DRMObject methods ***/
+    IDirect3DRMDevice2Impl_Clone,
+    IDirect3DRMDevice2Impl_AddDestroyCallback,
+    IDirect3DRMDevice2Impl_DeleteDestroyCallback,
+    IDirect3DRMDevice2Impl_SetAppData,
+    IDirect3DRMDevice2Impl_GetAppData,
+    IDirect3DRMDevice2Impl_SetName,
+    IDirect3DRMDevice2Impl_GetName,
+    IDirect3DRMDevice2Impl_GetClassName,
+    /*** IDirect3DRMDevice methods ***/
+    IDirect3DRMDevice2Impl_Init,
+    IDirect3DRMDevice2Impl_InitFromD3D,
+    IDirect3DRMDevice2Impl_InitFromClipper,
+    IDirect3DRMDevice2Impl_Update,
+    IDirect3DRMDevice2Impl_AddUpdateCallback,
+    IDirect3DRMDevice2Impl_DeleteUpdateCallback,
+    IDirect3DRMDevice2Impl_SetBufferCount,
+    IDirect3DRMDevice2Impl_GetBufferCount,
+    IDirect3DRMDevice2Impl_SetDither,
+    IDirect3DRMDevice2Impl_SetShades,
+    IDirect3DRMDevice2Impl_SetQuality,
+    IDirect3DRMDevice2Impl_SetTextureQuality,
+    IDirect3DRMDevice2Impl_GetViewports,
+    IDirect3DRMDevice2Impl_GetDither,
+    IDirect3DRMDevice2Impl_GetShades,
+    IDirect3DRMDevice2Impl_GetHeight,
+    IDirect3DRMDevice2Impl_GetWidth,
+    IDirect3DRMDevice2Impl_GetTrianglesDrawn,
+    IDirect3DRMDevice2Impl_GetWireframeOptions,
+    IDirect3DRMDevice2Impl_GetQuality,
+    IDirect3DRMDevice2Impl_GetColorModel,
+    IDirect3DRMDevice2Impl_GetTextureQuality,
+    IDirect3DRMDevice2Impl_GetDirect3DDevice,
+    /*** IDirect3DRMDevice2 methods ***/
+    IDirect3DRMDevice2Impl_InitFromD3D2,
+    IDirect3DRMDevice2Impl_InitFromSurface,
+    IDirect3DRMDevice2Impl_SetRenderMode,
+    IDirect3DRMDevice2Impl_GetRenderMode,
+    IDirect3DRMDevice2Impl_GetDirect3DDevice2
+};
-- 

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/20120113/bcfa736d/attachment.ksh>


More information about the wine-patches mailing list