Make CONST_VTABLE the default in the Wine source.
[wine/dcerpc.git] / dlls / ddraw / clipper.c
blobeac48b3cce6bb141e4c1041d23bc3086e4e83215
1 /* DirectDrawClipper implementation
3 * Copyright 2000 Marcus Meissner
4 * Copyright 2000 TransGaming Technologies Inc.
6 * This library is free software; you can redistribute it and/or
7 * modify it under the terms of the GNU Lesser General Public
8 * License as published by the Free Software Foundation; either
9 * version 2.1 of the License, or (at your option) any later version.
11 * This library is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 * Lesser General Public License for more details.
16 * You should have received a copy of the GNU Lesser General Public
17 * License along with this library; if not, write to the Free Software
18 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21 #include "config.h"
23 #include <stdarg.h>
24 #include <stdlib.h>
25 #include <string.h>
27 #include "windef.h"
28 #include "winbase.h"
29 #include "wingdi.h"
30 #include "ddraw.h"
31 #include "winerror.h"
33 #include "ddraw_private.h"
35 #include "wine/debug.h"
37 WINE_DEFAULT_DEBUG_CHANNEL(ddraw);
39 /******************************************************************************
40 * DirectDrawCreateClipper (DDRAW.@)
43 static const IDirectDrawClipperVtbl DDRAW_Clipper_VTable;
45 HRESULT WINAPI DirectDrawCreateClipper(
46 DWORD dwFlags, LPDIRECTDRAWCLIPPER *lplpDDClipper, LPUNKNOWN pUnkOuter
47 ) {
48 IDirectDrawClipperImpl* This;
49 TRACE("(%08lx,%p,%p)\n", dwFlags, lplpDDClipper, pUnkOuter);
51 if (pUnkOuter != NULL) return CLASS_E_NOAGGREGATION;
53 This = HeapAlloc(GetProcessHeap(), HEAP_ZERO_MEMORY,
54 sizeof(IDirectDrawClipperImpl));
55 if (This == NULL) return E_OUTOFMEMORY;
57 ICOM_INIT_INTERFACE(This, IDirectDrawClipper, DDRAW_Clipper_VTable);
58 This->ref = 1;
59 This->hWnd = 0;
60 This->ddraw_owner = NULL;
62 *lplpDDClipper = ICOM_INTERFACE(This, IDirectDrawClipper);
63 return DD_OK;
66 /* This is the classfactory implementation. */
67 HRESULT DDRAW_CreateDirectDrawClipper(IUnknown* pUnkOuter, REFIID riid,
68 LPVOID* ppObj)
70 HRESULT hr;
71 LPDIRECTDRAWCLIPPER pClip;
73 hr = DirectDrawCreateClipper(0, &pClip, pUnkOuter);
74 if (FAILED(hr)) return hr;
76 hr = IDirectDrawClipper_QueryInterface(pClip, riid, ppObj);
77 IDirectDrawClipper_Release(pClip);
78 return hr;
81 /******************************************************************************
82 * IDirectDrawClipper
84 HRESULT WINAPI Main_DirectDrawClipper_SetHwnd(
85 LPDIRECTDRAWCLIPPER iface, DWORD dwFlags, HWND hWnd
86 ) {
87 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
89 TRACE("(%p)->(0x%08lx,0x%08lx)\n", This, dwFlags, (DWORD)hWnd);
90 if( dwFlags ) {
91 FIXME("dwFlags = 0x%08lx, not supported.\n",dwFlags);
92 return DDERR_INVALIDPARAMS;
95 This->hWnd = hWnd;
96 return DD_OK;
99 static void Main_DirectDrawClipper_Destroy(IDirectDrawClipperImpl* This)
101 if (This->ddraw_owner != NULL)
102 Main_DirectDraw_RemoveClipper(This->ddraw_owner, This);
104 HeapFree(GetProcessHeap(), 0 ,This);
107 void Main_DirectDrawClipper_ForceDestroy(IDirectDrawClipperImpl* This)
109 WARN("deleting clipper %p with refcnt %lu\n", This, This->ref);
110 Main_DirectDrawClipper_Destroy(This);
113 ULONG WINAPI Main_DirectDrawClipper_Release(LPDIRECTDRAWCLIPPER iface) {
114 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
115 ULONG ref = InterlockedDecrement(&This->ref);
117 TRACE("(%p)->() decrementing from %lu.\n", This, ref + 1);
119 if (ref == 0)
121 Main_DirectDrawClipper_Destroy(This);
122 return 0;
124 else return ref;
127 /***********************************************************************
128 * IDirectDrawClipper::GetClipList
130 * Retrieve a copy of the clip list
132 * PARAMS
133 * lpRect Rectangle to be used to clip the clip list or NULL for the
134 * entire clip list
135 * lpClipList structure for the resulting copy of the clip list.
136 If NULL, fills lpdwSize up to the number of bytes necessary to hold
137 the entire clip.
138 * lpdwSize Size of resulting clip list; size of the buffer at lpClipList
139 or, if lpClipList is NULL, receives the required size of the buffer
140 in bytes
141 * RETURNS
142 * Either DD_OK or DDERR_*
144 HRESULT WINAPI Main_DirectDrawClipper_GetClipList(
145 LPDIRECTDRAWCLIPPER iface, LPRECT lpRect, LPRGNDATA lpClipList,
146 LPDWORD lpdwSize)
148 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
150 TRACE("(%p,%p,%p,%p)\n", This, lpRect, lpClipList, lpdwSize);
152 if (This->hWnd)
154 HDC hDC = GetDCEx(This->hWnd, NULL, DCX_WINDOW);
155 if (hDC)
157 HRGN hRgn = CreateRectRgn(0,0,0,0);
158 if (GetRandomRgn(hDC, hRgn, SYSRGN))
160 if (lpRect)
162 HRGN hRgnClip = CreateRectRgn(lpRect->left, lpRect->top,
163 lpRect->right, lpRect->bottom);
164 CombineRgn(hRgn, hRgn, hRgnClip, RGN_AND);
165 DeleteObject(hRgnClip);
167 *lpdwSize = GetRegionData(hRgn, *lpdwSize, lpClipList);
169 DeleteObject(hRgn);
170 ReleaseDC(This->hWnd, hDC);
172 return DD_OK;
174 else
176 static int warned = 0;
177 if (warned++ < 10)
178 FIXME("(%p,%p,%p,%p),stub!\n",This,lpRect,lpClipList,lpdwSize);
179 if (lpdwSize) *lpdwSize=0;
180 return DDERR_NOCLIPLIST;
184 /***********************************************************************
185 * IDirectDrawClipper::SetClipList
187 * Sets or deletes (if lprgn is NULL) the clip list
189 * PARAMS
190 * lprgn Pointer to a LRGNDATA structure or NULL
191 * dwFlags not used, must be 0
192 * RETURNS
193 * Either DD_OK or DDERR_*
195 HRESULT WINAPI Main_DirectDrawClipper_SetClipList(
196 LPDIRECTDRAWCLIPPER iface,LPRGNDATA lprgn,DWORD dwFlag
198 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
199 static int warned = 0;
200 if (warned++ < 10 || lprgn == NULL)
201 FIXME("(%p,%p,%ld),stub!\n",This,lprgn,dwFlag);
202 return DD_OK;
205 HRESULT WINAPI Main_DirectDrawClipper_QueryInterface(
206 LPDIRECTDRAWCLIPPER iface, REFIID riid, LPVOID* ppvObj
208 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
210 if (IsEqualGUID(&IID_IUnknown, riid)
211 || IsEqualGUID(&IID_IDirectDrawClipper, riid))
213 *ppvObj = ICOM_INTERFACE(This, IDirectDrawClipper);
214 InterlockedIncrement(&This->ref);
215 return S_OK;
217 else
219 return E_NOINTERFACE;
223 ULONG WINAPI Main_DirectDrawClipper_AddRef( LPDIRECTDRAWCLIPPER iface )
225 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
226 ULONG ref = InterlockedIncrement(&This->ref);
228 TRACE("(%p)->() incrementing from %lu.\n", This, ref - 1);
230 return ref;
233 HRESULT WINAPI Main_DirectDrawClipper_GetHWnd(
234 LPDIRECTDRAWCLIPPER iface, HWND* hWndPtr
236 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
237 TRACE("(%p)->(%p)\n", This, hWndPtr);
239 *hWndPtr = This->hWnd;
241 return DD_OK;
244 HRESULT WINAPI Main_DirectDrawClipper_Initialize(
245 LPDIRECTDRAWCLIPPER iface, LPDIRECTDRAW lpDD, DWORD dwFlags
247 IDirectDrawImpl* pOwner;
248 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
249 TRACE("(%p)->(%p,0x%08lx)\n", This, lpDD, dwFlags);
251 if (This->ddraw_owner != NULL) return DDERR_ALREADYINITIALIZED;
253 pOwner = ICOM_OBJECT(IDirectDrawImpl, IDirectDraw, lpDD);
254 This->ddraw_owner = pOwner;
255 Main_DirectDraw_AddClipper(pOwner, This);
257 return DD_OK;
260 HRESULT WINAPI Main_DirectDrawClipper_IsClipListChanged(
261 LPDIRECTDRAWCLIPPER iface, BOOL* lpbChanged
263 IDirectDrawClipperImpl *This = (IDirectDrawClipperImpl *)iface;
264 FIXME("(%p)->(%p),stub!\n",This,lpbChanged);
266 /* XXX What is safest? */
267 *lpbChanged = FALSE;
269 return DD_OK;
272 static const IDirectDrawClipperVtbl DDRAW_Clipper_VTable =
274 Main_DirectDrawClipper_QueryInterface,
275 Main_DirectDrawClipper_AddRef,
276 Main_DirectDrawClipper_Release,
277 Main_DirectDrawClipper_GetClipList,
278 Main_DirectDrawClipper_GetHWnd,
279 Main_DirectDrawClipper_Initialize,
280 Main_DirectDrawClipper_IsClipListChanged,
281 Main_DirectDrawClipper_SetClipList,
282 Main_DirectDrawClipper_SetHwnd