- Use smaller numbers as coordinates for mapping tests to avoid
[wine] / dlls / gdi / tests / bitmap.c
1 /*
2  * Unit test suite for bitmaps
3  *
4  * Copyright 2004 Huw Davies
5  *
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.
10  *
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.
15  *
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
19  */
20
21 #include <stdarg.h>
22 #include <assert.h>
23
24 #include "windef.h"
25 #include "winbase.h"
26 #include "wingdi.h"
27 #include "winuser.h"
28 #include "mmsystem.h"
29
30 #include "wine/test.h"
31
32 static BOOL is_win9x;
33
34 static void test_createdibitmap(void)
35 {
36     HDC hdc, hdcmem;
37     BITMAPINFOHEADER bmih;
38     BITMAP bm;
39     HBITMAP hbm, hbm_colour, hbm_old;
40     INT screen_depth;
41
42     hdc = GetDC(0);
43     screen_depth = GetDeviceCaps(hdc, BITSPIXEL);
44     memset(&bmih, 0, sizeof(bmih));
45     bmih.biSize = sizeof(bmih);
46     bmih.biWidth = 10;
47     bmih.biHeight = 10;
48     bmih.biPlanes = 1;
49     bmih.biBitCount = 32;
50     bmih.biCompression = BI_RGB;
51  
52     /* First create an un-initialised bitmap.  The depth of the bitmap
53        should match that of the hdc and not that supplied in bmih.
54     */
55
56     /* First try 32 bits */
57     hbm = CreateDIBitmap(hdc, &bmih, 0, NULL, NULL, 0);
58     ok(hbm != NULL, "CreateDIBitmap failed\n");
59     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
60
61     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
62     DeleteObject(hbm);
63     
64     /* Then 16 */
65     bmih.biBitCount = 16;
66     hbm = CreateDIBitmap(hdc, &bmih, 0, NULL, NULL, 0);
67     ok(hbm != NULL, "CreateDIBitmap failed\n");
68     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
69
70     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
71     DeleteObject(hbm);
72
73     /* Then 1 */
74     bmih.biBitCount = 1;
75     hbm = CreateDIBitmap(hdc, &bmih, 0, NULL, NULL, 0);
76     ok(hbm != NULL, "CreateDIBitmap failed\n");
77     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
78
79     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
80     DeleteObject(hbm);
81
82     /* Now with a monochrome dc we expect a monochrome bitmap */
83     hdcmem = CreateCompatibleDC(hdc);
84
85     /* First try 32 bits */
86     bmih.biBitCount = 32;
87     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
88     ok(hbm != NULL, "CreateDIBitmap failed\n");
89     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
90
91     ok(bm.bmBitsPixel == 1, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, 1);
92     DeleteObject(hbm);
93     
94     /* Then 16 */
95     bmih.biBitCount = 16;
96     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
97     ok(hbm != NULL, "CreateDIBitmap failed\n");
98     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
99
100     ok(bm.bmBitsPixel == 1, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, 1);
101     DeleteObject(hbm);
102     
103     /* Then 1 */
104     bmih.biBitCount = 1;
105     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
106     ok(hbm != NULL, "CreateDIBitmap failed\n");
107     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
108
109     ok(bm.bmBitsPixel == 1, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, 1);
110     DeleteObject(hbm);
111
112     /* Now select a polychrome bitmap into the dc and we expect
113        screen_depth bitmaps again */
114     hbm_colour = CreateCompatibleBitmap(hdc, 1, 1);
115     hbm_old = SelectObject(hdcmem, hbm_colour);
116
117     /* First try 32 bits */
118     bmih.biBitCount = 32;
119     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
120     ok(hbm != NULL, "CreateDIBitmap failed\n");
121     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
122
123     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
124     DeleteObject(hbm);
125     
126     /* Then 16 */
127     bmih.biBitCount = 16;
128     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
129     ok(hbm != NULL, "CreateDIBitmap failed\n");
130     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
131
132     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
133     DeleteObject(hbm);
134     
135     /* Then 1 */
136     bmih.biBitCount = 1;
137     hbm = CreateDIBitmap(hdcmem, &bmih, 0, NULL, NULL, 0);
138     ok(hbm != NULL, "CreateDIBitmap failed\n");
139     ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
140
141     ok(bm.bmBitsPixel == screen_depth, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, screen_depth);
142     DeleteObject(hbm);
143
144     SelectObject(hdcmem, hbm_old);
145     DeleteObject(hbm_colour);
146     DeleteDC(hdcmem);
147
148     /* If hdc == 0 then we get a 1 bpp bitmap */
149     if (!is_win9x) {
150         bmih.biBitCount = 32;
151         hbm = CreateDIBitmap(0, &bmih, 0, NULL, NULL, 0);
152         ok(hbm != NULL, "CreateDIBitmap failed\n");
153         ok(GetObject(hbm, sizeof(bm), &bm), "GetObject failed\n");
154
155         ok(bm.bmBitsPixel == 1, "CreateDIBitmap created bitmap of incorrect depth %d != %d\n", bm.bmBitsPixel, 1);
156         DeleteObject(hbm);
157     }
158     
159     ReleaseDC(0, hdc);
160 }
161
162 #define test_color_todo(got, exp, txt, todo) \
163     if (todo) todo_wine { ok(got == exp, #txt " failed: got 0x%06x expected 0x%06x\n", (UINT)got, (UINT)exp); } \
164     else ok(got == exp, #txt " failed: got 0x%06x expected 0x%06x\n", (UINT)got, (UINT)exp)
165
166 #define test_color(hdc, color, exp, todo_setp, todo_getp) \
167 { \
168     COLORREF c; \
169     c = SetPixel(hdc, 0, 0, color); \
170     if (!is_win9x) { test_color_todo(c, exp, SetPixel, todo_setp); } \
171     c = GetPixel(hdc, 0, 0); \
172     test_color_todo(c, exp, GetPixel, todo_getp); \
173 }
174
175 static void test_dibsections(void)
176 {
177     HDC hdc, hdcmem, hdcmem2;
178     HBITMAP hdib, oldbm, hdib2, oldbm2;
179     char bmibuf[sizeof(BITMAPINFO) + 256 * sizeof(RGBQUAD)];
180     char bcibuf[sizeof(BITMAPCOREINFO) + 256 * sizeof(RGBTRIPLE)];
181     BITMAPINFO *pbmi = (BITMAPINFO *)bmibuf;
182     BITMAPCOREINFO *pbci = (BITMAPCOREINFO *)bcibuf;
183     HBITMAP hcoredib;
184     char coreBits[256];
185     BYTE *bits;
186     RGBQUAD rgb[256];
187     int ret;
188     char logpalbuf[sizeof(LOGPALETTE) + 256 * sizeof(PALETTEENTRY)];
189     LOGPALETTE *plogpal = (LOGPALETTE*)logpalbuf;
190     WORD *index;
191     DWORD *bits32;
192     HPALETTE hpal, oldpal;
193     COLORREF c0, c1;
194     int i;
195
196     hdc = GetDC(0);
197     memset(pbmi, 0, sizeof(bmibuf));
198     pbmi->bmiHeader.biSize = sizeof(pbmi->bmiHeader);
199     pbmi->bmiHeader.biHeight = 16;
200     pbmi->bmiHeader.biWidth = 16;
201     pbmi->bmiHeader.biBitCount = 1;
202     pbmi->bmiHeader.biPlanes = 1;
203     pbmi->bmiHeader.biCompression = BI_RGB;
204     pbmi->bmiColors[0].rgbRed = 0xff;
205     pbmi->bmiColors[0].rgbGreen = 0;
206     pbmi->bmiColors[0].rgbBlue = 0;
207     pbmi->bmiColors[1].rgbRed = 0;
208     pbmi->bmiColors[1].rgbGreen = 0;
209     pbmi->bmiColors[1].rgbBlue = 0xff;
210
211     hdib = CreateDIBSection(hdc, pbmi, DIB_RGB_COLORS, (void**)&bits, NULL, 0);
212     ok(hdib != NULL, "CreateDIBSection failed\n");
213
214     /* Test if the old BITMAPCOREINFO structure is supported */    
215         
216     pbci->bmciHeader.bcSize = sizeof(BITMAPCOREHEADER);
217     pbci->bmciHeader.bcBitCount = 0;
218
219     if (!is_win9x) {
220         ret = GetDIBits(hdc, hdib, 0, 16, NULL, (BITMAPINFO*) pbci, DIB_RGB_COLORS);
221         ok(ret, "GetDIBits doesn't work with a BITMAPCOREHEADER\n");
222         ok((pbci->bmciHeader.bcWidth == 16) && (pbci->bmciHeader.bcHeight == 16)
223             && (pbci->bmciHeader.bcBitCount == 1) && (pbci->bmciHeader.bcPlanes == 1),
224         "GetDIBits did't fill in the BITMAPCOREHEADER structure properly\n");
225
226         ret = GetDIBits(hdc, hdib, 0, 16, &coreBits, (BITMAPINFO*) pbci, DIB_RGB_COLORS);
227         ok(ret, "GetDIBits doesn't work with a BITMAPCOREHEADER\n");
228         ok((pbci->bmciColors[0].rgbtRed == 0xff) && (pbci->bmciColors[0].rgbtGreen == 0) &&
229             (pbci->bmciColors[0].rgbtBlue == 0) && (pbci->bmciColors[1].rgbtRed == 0) &&
230             (pbci->bmciColors[1].rgbtGreen == 0) && (pbci->bmciColors[1].rgbtBlue == 0xff),
231             "The color table has not been translated to the old BITMAPCOREINFO format\n");
232
233         hcoredib = CreateDIBSection(hdc, (BITMAPINFO*) pbci, DIB_RGB_COLORS, (void**)&bits, NULL, 0);
234         ok(hcoredib != NULL, "CreateDIBSection failed with a BITMAPCOREINFO\n");
235
236         ZeroMemory(pbci->bmciColors, 256 * sizeof(RGBTRIPLE));
237         ret = GetDIBits(hdc, hcoredib, 0, 16, &coreBits, (BITMAPINFO*) pbci, DIB_RGB_COLORS);
238         ok(ret, "GetDIBits doesn't work with a BITMAPCOREHEADER\n");
239         ok((pbci->bmciColors[0].rgbtRed == 0xff) && (pbci->bmciColors[0].rgbtGreen == 0) &&
240             (pbci->bmciColors[0].rgbtBlue == 0) && (pbci->bmciColors[1].rgbtRed == 0) &&
241             (pbci->bmciColors[1].rgbtGreen == 0) && (pbci->bmciColors[1].rgbtBlue == 0xff),
242             "The color table has not been translated to the old BITMAPCOREINFO format\n");
243
244         DeleteObject(hcoredib);
245     }
246
247     hdcmem = CreateCompatibleDC(hdc);
248     oldbm = SelectObject(hdcmem, hdib);
249
250     ret = GetDIBColorTable(hdcmem, 0, 2, rgb);
251     ok(ret == 2, "GetDIBColorTable returned %d\n", ret);
252     ok(!memcmp(rgb, pbmi->bmiColors, 2 * sizeof(RGBQUAD)),
253        "GetDIBColorTable returns table 0: r%02x g%02x b%02x res%02x 1: r%02x g%02x b%02x res%02x\n",
254        rgb[0].rgbRed, rgb[0].rgbGreen, rgb[0].rgbBlue, rgb[0].rgbReserved,
255        rgb[1].rgbRed, rgb[1].rgbGreen, rgb[1].rgbBlue, rgb[1].rgbReserved);
256
257     c0 = RGB(pbmi->bmiColors[0].rgbRed, pbmi->bmiColors[0].rgbGreen, pbmi->bmiColors[0].rgbBlue);
258     c1 = RGB(pbmi->bmiColors[1].rgbRed, pbmi->bmiColors[1].rgbGreen, pbmi->bmiColors[1].rgbBlue);
259
260     test_color(hdcmem, DIBINDEX(0), c0, 0, 1);
261     test_color(hdcmem, DIBINDEX(1), c1, 0, 1);
262     test_color(hdcmem, DIBINDEX(2), c0, 1, 1);
263     test_color(hdcmem, PALETTEINDEX(0), c0, 1, 1);
264     test_color(hdcmem, PALETTEINDEX(1), c0, 1, 1);
265     test_color(hdcmem, PALETTEINDEX(2), c0, 1, 1);
266     test_color(hdcmem, PALETTERGB(pbmi->bmiColors[0].rgbRed, pbmi->bmiColors[0].rgbGreen,
267         pbmi->bmiColors[0].rgbBlue), c0, 1, 1);
268     test_color(hdcmem, PALETTERGB(pbmi->bmiColors[1].rgbRed, pbmi->bmiColors[1].rgbGreen,
269         pbmi->bmiColors[1].rgbBlue), c1, 1, 1);
270     test_color(hdcmem, PALETTERGB(0, 0, 0), c0, 1, 1);
271     test_color(hdcmem, PALETTERGB(0xff, 0xff, 0xff), c0, 1, 1);
272     test_color(hdcmem, PALETTERGB(0, 0, 0xfe), c1, 1, 1);
273
274     SelectObject(hdcmem, oldbm);
275     DeleteObject(hdib);
276
277     pbmi->bmiHeader.biBitCount = 8;
278
279     for (i = 0; i < 128; i++) {
280         pbmi->bmiColors[i].rgbRed = 255 - i * 2;
281         pbmi->bmiColors[i].rgbGreen = i * 2;
282         pbmi->bmiColors[i].rgbBlue = 0;
283         pbmi->bmiColors[255 - i].rgbRed = 0;
284         pbmi->bmiColors[255 - i].rgbGreen = i * 2;
285         pbmi->bmiColors[255 - i].rgbBlue = 255 - i * 2;
286     }
287     hdib = CreateDIBSection(hdcmem, pbmi, DIB_RGB_COLORS, (void**)&bits, NULL, 0);
288     ok(hdib != NULL, "CreateDIBSection failed\n");
289     oldbm = SelectObject(hdcmem, hdib);
290
291     for (i = 0; i < 256; i++) {
292         test_color(hdcmem, DIBINDEX(i), 
293             RGB(pbmi->bmiColors[i].rgbRed, pbmi->bmiColors[i].rgbGreen, pbmi->bmiColors[i].rgbBlue), 0, 0);
294         test_color(hdcmem, PALETTERGB(pbmi->bmiColors[i].rgbRed, pbmi->bmiColors[i].rgbGreen, pbmi->bmiColors[i].rgbBlue), 
295             RGB(pbmi->bmiColors[i].rgbRed, pbmi->bmiColors[i].rgbGreen, pbmi->bmiColors[i].rgbBlue), 0, 0);
296     }
297
298     SelectObject(hdcmem, oldbm);
299     DeleteObject(hdib);
300
301     pbmi->bmiHeader.biBitCount = 1;
302
303     /* Now create a palette and a palette indexed dib section */
304     memset(plogpal, 0, sizeof(logpalbuf));
305     plogpal->palVersion = 0x300;
306     plogpal->palNumEntries = 2;
307     plogpal->palPalEntry[0].peRed = 0xff;
308     plogpal->palPalEntry[0].peBlue = 0xff;
309     plogpal->palPalEntry[1].peGreen = 0xff;
310
311     index = (WORD*)pbmi->bmiColors;
312     *index++ = 0;
313     *index = 1;
314     hpal = CreatePalette(plogpal);
315     ok(hpal != NULL, "CreatePalette failed\n");
316     oldpal = SelectPalette(hdc, hpal, TRUE);
317     hdib = CreateDIBSection(hdc, pbmi, DIB_PAL_COLORS, (void**)&bits, NULL, 0);
318     ok(hdib != NULL, "CreateDIBSection failed\n");
319
320     /* The colour table has already been grabbed from the dc, so we select back the
321        old palette */
322
323     SelectPalette(hdc, oldpal, TRUE);
324     oldbm = SelectObject(hdcmem, hdib);
325     oldpal = SelectPalette(hdcmem, hpal, TRUE);
326
327     ret = GetDIBColorTable(hdcmem, 0, 2, rgb);
328     ok(ret == 2, "GetDIBColorTable returned %d\n", ret);
329     ok(rgb[0].rgbRed == 0xff && rgb[0].rgbBlue == 0xff && rgb[0].rgbGreen == 0 &&
330        rgb[1].rgbRed == 0    && rgb[1].rgbBlue == 0    && rgb[1].rgbGreen == 0xff,
331        "GetDIBColorTable returns table 0: r%02x g%02x b%02x res%02x 1: r%02x g%02x b%02x res%02x\n",
332        rgb[0].rgbRed, rgb[0].rgbGreen, rgb[0].rgbBlue, rgb[0].rgbReserved,
333        rgb[1].rgbRed, rgb[1].rgbGreen, rgb[1].rgbBlue, rgb[1].rgbReserved);
334
335     c0 = RGB(plogpal->palPalEntry[0].peRed, plogpal->palPalEntry[0].peGreen, plogpal->palPalEntry[0].peBlue);
336     c1 = RGB(plogpal->palPalEntry[1].peRed, plogpal->palPalEntry[1].peGreen, plogpal->palPalEntry[1].peBlue);
337
338     test_color(hdcmem, DIBINDEX(0), c0, 0, 1);
339     test_color(hdcmem, DIBINDEX(1), c1, 0, 1);
340     test_color(hdcmem, DIBINDEX(2), c0, 1, 1);
341     test_color(hdcmem, PALETTEINDEX(0), c0, 0, 1);
342     test_color(hdcmem, PALETTEINDEX(1), c1, 0, 1);
343     test_color(hdcmem, PALETTEINDEX(2), c0, 1, 1);
344     test_color(hdcmem, PALETTERGB(plogpal->palPalEntry[0].peRed, plogpal->palPalEntry[0].peGreen,
345         plogpal->palPalEntry[0].peBlue), c0, 1, 1);
346     test_color(hdcmem, PALETTERGB(plogpal->palPalEntry[1].peRed, plogpal->palPalEntry[1].peGreen,
347         plogpal->palPalEntry[1].peBlue), c1, 1, 1);
348     test_color(hdcmem, PALETTERGB(0, 0, 0), c1, 1, 1);
349     test_color(hdcmem, PALETTERGB(0xff, 0xff, 0xff), c0, 1, 1);
350     test_color(hdcmem, PALETTERGB(0, 0, 0xfe), c0, 1, 1);
351     test_color(hdcmem, PALETTERGB(0, 1, 0), c1, 1, 1);
352     test_color(hdcmem, PALETTERGB(0x3f, 0, 0x3f), c1, 1, 1);
353     test_color(hdcmem, PALETTERGB(0x40, 0, 0x40), c0, 1, 1);
354
355     /* Bottom and 2nd row from top green, everything else magenta */
356     bits[0] = bits[1] = 0xff;
357     bits[13 * 4] = bits[13*4 + 1] = 0xff;
358
359
360     pbmi->bmiHeader.biBitCount = 32;
361
362     hdib2 = CreateDIBSection(NULL, pbmi, DIB_RGB_COLORS, (void **)&bits32, NULL, 0);
363     ok(hdib2 != NULL, "CreateDIBSection failed\n");
364     hdcmem2 = CreateCompatibleDC(hdc);
365     oldbm2 = SelectObject(hdcmem2, hdib2);
366
367     BitBlt(hdcmem2, 0, 0, 16,16, hdcmem, 0, 0, SRCCOPY);
368
369     ok(bits32[0] == 0xff00, "lower left pixel is %08lx\n", bits32[0]);
370     ok(bits32[17] == 0xff00ff, "bottom but one, left pixel is %08lx\n", bits32[17]);
371
372     SelectObject(hdcmem2, oldbm2);
373     DeleteObject(hdib2);
374
375     SelectObject(hdcmem, oldbm);
376     SelectObject(hdcmem, oldpal);
377     DeleteObject(hdib);
378     DeleteObject(hpal);
379
380
381     pbmi->bmiHeader.biBitCount = 8;
382
383     memset(plogpal, 0, sizeof(logpalbuf));
384     plogpal->palVersion = 0x300;
385     plogpal->palNumEntries = 256;
386
387     for (i = 0; i < 128; i++) {
388         plogpal->palPalEntry[i].peRed = 255 - i * 2;
389         plogpal->palPalEntry[i].peBlue = i * 2;
390         plogpal->palPalEntry[i].peGreen = 0;
391         plogpal->palPalEntry[255 - i].peRed = 0;
392         plogpal->palPalEntry[255 - i].peGreen = i * 2;
393         plogpal->palPalEntry[255 - i].peBlue = 255 - i * 2;
394     }
395
396     index = (WORD*)pbmi->bmiColors;
397     for (i = 0; i < 256; i++) {
398         *index++ = i;
399     }
400
401     hpal = CreatePalette(plogpal);
402     ok(hpal != NULL, "CreatePalette failed\n");
403     oldpal = SelectPalette(hdc, hpal, TRUE);
404     hdib = CreateDIBSection(hdc, pbmi, DIB_PAL_COLORS, (void**)&bits, NULL, 0);
405     ok(hdib != NULL, "CreateDIBSection failed\n");
406
407     SelectPalette(hdc, oldpal, TRUE);
408     oldbm = SelectObject(hdcmem, hdib);
409     oldpal = SelectPalette(hdcmem, hpal, TRUE);
410
411     ret = GetDIBColorTable(hdcmem, 0, 256, rgb);
412     ok(ret == 256, "GetDIBColorTable returned %d\n", ret);
413     for (i = 0; i < 256; i++) {
414         ok(rgb[i].rgbRed == plogpal->palPalEntry[i].peRed && 
415             rgb[i].rgbBlue == plogpal->palPalEntry[i].peBlue && 
416             rgb[i].rgbGreen == plogpal->palPalEntry[i].peGreen, 
417             "GetDIBColorTable returns table %d: r%02x g%02x b%02x res%02x\n",
418             i, rgb[i].rgbRed, rgb[i].rgbGreen, rgb[i].rgbBlue, rgb[i].rgbReserved);
419     }
420
421     for (i = 0; i < 256; i++) {
422         test_color(hdcmem, DIBINDEX(i), 
423             RGB(plogpal->palPalEntry[i].peRed, plogpal->palPalEntry[i].peGreen, plogpal->palPalEntry[i].peBlue), 0, 0);
424         test_color(hdcmem, PALETTEINDEX(i), 
425             RGB(plogpal->palPalEntry[i].peRed, plogpal->palPalEntry[i].peGreen, plogpal->palPalEntry[i].peBlue), 0, 0);
426         test_color(hdcmem, PALETTERGB(plogpal->palPalEntry[i].peRed, plogpal->palPalEntry[i].peGreen, plogpal->palPalEntry[i].peBlue), 
427             RGB(plogpal->palPalEntry[i].peRed, plogpal->palPalEntry[i].peGreen, plogpal->palPalEntry[i].peBlue), 0, 0);
428     }
429
430     SelectPalette(hdcmem, oldpal, TRUE);
431     SelectObject(hdcmem, oldbm);
432     DeleteObject(hdib);
433     DeleteObject(hpal);
434
435
436     DeleteDC(hdcmem);
437     ReleaseDC(0, hdc);
438 }    
439
440 START_TEST(bitmap)
441 {
442     HWND hWnd;
443
444     hWnd = CreateWindowExA(0, "EDIT", NULL, 0,
445                            10, 10, 300, 300,
446                            NULL, NULL, NULL, NULL);
447     assert(hWnd);
448     is_win9x = GetWindowLongW(hWnd, GWL_WNDPROC) == 0;
449     DestroyWindow(hWnd);
450
451     test_createdibitmap();
452     test_dibsections();
453 }