2 /* DirectDraw Base Functions
4 * Copyright 1997-1999 Marcus Meissner
5 * Copyright 1998 Lionel Ulmer (most of Direct3D stuff)
19 #include "wine/exception.h"
22 #include "debugtools.h"
25 DEFAULT_DEBUG_CHANNEL(ddraw
);
27 /******************************************************************************
28 * debug output functions
30 void _dump_DDBLTFX(DWORD flagmask
) {
36 #define FE(x) { x, #x},
37 FE(DDBLTFX_ARITHSTRETCHY
)
38 FE(DDBLTFX_MIRRORLEFTRIGHT
)
39 FE(DDBLTFX_MIRRORUPDOWN
)
44 FE(DDBLTFX_ZBUFFERRANGE
)
45 FE(DDBLTFX_ZBUFFERBASEDEST
)
48 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
49 if (flags
[i
].mask
& flagmask
)
50 DPRINTF("%s ",flags
[i
].name
);
54 void _dump_DDBLTFAST(DWORD flagmask
) {
60 #define FE(x) { x, #x},
61 FE(DDBLTFAST_NOCOLORKEY
)
62 FE(DDBLTFAST_SRCCOLORKEY
)
63 FE(DDBLTFAST_DESTCOLORKEY
)
67 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
68 if (flags
[i
].mask
& flagmask
)
69 DPRINTF("%s ",flags
[i
].name
);
73 void _dump_DDBLT(DWORD flagmask
) {
79 #define FE(x) { x, #x},
81 FE(DDBLT_ALPHADESTCONSTOVERRIDE
)
82 FE(DDBLT_ALPHADESTNEG
)
83 FE(DDBLT_ALPHADESTSURFACEOVERRIDE
)
84 FE(DDBLT_ALPHAEDGEBLEND
)
86 FE(DDBLT_ALPHASRCCONSTOVERRIDE
)
88 FE(DDBLT_ALPHASRCSURFACEOVERRIDE
)
94 FE(DDBLT_KEYDESTOVERRIDE
)
96 FE(DDBLT_KEYSRCOVERRIDE
)
98 FE(DDBLT_ROTATIONANGLE
)
100 FE(DDBLT_ZBUFFERDESTCONSTOVERRIDE
)
101 FE(DDBLT_ZBUFFERDESTOVERRIDE
)
102 FE(DDBLT_ZBUFFERSRCCONSTOVERRIDE
)
103 FE(DDBLT_ZBUFFERSRCOVERRIDE
)
108 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
109 if (flags
[i
].mask
& flagmask
)
110 DPRINTF("%s ",flags
[i
].name
);
114 void _dump_DDSCAPS(void *in
) {
120 #define FE(x) { x, #x},
121 FE(DDSCAPS_RESERVED1
)
123 FE(DDSCAPS_BACKBUFFER
)
126 FE(DDSCAPS_FRONTBUFFER
)
127 FE(DDSCAPS_OFFSCREENPLAIN
)
130 FE(DDSCAPS_PRIMARYSURFACE
)
131 FE(DDSCAPS_PRIMARYSURFACELEFT
)
132 FE(DDSCAPS_SYSTEMMEMORY
)
135 FE(DDSCAPS_VIDEOMEMORY
)
137 FE(DDSCAPS_WRITEONLY
)
140 FE(DDSCAPS_LIVEVIDEO
)
144 FE(DDSCAPS_RESERVED2
)
145 FE(DDSCAPS_ALLOCONLOAD
)
146 FE(DDSCAPS_VIDEOPORT
)
147 FE(DDSCAPS_LOCALVIDMEM
)
148 FE(DDSCAPS_NONLOCALVIDMEM
)
149 FE(DDSCAPS_STANDARDVGAMODE
)
150 FE(DDSCAPS_OPTIMIZED
)
153 DWORD flagmask
= *((DWORD
*) in
);
154 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
155 if (flags
[i
].mask
& flagmask
)
156 DPRINTF("%s ",flags
[i
].name
);
159 void _dump_pixelformat_flag(DWORD flagmask
) {
165 #define FE(x) { x, #x},
169 FE(DDPF_PALETTEINDEXED4
)
170 FE(DDPF_PALETTEINDEXEDTO8
)
171 FE(DDPF_PALETTEINDEXED8
)
177 FE(DDPF_PALETTEINDEXED1
)
178 FE(DDPF_PALETTEINDEXED2
)
182 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
183 if (flags
[i
].mask
& flagmask
)
184 DPRINTF("%s ",flags
[i
].name
);
187 void _dump_paletteformat(DWORD dwFlags
) {
193 #define FE(x) { x, #x},
195 FE(DDPCAPS_8BITENTRIES
)
197 FE(DDPCAPS_INITIALIZE
)
198 FE(DDPCAPS_PRIMARYSURFACE
)
199 FE(DDPCAPS_PRIMARYSURFACELEFT
)
207 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
208 if (flags
[i
].mask
& dwFlags
)
209 DPRINTF("%s ",flags
[i
].name
);
213 void _dump_pixelformat(void *in
) {
214 LPDDPIXELFORMAT pf
= (LPDDPIXELFORMAT
) in
;
217 _dump_pixelformat_flag(pf
->dwFlags
);
218 if (pf
->dwFlags
& DDPF_FOURCC
) {
219 DPRINTF(", dwFourCC : %c%c%c%c",
220 (unsigned char)((pf
->dwFourCC
>>24)&0xff),
221 (unsigned char)((pf
->dwFourCC
>>16)&0xff),
222 (unsigned char)((pf
->dwFourCC
>> 8)&0xff),
223 (unsigned char)( pf
->dwFourCC
&0xff)
226 if (pf
->dwFlags
& DDPF_RGB
) {
228 DPRINTF(", RGB bits: %ld, ", pf
->u
.dwRGBBitCount
);
229 switch (pf
->u
.dwRGBBitCount
) {
230 case 4: cmd
= "%1lx"; break;
231 case 8: cmd
= "%02lx"; break;
232 case 16: cmd
= "%04lx"; break;
233 case 24: cmd
= "%06lx"; break;
234 case 32: cmd
= "%08lx"; break;
235 default: ERR("Unexpected bit depth !\n"); cmd
= "%d"; break;
237 DPRINTF(" R "); DPRINTF(cmd
, pf
->u1
.dwRBitMask
);
238 DPRINTF(" G "); DPRINTF(cmd
, pf
->u2
.dwGBitMask
);
239 DPRINTF(" B "); DPRINTF(cmd
, pf
->u3
.dwBBitMask
);
240 if (pf
->dwFlags
& DDPF_ALPHAPIXELS
) {
241 DPRINTF(" A "); DPRINTF(cmd
, pf
->u4
.dwRGBAlphaBitMask
);
243 if (pf
->dwFlags
& DDPF_ZPIXELS
) {
244 DPRINTF(" Z "); DPRINTF(cmd
, pf
->u4
.dwRGBZBitMask
);
247 if (pf
->dwFlags
& DDPF_ZBUFFER
) {
248 DPRINTF(", Z bits : %ld", pf
->u
.dwZBufferBitDepth
);
250 if (pf
->dwFlags
& DDPF_ALPHA
) {
251 DPRINTF(", Alpha bits : %ld", pf
->u
.dwAlphaBitDepth
);
256 void _dump_colorkeyflag(DWORD ck
) {
262 #define FE(x) { x, #x},
263 FE(DDCKEY_COLORSPACE
)
265 FE(DDCKEY_DESTOVERLAY
)
267 FE(DDCKEY_SRCOVERLAY
)
270 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
271 if (flags
[i
].mask
& ck
)
272 DPRINTF("%s ",flags
[i
].name
);
275 static void _dump_DWORD(void *in
) {
276 DPRINTF("%ld", *((DWORD
*) in
));
278 static void _dump_PTR(void *in
) {
279 DPRINTF("%p", *((void **) in
));
281 void _dump_DDCOLORKEY(void *in
) {
282 DDCOLORKEY
*ddck
= (DDCOLORKEY
*) in
;
284 DPRINTF(" Low : %ld - High : %ld", ddck
->dwColorSpaceLowValue
, ddck
->dwColorSpaceHighValue
);
287 void _dump_surface_desc(DDSURFACEDESC
*lpddsd
) {
292 void (*func
)(void *);
294 } flags
[16], *fe
= flags
;
295 #define FE(x,f,e) do { fe->mask = x; fe->name = #x; fe->func = f; fe->elt = (void *) &(lpddsd->e); fe++; } while(0)
296 FE(DDSD_CAPS
, _dump_DDSCAPS
, ddsCaps
);
297 FE(DDSD_HEIGHT
, _dump_DWORD
, dwHeight
);
298 FE(DDSD_WIDTH
, _dump_DWORD
, dwWidth
);
299 FE(DDSD_PITCH
, _dump_DWORD
, lPitch
);
300 FE(DDSD_BACKBUFFERCOUNT
, _dump_DWORD
, dwBackBufferCount
);
301 FE(DDSD_ZBUFFERBITDEPTH
, _dump_DWORD
, u
.dwZBufferBitDepth
);
302 FE(DDSD_ALPHABITDEPTH
, _dump_DWORD
, dwAlphaBitDepth
);
303 FE(DDSD_PIXELFORMAT
, _dump_pixelformat
, ddpfPixelFormat
);
304 FE(DDSD_CKDESTOVERLAY
, _dump_DDCOLORKEY
, ddckCKDestOverlay
);
305 FE(DDSD_CKDESTBLT
, _dump_DDCOLORKEY
, ddckCKDestBlt
);
306 FE(DDSD_CKSRCOVERLAY
, _dump_DDCOLORKEY
, ddckCKSrcOverlay
);
307 FE(DDSD_CKSRCBLT
, _dump_DDCOLORKEY
, ddckCKSrcBlt
);
308 FE(DDSD_MIPMAPCOUNT
, _dump_DWORD
, u
.dwMipMapCount
);
309 FE(DDSD_REFRESHRATE
, _dump_DWORD
, u
.dwRefreshRate
);
310 FE(DDSD_LINEARSIZE
, _dump_DWORD
, u1
.dwLinearSize
);
311 FE(DDSD_LPSURFACE
, _dump_PTR
, u1
.lpSurface
);
314 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
315 if (flags
[i
].mask
& lpddsd
->dwFlags
) {
316 DPRINTF(" - %s : ",flags
[i
].name
);
317 flags
[i
].func(flags
[i
].elt
);
321 void _dump_cooperativelevel(DWORD cooplevel
) {
327 #define FE(x) { x, #x},
329 FE(DDSCL_ALLOWREBOOT
)
330 FE(DDSCL_NOWINDOWCHANGES
)
334 FE(DDSCL_SETFOCUSWINDOW
)
335 FE(DDSCL_SETDEVICEWINDOW
)
336 FE(DDSCL_CREATEDEVICEWINDOW
)
340 if (TRACE_ON(ddraw
)) {
342 for (i
=0;i
<sizeof(flags
)/sizeof(flags
[0]);i
++)
343 if (flags
[i
].mask
& cooplevel
)
344 DPRINTF("%s ",flags
[i
].name
);