Release 980726
Sat Jul 25 19:45:45 1998 Juergen Schmied <juergen.schmied@metronet.de>
* [include/shlobj.h][misc/shell.c][misc/shellord.c][ole/folders.c]
[shell32.spec]
Added SHFILEOPSTRUCT32[A|W] and constants, prototypes.
Implemented SHGetSpecialFolderLocation, SHGetPathFromIDList32[A].
Many IShellFolder, pidl, shell -related changes.
SHChangeNotifyRegister, SHChangeNotifyDeregister,
SHShellFolderView_Message, SHMapPIDLToSystemImageListIndex,
SHAddToRecentDocs32, SHFileOperation, SHChangeNotify,
SHCreateShellFolderViewEx stubs.
Sat Jul 25 17:16:25 1998 Huw D M Davies <daviesh@abacus.physics.ox.ac.uk>
* [files/profile.c]
Fix return value of PROFILE_GetSection().
Fri Jul 24 22:45:19 1998 Ove Kaaven <ovek@isflak.arcticnet.no>
* [controls/edit.c]
Killed the modified flag on WM_SETTEXT. Eudora should no longer
bother asking whether you want to save an unchanged message.
Fri Jul 24 21:21:35 1998 Andreas Mohr <100.30936@germany.net>
* [controls/menu.c]
Fixed bug in GetMenuState32.
Doesn't fix Free Agent 32 :((
* [documentation/debugging]
Hints added.
* [files/dos_fs.c] [include/msdos.h] [msdos/int21.c]
Enhanced DOS device support.
* [if1632/Makefile.in] [if1632/builtin.c] [if1632/rasapi16.spec]
[relay32/Makefile.in] [relay32/builtin32.c] [relay32/rasapi32.spec]
Added RASAPI16/32.DLL.
* [misc/aspi.c] [relay32/wnaspi32.spec]
Implemented GetASPI32SupportInfo.
* [multimedia/mmsystem.c]
Implemented mmTaskCreate.
Fri Jul 24 20:55:31 1998 Eric Kohl <ekohl@abo.rhein-zeitung.de>
* [controls/toolbar.c]
Fixed some bugs and added new features.
* [controls/tooltips.c][include/tooltips.h]
Added more messages and started display code.
* [misc/shell.c][misc/shellord.c][relay32/shell.spec]
Fixed StrToOleStrN (SHELL32_79) and added OleStrToStrN (SHELL32_78).
Added some new stubs.
* [objects/cursoricon.c][misc/imagelist.c][include/windows.h]
Fixed GetIconInfo and removed the GetIconInfo hack from the
image list code.
* [controls/pager.c][include/pager.h][controls/treeview.c]
[include/treeview.h]
Added some messages.
* [misc/tweak.c][winows/nonclient.c][documentation/win95look]
Removed unused tweak variables.
* [documentation/common_controls]
Updated.
Fri Jul 24 18:36:32 1998 James Moody <013263m@dragon.acadiau.ca>
* [objects/font.c]
Fixed a bug in GetTextFace.
Fri Jul 24 17:09:33 1998 Marcus Meissner <marcus@jet.franken.de>
* [misc/commdlg.c]
Fixed stacksmashing bug due to invalid specified function
pointers.
* [files/dos_fs.c]
Small change in case handling... be able to create files with
uppercase in them (like Program Files/).
* [graphics/ddraw.c]
XF86DGA support made threadsafe, added more Xlib dependent stuff
(create Window using CreateWindow(), draw into it). xlib support
is not satisfying.
* [scheduler/critsection.c]
Don't recurse on HeapLock with semaphore id 0.
* [win32/user32.c][windows/message.c][windows/event.c]
Moved win32 *Message functions where they belong.
Removed some potential races between XPending and XNextEvent by
a bit more locking.
Fri Jul 24 13:58:19 1998 Alexandre Julliard <julliard@lrc.epfl.ch>
* [loader/pe_image.c] [loader/ne/segment.c]
Use bogus pointer value instead of NULL for unresolved externals.
* [memory/selector.c]
Clear saved_fs on selector free.
* [msdos/cdrom.c] [configure.in]
Added check for linux/ucdrom.h.
* [scheduler/client.c] [server/socket.c]
Fix for missing struct cmsghdr.
Attempt to support msg_accrights fd passing (completely untested).
* [windows/event.c]
Do not grab the pointer in SetCapture (Win32 behavior).
Tue Jul 21 22:28:13 1998 James Juran <jrj120@psu.edu>
* [Make.rules.in]
Changed $(MKDIR) macro to use -p option (make parent directories
if they don't already exist. This fixes an error in 'make install'
if /usr/local/include doesn't already exist.
Tue Jul 21 13:37:04 Rein Klazes <rklazes@casema.net>
* [include/heap.h]
Replaced macro SEGPTR_GET by inline function to avoid *lots*
of wrong use of this macro.
* [relay32/comdlg32.spec]
Corrected GetSaveFileNameW entry.
* [relay32/advapi32.spec] [win32/advapi.c]
[relay32/ole32.spec] [ ole/moniker.c]
Added stubs for SetFileSecurity[AW] and CreateFileMoniker32
* [graphics/x11drv/graphics.c]
Finished implementation of bezier drawing code.
Tue Jul 21 11:00:51 1998 Claus Fischer <cfischer@td2cad.intel.com>
* [files/drive.c]
Remove label trailing blanks in GetVolumeInformation32A.
* [documentation/cdrom-labels]
Added documentation on how to find out a CD-ROM label.
Sun Jul 19 23:16:41 1998 Pascal Cuoq <pcuoq@ens-lyon.fr>
* [include/windows.h]
Added some DM_* and DISP_CHANGE_* flags.
* [relay32/user32.spec] [windows/user.c]
Added stub for ChangeDisplaySettingA.
* [ole/ole2nls.c]
is_punctuation: reuse information from another table.
Sun Jul 19 22:04:46 1998 Douglas Ridgway <ridgway@winehq.com>
* [Make.rules.in]
Updated automatic documentation rules.
* [graphics/path.c] [misc/aspi.c] [misc/ntdll.c] [misc/winsock_dns.c]
[ole/ole2dsp.c] [relay32/user32.spec]
Comment format futzing to keep c2man happy.
* [documentation/README.documentation]
Updated description of automatic documentation.
Wed Jul 15 19:10:09 1998 Andrew M. Bishop <amb@gedanken.demon.co.uk>
* [files/profile.c]
Cache the 10 most recently used .ini files.
Tue May 20 19:20:23 1997 Pablo Saratxaga <srtxg@chanae.alphanet.ch>
* [misc/commdlg.c]
Makes PrintDlg32A() return TRUE even if it is an empty
stub, so most programs are happy and run anyway instead of
aborting at startup.
* [graphics/x11drv/xfont.c]
Increased the maximum font families as (X11) font aliases
eated up a lot of families causing wine to stop reading fonts.
diff --git a/misc/imagelist.c b/misc/imagelist.c
index 0514c0f..4c3125d 100644
--- a/misc/imagelist.c
+++ b/misc/imagelist.c
@@ -30,9 +30,7 @@
* an empty structure. It's just to keep compatibility.
*/
#define __WINE_IMAGELIST_C
-
-/* This must be defined until "GetIconInfo" is not fully implemented. */
-#define __GET_ICON_INFO_HACK__
+
#include "windows.h"
#include "compobj.h"
@@ -41,10 +39,6 @@
#include "commctrl.h"
#include "debug.h"
-#ifdef __GET_ICON_INFO_HACK__
-#include "bitmap.h"
-#endif
-
#define _MAX(a,b) (((a)>(b))?(a):(b))
#define _MIN(a,b) (((a)>(b))?(b):(a))
@@ -112,7 +106,7 @@
if (himl->hbmMask) {
hbmNewBitmap =
- CreateBitmap32 (nNewWidth, himl->cy, 1, himl->uBitsPixel, NULL);
+ CreateBitmap32 (nNewWidth, himl->cy, 1, 1, NULL);
if (hbmNewBitmap == 0)
ERR (imagelist, "creating new mask bitmap!");
@@ -438,7 +432,7 @@
hbmTempImage = CreateBitmap32 (himlSrc->cx, himlSrc->cy, 1,
himlSrc->uBitsPixel, NULL);
hbmTempMask = CreateBitmap32 (himlSrc->cx, himlSrc->cy, 1,
- himlSrc->uBitsPixel, NULL);
+ 1, NULL);
/* copy (and stretch) destination to temporary bitmaps.(save) */
/* image */
@@ -546,6 +540,8 @@
{0x5555, 0xAAAA, 0x5555, 0xAAAA, 0x5555, 0xAAAA, 0x5555, 0xAAAA,
0x5555, 0xAAAA, 0x5555, 0xAAAA, 0x5555, 0xAAAA, 0x5555, 0xAAAA};
+ TRACE (imagelist, "(%d %d 0x%x %d %d)\n", cx, cy, flags, cInitial, cGrow);
+
himl = (HIMAGELIST)LocalAlloc32 (LMEM_FIXED | LMEM_ZEROINIT,
sizeof(struct _IMAGELIST));
if (!himl)
@@ -579,7 +575,7 @@
if (himl->flags & ILC_MASK) {
himl->hbmMask = CreateBitmap32 (himl->cx * himl->cMaxImage, himl->cy,
- 1, himl->uBitsPixel, NULL);
+ 1, 1, NULL);
if (himl->hbmMask == 0) {
ERR(imagelist, "Error creating mask bitmap!\n");
if (himl->hbmImage)
@@ -1242,7 +1238,7 @@
ii.xHotspot = 0;
ii.yHotspot = 0;
ii.hbmMask = CreateBitmap32 (nWidth, nHeight, 1, 1, NULL);
- ii.hbmColor = CreateBitmap32 (nWidth, nHeight, 1, 1, NULL);
+ ii.hbmColor = CreateBitmap32 (nWidth, nHeight, 1, himl->uBitsPixel, NULL);
hdc = CreateCompatibleDC32(0);
@@ -1431,36 +1427,16 @@
ImageList_AddMasked (himl, (HBITMAP32)handle, clrMask);
}
else if ((uType == IMAGE_ICON) || (uType == IMAGE_CURSOR)) {
-#ifdef __GET_ICON_INFO_HACK__
- HBITMAP32 hbmImage;
- HBITMAP32 hbmMask;
- CURSORICONINFO *ptr;
-
- if (!(ptr = (CURSORICONINFO *)GlobalLock16(handle))) return (NULL);
- hbmMask = CreateBitmap32 (ptr->nWidth, ptr->nHeight, 1, 1,
- (char *)(ptr + 1));
- hbmImage = CreateBitmap32 (ptr->nWidth, ptr->nHeight, ptr->bPlanes,
- ptr->bBitsPerPixel,
- (char *)(ptr + 1) + ptr->nHeight *
- BITMAP_WIDTH_BYTES(ptr->nWidth, 1));
- GlobalUnlock16 (handle);
- himl = ImageList_Create (ptr->nWidth, ptr->nHeight,
- ILC_MASK | ILC_COLOR, 1, cGrow);
- ImageList_Add (himl, hbmImage, hbmMask);
- DeleteObject32 (hbmImage);
- DeleteObject32 (hbmMask);
-#else
- ICONINFO32 ii;
+ ICONINFO ii;
BITMAP32 bmp;
- GetIconInfo (hIcon, &ii);
- GetObject32A (ii->hbmColor, sizeof(BITMAP32), (LPVOID)&bmp);
+ GetIconInfo (handle, &ii);
+ GetObject32A (ii.hbmColor, sizeof(BITMAP32), (LPVOID)&bmp);
himl = ImageList_Create (bmp.bmWidth, bmp.bmHeight,
ILC_MASK | ILC_COLOR, 1, cGrow);
- ImageList_Add (himl, ii->hbmColor, ii->hbmMask);
- DeleteObject32 (ii->hbmColor);
- DeleteObject32 (ii->hbmMask);
-#endif
+ ImageList_Add (himl, ii.hbmColor, ii.hbmMask);
+ DeleteObject32 (ii.hbmColor);
+ DeleteObject32 (ii.hbmMask);
}
DeleteObject32 (handle);
@@ -1515,36 +1491,16 @@
ImageList_AddMasked (himl, (HBITMAP32)handle, clrMask);
}
else if ((uType == IMAGE_ICON) || (uType == IMAGE_CURSOR)) {
-#ifdef __GET_ICON_INFO_HACK__
- HBITMAP32 hbmImage;
- HBITMAP32 hbmMask;
- CURSORICONINFO *ptr;
-
- if (!(ptr = (CURSORICONINFO *)GlobalLock16(handle))) return (NULL);
- hbmMask = CreateBitmap32 (ptr->nWidth, ptr->nHeight, 1, 1,
- (char *)(ptr + 1));
- hbmImage = CreateBitmap32 (ptr->nWidth, ptr->nHeight, ptr->bPlanes,
- ptr->bBitsPerPixel,
- (char *)(ptr + 1) + ptr->nHeight *
- BITMAP_WIDTH_BYTES(ptr->nWidth, 1));
- himl = ImageList_Create (ptr->nWidth, ptr->nHeight,
- ILC_MASK | ILC_COLOR, 1, cGrow);
- ImageList_Add (himl, hbmImage, hbmMask);
- DeleteObject32 (hbmImage);
- DeleteObject32 (hbmMask);
- GlobalUnlock16 (handle);
-#else
- ICONINFO32 ii;
+ ICONINFO ii;
BITMAP32 bmp;
- GetIconInfo (hIcon, &ii);
- GetObject32A (ii->hbmMask, sizeof(BITMAP32), (LPVOID)&bmp);
+ GetIconInfo (handle, &ii);
+ GetObject32A (ii.hbmMask, sizeof(BITMAP32), (LPVOID)&bmp);
himl = ImageList_Create (bmp.bmWidth, bmp.bmHeight,
ILC_MASK | ILC_COLOR, 1, cGrow);
- ImageList_Add (himl, ii->hbmColor, ii->hbmMask);
- DeleteObject32 (ii->hbmColor);
- DeleteObject32 (ii->hbmMask);
-#endif
+ ImageList_Add (himl, ii.hbmColor, ii.hbmMask);
+ DeleteObject32 (ii.hbmColor);
+ DeleteObject32 (ii.hbmMask);
}
DeleteObject32 (handle);
@@ -1747,7 +1703,7 @@
DeleteObject32 (himl->hbmMask);
himl->hbmMask =
CreateBitmap32 (himl->cMaxImage * himl->cx, himl->cy,
- 1, himl->uBitsPixel, NULL);
+ 1, 1, NULL);
}
}
else {
@@ -1766,7 +1722,7 @@
CreateBitmap32 (cxNew, himl->cy, 1, himl->uBitsPixel, NULL);
if (himl->hbmMask)
- hbmNewMask = CreateBitmap32 (cxNew, himl->cy, 1, himl->uBitsPixel, NULL);
+ hbmNewMask = CreateBitmap32 (cxNew, himl->cy, 1, 1, NULL);
else
hbmNewMask = 0; /* Just to keep compiler happy! */
@@ -1907,36 +1863,21 @@
{
HDC32 hdcImageList, hdcImage;
INT32 nIndex;
-#ifdef __GET_ICON_INFO_HACK__
- HBITMAP32 hbmImage;
- HBITMAP32 hbmMask;
- CURSORICONINFO *ptr;
-#else
- ICONINFO32 ii;
+ HBITMAP32 hbmOldSrc, hbmOldDst;
+ ICONINFO ii;
BITMAP32 bmp;
-#endif
- TRACE (imagelist, "(0x%x 0x%x 0x%x)\n", himl, i, hIcon);
+ TRACE (imagelist, "(0x%lx 0x%x 0x%x)\n", (DWORD)himl, i, hIcon);
if (himl == NULL) return (-1);
if ((i >= himl->cCurImage) || (i < -1)) return (-1);
-#ifdef __GET_ICON_INFO_HACK__
- if (!(ptr = (CURSORICONINFO *)GlobalLock16(hIcon))) return (-1);
- hbmMask = CreateBitmap32 (ptr->nWidth, ptr->nHeight, 1, 1,
- (char *)(ptr + 1));
- if (!(hbmMask))
- ERR (imagelist, " no mask!\n");
- hbmImage = CreateBitmap32 (ptr->nWidth, ptr->nHeight, ptr->bPlanes,
- ptr->bBitsPerPixel,
- (char *)(ptr + 1) + ptr->nHeight *
- BITMAP_WIDTH_BYTES(ptr->nWidth, 1));
- if (!(hbmMask))
- ERR (imagelist, " no image!\n");
-#else
GetIconInfo (hIcon, &ii);
- GetObject32A (ii->hbmMask, sizeof(BITMAP32), (LPVOID)&bmp);
-#endif
+ if (ii.hbmMask == 0)
+ ERR (imagelist, "no mask!\n");
+ if (ii.hbmColor == 0)
+ ERR (imagelist, "no color!\n");
+ GetObject32A (ii.hbmMask, sizeof(BITMAP32), (LPVOID)&bmp);
if (i == -1) {
if (himl->cCurImage + 1 >= himl->cMaxImage)
@@ -1949,42 +1890,42 @@
nIndex = i;
hdcImageList = CreateCompatibleDC32 (0);
- hdcImage = CreateCompatibleDC32 (0);
+ TRACE (imagelist, "hdcImageList=0x%x!\n", hdcImageList);
+ if (hdcImageList == 0)
+ ERR (imagelist, "invalid hdcImageList!\n");
-#ifdef __GET_ICON_INFO_HACK__
- SelectObject32 (hdcImageList, himl->hbmImage);
- SelectObject32 (hdcImage, hbmImage);
- StretchBlt32 (hdcImageList, nIndex * himl->cx, 0, himl->cx, himl->cy,
- hdcImage, 0, 0, ptr->nWidth, ptr->nHeight, SRCCOPY);
-#else
- SelectObject32 (hdcImage, ii->hbmColor);
+ hdcImage = CreateCompatibleDC32 (0);
+ TRACE (imagelist, "hdcImage=0x%x!\n", hdcImage);
+ if (hdcImage == 0)
+ ERR (imagelist, "invalid hdcImage!\n");
+
+ hbmOldDst = SelectObject32 (hdcImageList, himl->hbmImage);
+ SetTextColor32( hdcImageList, RGB(0,0,0));
+ SetBkColor32( hdcImageList, RGB(255,255,255));
+ hbmOldSrc = SelectObject32 (hdcImage, ii.hbmColor);
StretchBlt32 (hdcImageList, nIndex * himl->cx, 0, himl->cx, himl->cy,
hdcImage, 0, 0, bmp.bmWidth, bmp.bmHeight, SRCCOPY);
-#endif
if (himl->hbmMask) {
-#ifdef __GET_ICON_INFO_HACK__
SelectObject32 (hdcImageList, himl->hbmMask);
- SelectObject32 (hdcImage, hbmMask);
- StretchBlt32 (hdcImageList, nIndex * himl->cx, 0, himl->cx, himl->cy,
- hdcImage, 0, 0, ptr->nWidth, ptr->nHeight, SRCCOPY);
-#else
- SelectObject32 (hdcImage, ii->hbmMask);
+ SelectObject32 (hdcImage, ii.hbmMask);
StretchBlt32 (hdcImageList, nIndex * himl->cx, 0, himl->cx, himl->cy,
hdcImage, 0, 0, bmp.bmWidth, bmp.bmHeight, SRCCOPY);
-#endif
}
- DeleteDC32 (hdcImageList);
- DeleteDC32 (hdcImage);
-#ifdef __GET_ICON_INFO_HACK__
- DeleteObject32 (hbmImage);
- DeleteObject32 (hbmMask);
- GlobalUnlock16 (hIcon);
-#else
- DeleteObject32 (ii->hbmColor);
- DeleteObject32 (ii->hbmMask);
-#endif
+ SelectObject32 (hdcImage, hbmOldSrc);
+ SelectObject32 (hdcImageList, hbmOldDst);
+
+ if (hdcImageList)
+ DeleteDC32 (hdcImageList);
+ if (hdcImage)
+ DeleteDC32 (hdcImage);
+
+// FIXME (imagelist, "deleting hbmColor!\n");
+ DeleteObject32 (ii.hbmColor);
+// FIXME (imagelist, "deleted hbmColor!\n");
+ DeleteObject32 (ii.hbmMask);
+
return (nIndex);
}
@@ -2084,7 +2025,7 @@
BOOL32 WINAPI
ImageList_SetFilter (HIMAGELIST himl, INT32 i, DWORD dwFilter)
{
- FIXME (imagelist, "(%p 0x%08x 0x%08x):empty stub!\n",
+ FIXME (imagelist, "(%p 0x%x 0x%lx):empty stub!\n",
himl, i, dwFilter);
return FALSE;
@@ -2132,7 +2073,7 @@
DeleteObject32 (himl->hbmMask);
himl->hbmMask =
CreateBitmap32 (himl->cMaxImage * himl->cx, himl->cy,
- 1, himl->uBitsPixel, NULL);
+ 1, 1, NULL);
}
return (TRUE);
@@ -2189,7 +2130,7 @@
if (himl->hbmMask)
{
hbmNewBitmap = CreateBitmap32 (nNewCount * himl->cx, himl->cy,
- 1, himl->uBitsPixel, NULL);
+ 1, 1, NULL);
if (hbmNewBitmap != 0)
{
SelectObject32 (hdcImageList, himl->hbmMask);