From 3f5ef480695c1f0123703f4a6697b468fe4494af Mon Sep 17 00:00:00 2001 From: Eric Kohl Date: Fri, 7 May 2010 00:17:04 +0000 Subject: [PATCH 01/12] [USERENV] - Create the environment variables 'ProgramFiles' and 'CommonProgramFiles' from the registry. Fixes bug #4008. See issue #2972 for more details. svn path=/trunk/; revision=47116 --- reactos/dll/win32/userenv/environment.c | 66 ++++++++++++++++++++----- 1 file changed, 55 insertions(+), 11 deletions(-) diff --git a/reactos/dll/win32/userenv/environment.c b/reactos/dll/win32/userenv/environment.c index 16754d46408..5bb38a6dc73 100644 --- a/reactos/dll/win32/userenv/environment.c +++ b/reactos/dll/win32/userenv/environment.c @@ -317,9 +317,13 @@ CreateEnvironmentBlock(LPVOID *lpEnvironment, BOOL bInherit) { WCHAR Buffer[MAX_PATH]; + WCHAR szValue[1024]; DWORD Length; + DWORD dwType; + HKEY hKey; HKEY hKeyUser; NTSTATUS Status; + LONG lError; DPRINT("CreateEnvironmentBlock() called\n"); @@ -349,17 +353,6 @@ CreateEnvironmentBlock(LPVOID *lpEnvironment, FALSE); } - if (hToken == NULL) - return TRUE; - - hKeyUser = GetCurrentUserKey(hToken); - if (hKeyUser == NULL) - { - DPRINT1("GetCurrentUserKey() failed\n"); - RtlDestroyEnvironment(*lpEnvironment); - return FALSE; - } - /* Set 'ALLUSERSPROFILE' variable */ Length = MAX_PATH; if (GetAllUsersProfileDirectoryW(Buffer, @@ -371,6 +364,57 @@ CreateEnvironmentBlock(LPVOID *lpEnvironment, FALSE); } + lError = RegOpenKeyExW(HKEY_LOCAL_MACHINE, + L"SOFTWARE\\Microsoft\\Windows\\CurrentVersion", + 0, + KEY_READ, + &hKey); + if (lError == ERROR_SUCCESS) + { + Length = 1024 * sizeof(WCHAR); + lError = RegQueryValueExW(hKey, + L"ProgramFilesDir", + NULL, + &dwType, + (LPBYTE)szValue, + &Length); + if (lError == ERROR_SUCCESS) + { + SetUserEnvironmentVariable(lpEnvironment, + L"ProgramFiles", + szValue, + FALSE); + } + + Length = 1024 * sizeof(WCHAR); + lError = RegQueryValueExW(hKey, + L"CommonFilesDir", + NULL, + &dwType, + (LPBYTE)szValue, + &Length); + if (lError == ERROR_SUCCESS) + { + SetUserEnvironmentVariable(lpEnvironment, + L"CommonProgramFiles", + szValue, + FALSE); + } + + RegCloseKey(hKey); + } + + if (hToken == NULL) + return TRUE; + + hKeyUser = GetCurrentUserKey(hToken); + if (hKeyUser == NULL) + { + DPRINT1("GetCurrentUserKey() failed\n"); + RtlDestroyEnvironment(*lpEnvironment); + return FALSE; + } + /* Set 'USERPROFILE' variable */ Length = MAX_PATH; if (GetUserProfileDirectoryW(hToken, From 4c417355a6b7a26e2554c99c1ad41c7f1df3d121 Mon Sep 17 00:00:00 2001 From: Timo Kreuzer Date: Sat, 8 May 2010 01:17:46 +0000 Subject: [PATCH 02/12] Disable GDI batch code for regions. "Fixes" broken drawing for AcrobatReader. Yes, it's a "band aid over a bullet wound". I hope the man with the gun is a surgeon, too. svn path=/trunk/; revision=47121 --- reactos/dll/win32/gdi32/objects/region.c | 25 ++++++++++++++++++------ 1 file changed, 19 insertions(+), 6 deletions(-) diff --git a/reactos/dll/win32/gdi32/objects/region.c b/reactos/dll/win32/gdi32/objects/region.c index b8d70772dcf..eb6395363e4 100644 --- a/reactos/dll/win32/gdi32/objects/region.c +++ b/reactos/dll/win32/gdi32/objects/region.c @@ -104,6 +104,7 @@ BOOL FASTCALL DeleteRegion( HRGN hRgn ) { +#if 0 PRGN_ATTR Rgn_Attr; if ((GdiGetHandleUserData((HGDIOBJ) hRgn, GDI_OBJECT_TYPE_REGION, (PVOID) &Rgn_Attr)) && @@ -118,6 +119,7 @@ DeleteRegion( HRGN hRgn ) return TRUE; } } +#endif return NtGdiDeleteObjectApp((HGDIOBJ) hRgn); } @@ -199,6 +201,9 @@ CombineRgn(HRGN hDest, INT Complexity; BOOL Ret; +// HACK +return NtGdiCombineRgn(hDest, hSrc1, hSrc2, CombineMode); + Ret = GdiGetHandleUserData((HGDIOBJ) hDest, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr_Dest); Ret = GdiGetHandleUserData((HGDIOBJ) hSrc1, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr_Src1); @@ -436,6 +441,11 @@ CreateRectRgn(int x1, int y1, int x2, int y2) HRGN hrgn; int tmp; +/// <- +//// Remove when Brush/Pen/Rgn Attr is ready! + return NtGdiCreateRectRgn(x1,y1,x2,y2); +//// + /* Normalize points */ tmp = x1; if ( x1 > x2 ) @@ -586,7 +596,7 @@ ExtSelectClipRgn( IN HDC hdc, IN HRGN hrgn, IN INT iMode) { if (pLDC->iType != LDC_EMFLDC || EMFDRV_ExtSelectClipRgn( hdc, )) return NtGdiExtSelectClipRgn(hdc, ); - } +} else SetLastError(ERROR_INVALID_HANDLE); return ERROR; @@ -734,7 +744,7 @@ GetRgnBox(HRGN hrgn, { PRGN_ATTR Rgn_Attr; - if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &Rgn_Attr)) + //if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &Rgn_Attr)) return NtGdiGetRgnBox(hrgn, prcOut); if (Rgn_Attr->Flags == NULLREGION) @@ -845,7 +855,8 @@ OffsetRgn( HRGN hrgn, PRGN_ATTR pRgn_Attr; int nLeftRect, nTopRect, nRightRect, nBottomRect; - if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) +// HACKFIX +// if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) return NtGdiOffsetRgn(hrgn,nXOffset,nYOffset); if ( pRgn_Attr->Flags == NULLREGION) @@ -898,7 +909,8 @@ PtInRegion(IN HRGN hrgn, { PRGN_ATTR pRgn_Attr; - if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) + // HACKFIX + //if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) return NtGdiPtInRegion(hrgn,x,y); if ( pRgn_Attr->Flags == NULLREGION) @@ -921,7 +933,8 @@ RectInRegion(HRGN hrgn, PRGN_ATTR pRgn_Attr; RECTL rc; - if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) + // HACKFIX + //if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &pRgn_Attr)) return NtGdiRectInRegion(hrgn, (LPRECT) prcl); if ( pRgn_Attr->Flags == NULLREGION) @@ -984,7 +997,7 @@ SetRectRgn(HRGN hrgn, { PRGN_ATTR Rgn_Attr; - if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &Rgn_Attr)) + //if (!GdiGetHandleUserData((HGDIOBJ) hrgn, GDI_OBJECT_TYPE_REGION, (PVOID) &Rgn_Attr)) return NtGdiSetRectRgn(hrgn, nLeftRect, nTopRect, nRightRect, nBottomRect); if ((nLeftRect == nRightRect) || (nTopRect == nBottomRect)) From 3c586a19b2b47bea041c23e5c7889b8cee2efa6b Mon Sep 17 00:00:00 2001 From: Eric Kohl Date: Sat, 8 May 2010 13:07:40 +0000 Subject: [PATCH 03/12] [WINLOGON] Add missing newline to a TRACE message. svn path=/trunk/; revision=47122 --- reactos/base/system/winlogon/winlogon.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/reactos/base/system/winlogon/winlogon.c b/reactos/base/system/winlogon/winlogon.c index 79535666a82..f711cf38085 100644 --- a/reactos/base/system/winlogon/winlogon.c +++ b/reactos/base/system/winlogon/winlogon.c @@ -69,7 +69,7 @@ PlayLogonSoundThread( if (!hService) { CloseServiceHandle(hSCManager); - TRACE("WL: failed to open sysaudio Status %x", GetLastError()); + TRACE("WL: failed to open sysaudio Status %x\n", GetLastError()); ExitThread(0); } From f0d7ecd148fe96565136ec7f2455502f1a2e948a Mon Sep 17 00:00:00 2001 From: Cameron Gutman Date: Sat, 8 May 2010 14:47:42 +0000 Subject: [PATCH 04/12] [PSDK] - Replace WINE's commctrl.h with mingw-w64's commctrl.h - Move WINE-specific hacks to reactos/wine/commctrl.h - Patch by Timo Kreuzer - Fixes bug 4958 svn path=/trunk/; revision=47123 --- .../base/applications/wordpad/wordpad.rbuild | 3 +- reactos/dll/cpl/usrmgr/usrmgr.rbuild | 1 + reactos/dll/win32/comctl32/comctl32.rbuild | 2 + reactos/dll/win32/netcfgx/netcfgx.rbuild | 1 + reactos/dll/win32/netshell/netshell.rbuild | 1 + reactos/dll/win32/user32/user32.rbuild | 1 + reactos/include/psdk/commctrl.h | 9243 ++++++++--------- reactos/include/reactos/wine/commctrl.h | 72 + 8 files changed, 4672 insertions(+), 4652 deletions(-) create mode 100644 reactos/include/reactos/wine/commctrl.h diff --git a/reactos/base/applications/wordpad/wordpad.rbuild b/reactos/base/applications/wordpad/wordpad.rbuild index 6a419cdc4ad..9c21eac69b9 100644 --- a/reactos/base/applications/wordpad/wordpad.rbuild +++ b/reactos/base/applications/wordpad/wordpad.rbuild @@ -2,7 +2,8 @@ . - + include/reactos/wine + comdlg32 shell32 user32 diff --git a/reactos/dll/cpl/usrmgr/usrmgr.rbuild b/reactos/dll/cpl/usrmgr/usrmgr.rbuild index 6b88a4b8103..472bec32e51 100644 --- a/reactos/dll/cpl/usrmgr/usrmgr.rbuild +++ b/reactos/dll/cpl/usrmgr/usrmgr.rbuild @@ -3,6 +3,7 @@ . + include/reactos/wine advapi32 user32 gdi32 diff --git a/reactos/dll/win32/comctl32/comctl32.rbuild b/reactos/dll/win32/comctl32/comctl32.rbuild index 460df46a789..3cc1ce2c0ad 100644 --- a/reactos/dll/win32/comctl32/comctl32.rbuild +++ b/reactos/dll/win32/comctl32/comctl32.rbuild @@ -8,6 +8,8 @@ include/reactos/wine + + 0x600 animate.c comboex.c comctl32undoc.c diff --git a/reactos/dll/win32/netcfgx/netcfgx.rbuild b/reactos/dll/win32/netcfgx/netcfgx.rbuild index f846715255d..1ff2adb7838 100644 --- a/reactos/dll/win32/netcfgx/netcfgx.rbuild +++ b/reactos/dll/win32/netcfgx/netcfgx.rbuild @@ -1,6 +1,7 @@ + 0x0600 ntdll rpcrt4 setupapi diff --git a/reactos/dll/win32/netshell/netshell.rbuild b/reactos/dll/win32/netshell/netshell.rbuild index f76dbdee79c..a5cfbce03a7 100644 --- a/reactos/dll/win32/netshell/netshell.rbuild +++ b/reactos/dll/win32/netshell/netshell.rbuild @@ -3,6 +3,7 @@ . + 0x600 shlwapi shell32 version diff --git a/reactos/dll/win32/user32/user32.rbuild b/reactos/dll/win32/user32/user32.rbuild index e905d747d31..21ee5444b6b 100644 --- a/reactos/dll/win32/user32/user32.rbuild +++ b/reactos/dll/win32/user32/user32.rbuild @@ -3,6 +3,7 @@ . include include/reactos/subsys + include/reactos/wine wine gdi32 advapi32 diff --git a/reactos/include/psdk/commctrl.h b/reactos/include/psdk/commctrl.h index 24b04fdb2e7..9f3366e3474 100644 --- a/reactos/include/psdk/commctrl.h +++ b/reactos/include/psdk/commctrl.h @@ -1,1254 +1,852 @@ -/* - * Common controls definitions - * - * Copyright (C) the Wine project - * - * 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 +/** + * This file has no copyright assigned and is placed in the Public Domain. + * This file is part of the w64 mingw-runtime package. + * No warranty is given; refer to the file DISCLAIMER.PD within this package. */ +#ifndef _INC_COMMCTRL +#define _INC_COMMCTRL -#ifndef __WINE_COMMCTRL_H -#define __WINE_COMMCTRL_H +#ifndef _WINRESRC_ +#ifndef _WIN32_IE +#define _WIN32_IE 0x0501 +#else +/* FIXME: This really must be 0x0501 !!! */ +#if (_WIN32_IE < 0x0500) +#error _WIN32_IE setting conflicts +#endif +#endif +#endif -#include +#ifndef _HRESULT_DEFINED +#define _HRESULT_DEFINED +typedef LONG HRESULT; +#endif + +#ifndef NOUSER +#ifndef WINCOMMCTRLAPI +#ifndef _COMCTL32_ +#define WINCOMMCTRLAPI DECLSPEC_IMPORT +#else +#define WINCOMMCTRLAPI +#endif +#endif #ifdef __cplusplus extern "C" { #endif -BOOL WINAPI ShowHideMenuCtl (HWND, UINT_PTR, LPINT); -VOID WINAPI GetEffectiveClientRect (HWND, LPRECT, const INT*); -VOID WINAPI InitCommonControls (VOID); +#include -typedef struct tagINITCOMMONCONTROLSEX { - DWORD dwSize; - DWORD dwICC; -} INITCOMMONCONTROLSEX, *LPINITCOMMONCONTROLSEX; - -BOOL WINAPI InitCommonControlsEx (const INITCOMMONCONTROLSEX*); - -LANGID WINAPI GetMUILanguage (VOID); -VOID WINAPI InitMUILanguage (LANGID uiLang); - - -#define COMCTL32_VERSION 5 /* dll version */ - -#ifndef _WIN32_IE -#define _WIN32_IE 0x0400 +#ifndef SNDMSG +#ifdef __cplusplus +#define SNDMSG ::SendMessage +#else +#define SNDMSG SendMessage +#endif #endif -#define ICC_LISTVIEW_CLASSES 0x00000001 /* listview, header */ -#define ICC_TREEVIEW_CLASSES 0x00000002 /* treeview, tooltips */ -#define ICC_BAR_CLASSES 0x00000004 /* toolbar, statusbar, trackbar, tooltips */ -#define ICC_TAB_CLASSES 0x00000008 /* tab, tooltips */ -#define ICC_UPDOWN_CLASS 0x00000010 /* updown */ -#define ICC_PROGRESS_CLASS 0x00000020 /* progress */ -#define ICC_HOTKEY_CLASS 0x00000040 /* hotkey */ -#define ICC_ANIMATE_CLASS 0x00000080 /* animate */ -#define ICC_WIN95_CLASSES 0x000000FF -#define ICC_DATE_CLASSES 0x00000100 /* month picker, date picker, time picker, updown */ -#define ICC_USEREX_CLASSES 0x00000200 /* comboex */ -#define ICC_COOL_CLASSES 0x00000400 /* rebar (coolbar) */ -#define ICC_INTERNET_CLASSES 0x00000800 /* IP address, ... */ -#define ICC_PAGESCROLLER_CLASS 0x00001000 /* page scroller */ -#define ICC_NATIVEFNTCTL_CLASS 0x00002000 /* native font control ???*/ -#define ICC_STANDARD_CLASSES 0x00004000 -#define ICC_LINK_CLASS 0x00008000 + WINCOMMCTRLAPI void WINAPI InitCommonControls(void); + typedef struct tagINITCOMMONCONTROLSEX { + DWORD dwSize; + DWORD dwICC; + } INITCOMMONCONTROLSEX,*LPINITCOMMONCONTROLSEX; +#define ICC_LISTVIEW_CLASSES 0x1 +#define ICC_TREEVIEW_CLASSES 0x2 +#define ICC_BAR_CLASSES 0x4 +#define ICC_TAB_CLASSES 0x8 +#define ICC_UPDOWN_CLASS 0x10 +#define ICC_PROGRESS_CLASS 0x20 +#define ICC_HOTKEY_CLASS 0x40 +#define ICC_ANIMATE_CLASS 0x80 +#define ICC_WIN95_CLASSES 0xff +#define ICC_DATE_CLASSES 0x100 +#define ICC_USEREX_CLASSES 0x200 +#define ICC_COOL_CLASSES 0x400 +#define ICC_INTERNET_CLASSES 0x800 +#define ICC_PAGESCROLLER_CLASS 0x1000 +#define ICC_NATIVEFNTCTL_CLASS 0x2000 +#define ICC_STANDARD_CLASSES 0x4000 +#define ICC_LINK_CLASS 0x8000 + WINCOMMCTRLAPI WINBOOL WINAPI InitCommonControlsEx(const INITCOMMONCONTROLSEX *); -/* common control styles */ -#define CCS_TOP 0x00000001L -#define CCS_NOMOVEY 0x00000002L -#define CCS_BOTTOM 0x00000003L -#define CCS_NORESIZE 0x00000004L -#define CCS_NOPARENTALIGN 0x00000008L -#define CCS_ADJUSTABLE 0x00000020L -#define CCS_NODIVIDER 0x00000040L -#define CCS_VERT 0x00000080L -#define CCS_LEFT (CCS_VERT|CCS_TOP) -#define CCS_RIGHT (CCS_VERT|CCS_BOTTOM) -#define CCS_NOMOVEX (CCS_VERT|CCS_NOMOVEY) +#define ODT_HEADER 100 +#define ODT_TAB 101 +#define ODT_LISTVIEW 102 +#define LVM_FIRST 0x1000 +#define TV_FIRST 0x1100 +#define HDM_FIRST 0x1200 +#define TCM_FIRST 0x1300 -/* common control shared messages */ -#define CCM_FIRST 0x2000 +#define PGM_FIRST 0x1400 +#define ECM_FIRST 0x1500 +#define BCM_FIRST 0x1600 +#define CBM_FIRST 0x1700 +#define CCM_FIRST 0x2000 +#define CCM_LAST (CCM_FIRST+0x200) +#define CCM_SETBKCOLOR (CCM_FIRST+1) +#define CCM_SETCOLORSCHEME (CCM_FIRST+2) +#define CCM_GETCOLORSCHEME (CCM_FIRST+3) +#define CCM_GETDROPTARGET (CCM_FIRST+4) +#define CCM_SETUNICODEFORMAT (CCM_FIRST+5) +#define CCM_GETUNICODEFORMAT (CCM_FIRST+6) -#define CCM_SETBKCOLOR (CCM_FIRST+0x1) /* lParam = bkColor */ -#define CCM_SETCOLORSCHEME (CCM_FIRST+0x2) /* lParam = COLORSCHEME struct ptr */ -#define CCM_GETCOLORSCHEME (CCM_FIRST+0x3) /* lParam = COLORSCHEME struct ptr */ -#define CCM_GETDROPTARGET (CCM_FIRST+0x4) -#define CCM_SETUNICODEFORMAT (CCM_FIRST+0x5) -#define CCM_GETUNICODEFORMAT (CCM_FIRST+0x6) -#define CCM_SETVERSION (CCM_FIRST+0x7) -#define CCM_GETVERSION (CCM_FIRST+0x8) -#define CCM_SETNOTIFYWINDOW (CCM_FIRST+0x9) /* wParam = hwndParent */ -#define CCM_SETWINDOWTHEME (CCM_FIRST+0xb) -#define CCM_DPISCALE (CCM_FIRST+0xc) + typedef struct tagCOLORSCHEME { + DWORD dwSize; + COLORREF clrBtnHighlight; + COLORREF clrBtnShadow; + } COLORSCHEME,*LPCOLORSCHEME; +#define COMCTL32_VERSION 6 -/* common notification codes (WM_NOTIFY)*/ -#define NM_FIRST (0U- 0U) -#define NM_LAST (0U- 99U) -#define NM_OUTOFMEMORY (NM_FIRST-1) -#define NM_CLICK (NM_FIRST-2) -#define NM_DBLCLK (NM_FIRST-3) -#define NM_RETURN (NM_FIRST-4) -#define NM_RCLICK (NM_FIRST-5) -#define NM_RDBLCLK (NM_FIRST-6) -#define NM_SETFOCUS (NM_FIRST-7) -#define NM_KILLFOCUS (NM_FIRST-8) -#define NM_CUSTOMDRAW (NM_FIRST-12) -#define NM_HOVER (NM_FIRST-13) -#define NM_NCHITTEST (NM_FIRST-14) -#define NM_KEYDOWN (NM_FIRST-15) -#define NM_RELEASEDCAPTURE (NM_FIRST-16) -#define NM_SETCURSOR (NM_FIRST-17) -#define NM_CHAR (NM_FIRST-18) -#define NM_TOOLTIPSCREATED (NM_FIRST-19) -#define NM_LDOWN (NM_FIRST-20) -#define NM_RDOWN (NM_FIRST-21) -#define NM_THEMECHANGED (NM_FIRST-22) -#define NM_FONTCHANGED (NM_FIRST-23) -#define NM_CUSTOMTEXT (NM_FIRST-24) -#define NM_TVSTATEIMAGECHANGING (NM_FIRST-24) +#define CCM_SETVERSION (CCM_FIRST+0x7) +#define CCM_GETVERSION (CCM_FIRST+0x8) +#define CCM_SETNOTIFYWINDOW (CCM_FIRST+0x9) +#define CCM_SETWINDOWTHEME (CCM_FIRST+0xb) +#define CCM_DPISCALE (CCM_FIRST+0xc) -#define HANDLE_WM_NOTIFY(hwnd, wParam, lParam, fn) \ - (fn)((hwnd), (int)(wParam), (NMHDR*)(lParam)) -#define FORWARD_WM_NOTIFY(hwnd, idFrom, pnmhdr, fn) \ - (LRESULT)(fn)((hwnd), WM_NOTIFY, (WPARAM)(int)(idFrom), (LPARAM)(NMHDR*)(pnmhdr)) +#define INFOTIPSIZE 1024 +#define HANDLE_WM_NOTIFY(hwnd,wParam,lParam,fn) (fn)((hwnd),(int)(wParam),(NMHDR *)(lParam)) +#define FORWARD_WM_NOTIFY(hwnd,idFrom,pnmhdr,fn) (LRESULT)(fn)((hwnd),WM_NOTIFY,(WPARAM)(int)(idFrom),(LPARAM)(NMHDR *)(pnmhdr)) -/* callback constants */ -#define LPSTR_TEXTCALLBACKA ((LPSTR)-1L) -#define LPSTR_TEXTCALLBACKW ((LPWSTR)-1L) -#define LPSTR_TEXTCALLBACK WINELIB_NAME_AW(LPSTR_TEXTCALLBACK) +#define NM_OUTOFMEMORY (NM_FIRST-1) +#define NM_CLICK (NM_FIRST-2) +#define NM_DBLCLK (NM_FIRST-3) +#define NM_RETURN (NM_FIRST-4) +#define NM_RCLICK (NM_FIRST-5) +#define NM_RDBLCLK (NM_FIRST-6) +#define NM_SETFOCUS (NM_FIRST-7) +#define NM_KILLFOCUS (NM_FIRST-8) +#define NM_CUSTOMDRAW (NM_FIRST-12) +#define NM_HOVER (NM_FIRST-13) +#define NM_NCHITTEST (NM_FIRST-14) +#define NM_KEYDOWN (NM_FIRST-15) +#define NM_RELEASEDCAPTURE (NM_FIRST-16) +#define NM_SETCURSOR (NM_FIRST-17) +#define NM_CHAR (NM_FIRST-18) +#define NM_TOOLTIPSCREATED (NM_FIRST-19) +#define NM_LDOWN (NM_FIRST-20) +#define NM_RDOWN (NM_FIRST-21) +#define NM_THEMECHANGED (NM_FIRST-22) -#define I_IMAGECALLBACK (-1) -#define I_IMAGENONE (-2) -#define I_INDENTCALLBACK (-1) -#define I_CHILDRENCALLBACK (-1) -#define I_GROUPIDCALLBACK (-1) -#define I_GROUPIDNONE (-2) -#define I_COLUMNSCALLBACK ((UINT)-1) +#ifndef CCSIZEOF_STRUCT +#define CCSIZEOF_STRUCT(structname,member) (((int)((LPBYTE)(&((structname*)0)->member) - ((LPBYTE)((structname*)0))))+sizeof(((structname*)0)->member)) +#endif -/* owner drawn types */ -#define ODT_HEADER 100 -#define ODT_TAB 101 -#define ODT_LISTVIEW 102 - -/* common notification structures */ -typedef struct tagNMTOOLTIPSCREATED -{ - NMHDR hdr; + typedef struct tagNMTOOLTIPSCREATED { + NMHDR hdr; HWND hwndToolTips; -} NMTOOLTIPSCREATED, *LPNMTOOLTIPSCREATED; + } NMTOOLTIPSCREATED,*LPNMTOOLTIPSCREATED; -typedef struct tagNMMOUSE -{ - NMHDR hdr; - DWORD_PTR dwItemSpec; - DWORD_PTR dwItemData; - POINT pt; - DWORD dwHitInfo; /* info where on item or control the mouse is */ -} NMMOUSE, *LPNMMOUSE; + typedef struct tagNMMOUSE { + NMHDR hdr; + DWORD_PTR dwItemSpec; + DWORD_PTR dwItemData; + POINT pt; + LPARAM dwHitInfo; + } NMMOUSE,*LPNMMOUSE; -typedef struct tagNMOBJECTNOTIFY -{ - NMHDR hdr; - int iItem; + typedef NMMOUSE NMCLICK; + typedef LPNMMOUSE LPNMCLICK; + + typedef struct tagNMOBJECTNOTIFY { + NMHDR hdr; + int iItem; #ifdef __IID_DEFINED__ const IID *piid; #else const void *piid; #endif - void *pObject; + void *pObject; HRESULT hResult; - DWORD dwFlags; -} NMOBJECTNOTIFY, *LPNMOBJECTNOTIFY; + DWORD dwFlags; + } NMOBJECTNOTIFY,*LPNMOBJECTNOTIFY; -typedef struct tagNMKEY -{ - NMHDR hdr; - UINT nVKey; - UINT uFlags; -} NMKEY, *LPNMKEY; + typedef struct tagNMKEY { + NMHDR hdr; + UINT nVKey; + UINT uFlags; + } NMKEY,*LPNMKEY; -typedef struct tagNMCHAR -{ - NMHDR hdr; - UINT ch; - DWORD dwItemPrev; /* Item previously selected */ - DWORD dwItemNext; /* Item to be selected */ -} NMCHAR, *LPNMCHAR; + typedef struct tagNMCHAR { + NMHDR hdr; + UINT ch; + DWORD dwItemPrev; + DWORD dwItemNext; + } NMCHAR,*LPNMCHAR; -#ifndef CCSIZEOF_STRUCT -#define CCSIZEOF_STRUCT(name, member) \ - (((INT)((LPBYTE)(&((name*)0)->member)-((LPBYTE)((name*)0))))+ \ - sizeof(((name*)0)->member)) +#define NM_FIRST (0U- 0U) +#define NM_LAST (0U- 99U) + +#define LVN_FIRST (0U-100U) +#define LVN_LAST (0U-199U) + +#define HDN_FIRST (0U-300U) +#define HDN_LAST (0U-399U) + +#define TVN_FIRST (0U-400U) +#define TVN_LAST (0U-499U) + +#define TTN_FIRST (0U-520U) +#define TTN_LAST (0U-549U) + +#define TCN_FIRST (0U-550U) +#define TCN_LAST (0U-580U) + +#ifndef CDN_FIRST +#define CDN_FIRST (0U-601U) +#define CDN_LAST (0U-699U) #endif +#define TBN_FIRST (0U-700U) +#define TBN_LAST (0U-720U) -/* This is only for Winelib applications. DON't use it wine itself!!! */ -#ifndef SNDMSG -#ifdef __cplusplus -#define SNDMSG ::SendMessage -#else /* __cplusplus */ -#define SNDMSG SendMessage -#endif /* __cplusplus */ -#endif /* SNDMSG */ +#define UDN_FIRST (0U-721) +#define UDN_LAST (0U-740) +#define MCN_FIRST (0U-750U) +#define MCN_LAST (0U-759U) +#define DTN_FIRST (0U-760U) +#define DTN_LAST (0U-799U) +#define CBEN_FIRST (0U-800U) +#define CBEN_LAST (0U-830U) +#define RBN_FIRST (0U-831U) +#define RBN_LAST (0U-859U) -#ifdef __cplusplus -#define SNDMSGA ::SendMessageA -#define SNDMSGW ::SendMessageW -#else -#define SNDMSGA SendMessageA -#define SNDMSGW SendMessageW +#define IPN_FIRST (0U-860U) +#define IPN_LAST (0U-879U) +#define SBN_FIRST (0U-880U) +#define SBN_LAST (0U-899U) +#define PGN_FIRST (0U-900U) +#define PGN_LAST (0U-950U) + +#ifndef WMN_FIRST +#define WMN_FIRST (0U-1000U) +#define WMN_LAST (0U-1200U) #endif -/* Custom Draw messages */ +#define BCN_FIRST (0U-1250U) +#define BCN_LAST (0U-1350U) -#define CDRF_DODEFAULT 0x0 -#define CDRF_NEWFONT 0x00000002 -#define CDRF_SKIPDEFAULT 0x00000004 -#define CDRF_NOTIFYPOSTPAINT 0x00000010 -#define CDRF_NOTIFYITEMDRAW 0x00000020 -#define CDRF_NOTIFYSUBITEMDRAW 0x00000020 -#define CDRF_NOTIFYPOSTERASE 0x00000040 -#define CDRF_NOTIFYITEMERASE 0x00000080 /* obsolete ??? */ +#define MSGF_COMMCTRL_BEGINDRAG 0x4200 +#define MSGF_COMMCTRL_SIZEHEADER 0x4201 +#define MSGF_COMMCTRL_DRAGSELECT 0x4202 +#define MSGF_COMMCTRL_TOOLBARCUST 0x4203 +#define CDRF_DODEFAULT 0x0 +#define CDRF_NEWFONT 0x2 +#define CDRF_SKIPDEFAULT 0x4 -/* drawstage flags */ +#define CDRF_NOTIFYPOSTPAINT 0x10 +#define CDRF_NOTIFYITEMDRAW 0x20 +#define CDRF_NOTIFYSUBITEMDRAW 0x20 +#define CDRF_NOTIFYPOSTERASE 0x40 -#define CDDS_PREPAINT 1 -#define CDDS_POSTPAINT 2 -#define CDDS_PREERASE 3 -#define CDDS_POSTERASE 4 +#define CDDS_PREPAINT 0x1 +#define CDDS_POSTPAINT 0x2 +#define CDDS_PREERASE 0x3 +#define CDDS_POSTERASE 0x4 +#define CDDS_ITEM 0x10000 +#define CDDS_ITEMPREPAINT (CDDS_ITEM | CDDS_PREPAINT) +#define CDDS_ITEMPOSTPAINT (CDDS_ITEM | CDDS_POSTPAINT) +#define CDDS_ITEMPREERASE (CDDS_ITEM | CDDS_PREERASE) +#define CDDS_ITEMPOSTERASE (CDDS_ITEM | CDDS_POSTERASE) +#define CDDS_SUBITEM 0x20000 -#define CDDS_ITEM 0x00010000 -#define CDDS_ITEMPREPAINT (CDDS_ITEM | CDDS_PREPAINT) -#define CDDS_ITEMPOSTPAINT (CDDS_ITEM | CDDS_POSTPAINT) -#define CDDS_ITEMPREERASE (CDDS_ITEM | CDDS_PREERASE) -#define CDDS_ITEMPOSTERASE (CDDS_ITEM | CDDS_POSTERASE) -#define CDDS_SUBITEM 0x00020000 +#define CDIS_SELECTED 0x1 +#define CDIS_GRAYED 0x2 +#define CDIS_DISABLED 0x4 +#define CDIS_CHECKED 0x8 +#define CDIS_FOCUS 0x10 +#define CDIS_DEFAULT 0x20 +#define CDIS_HOT 0x40 +#define CDIS_MARKED 0x80 +#define CDIS_INDETERMINATE 0x100 +#define CDIS_SHOWKEYBOARDCUES 0x200 -/* itemState flags */ + typedef struct tagNMCUSTOMDRAWINFO { + NMHDR hdr; + DWORD dwDrawStage; + HDC hdc; + RECT rc; + DWORD_PTR dwItemSpec; + UINT uItemState; + LPARAM lItemlParam; + } NMCUSTOMDRAW,*LPNMCUSTOMDRAW; -#define CDIS_SELECTED 0x0001 -#define CDIS_GRAYED 0x0002 -#define CDIS_DISABLED 0x0004 -#define CDIS_CHECKED 0x0008 -#define CDIS_FOCUS 0x0010 -#define CDIS_DEFAULT 0x0020 -#define CDIS_HOT 0x0040 -#define CDIS_MARKED 0x0080 -#define CDIS_INDETERMINATE 0x0100 -#define CDIS_SHOWKEYBOARDCUES 0x0200 -#define CDIS_NEARHOT 0x0400 -#define CDIS_OTHERSIDEHOT 0x0800 -#define CDIS_DROPHILITED 0x1000 - - -typedef struct tagNMCUSTOMDRAWINFO -{ - NMHDR hdr; - DWORD dwDrawStage; - HDC hdc; - RECT rc; - DWORD_PTR dwItemSpec; - UINT uItemState; - LPARAM lItemlParam; -} NMCUSTOMDRAW, *LPNMCUSTOMDRAW; - -typedef struct tagNMTTCUSTOMDRAW -{ + typedef struct tagNMTTCUSTOMDRAW { NMCUSTOMDRAW nmcd; - UINT uDrawFlags; -} NMTTCUSTOMDRAW, *LPNMTTCUSTOMDRAW; + UINT uDrawFlags; + } NMTTCUSTOMDRAW,*LPNMTTCUSTOMDRAW; +#ifndef NOIMAGEAPIS +#define CLR_NONE 0xffffffffL +#define CLR_DEFAULT 0xFF000000L - -/* StatusWindow */ - -#define STATUSCLASSNAMEA "msctls_statusbar32" -#if defined(__GNUC__) -# define STATUSCLASSNAMEW (const WCHAR []){ 'm','s','c','t','l','s','_', \ - 's','t','a','t','u','s','b','a','r','3','2',0 } -#elif defined(_MSC_VER) -# define STATUSCLASSNAMEW L"msctls_statusbar32" -#else -static const WCHAR STATUSCLASSNAMEW[] = { 'm','s','c','t','l','s','_', - 's','t','a','t','u','s','b','a','r','3','2',0 }; +#ifndef HIMAGELIST + struct _IMAGELIST; + typedef struct _IMAGELIST *HIMAGELIST; #endif -#define STATUSCLASSNAME WINELIB_NAME_AW(STATUSCLASSNAME) -#define SBT_NOBORDERS 0x0100 -#define SBT_POPOUT 0x0200 -#define SBT_RTLREADING 0x0400 /* not supported */ -#define SBT_TOOLTIPS 0x0800 -#define SBT_OWNERDRAW 0x1000 +#ifndef IMAGELISTDRAWPARAMS + typedef struct _IMAGELISTDRAWPARAMS { + DWORD cbSize; + HIMAGELIST himl; + int i; + HDC hdcDst; + int x; + int y; + int cx; + int cy; + int xBitmap; + int yBitmap; + COLORREF rgbBk; + COLORREF rgbFg; + UINT fStyle; + DWORD dwRop; + DWORD fState; + DWORD Frame; + COLORREF crEffect; + } IMAGELISTDRAWPARAMS,*LPIMAGELISTDRAWPARAMS; -#define SBARS_SIZEGRIP 0x0100 - -#define SB_SIMPLEID 0x00ff - -#define SB_SETTEXTA (WM_USER+1) -#define SB_SETTEXTW (WM_USER+11) -#define SB_SETTEXT WINELIB_NAME_AW(SB_SETTEXT) -#define SB_GETTEXTA (WM_USER+2) -#define SB_GETTEXTW (WM_USER+13) -#define SB_GETTEXT WINELIB_NAME_AW(SB_GETTEXT) -#define SB_GETTEXTLENGTHA (WM_USER+3) -#define SB_GETTEXTLENGTHW (WM_USER+12) -#define SB_GETTEXTLENGTH WINELIB_NAME_AW(SB_GETTEXTLENGTH) -#define SB_SETPARTS (WM_USER+4) -#define SB_SETBORDERS (WM_USER+5) -#define SB_GETPARTS (WM_USER+6) -#define SB_GETBORDERS (WM_USER+7) -#define SB_SETMINHEIGHT (WM_USER+8) -#define SB_SIMPLE (WM_USER+9) -#define SB_GETRECT (WM_USER+10) -#define SB_ISSIMPLE (WM_USER+14) -#define SB_SETICON (WM_USER+15) -#define SB_SETTIPTEXTA (WM_USER+16) -#define SB_SETTIPTEXTW (WM_USER+17) -#define SB_SETTIPTEXT WINELIB_NAME_AW(SB_SETTIPTEXT) -#define SB_GETTIPTEXTA (WM_USER+18) -#define SB_GETTIPTEXTW (WM_USER+19) -#define SB_GETTIPTEXT WINELIB_NAME_AW(SB_GETTIPTEXT) -#define SB_GETICON (WM_USER+20) -#define SB_SETBKCOLOR CCM_SETBKCOLOR /* lParam = bkColor */ -#define SB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define SB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT - -#define SBN_FIRST (0U-880U) -#define SBN_LAST (0U-899U) -#define SBN_SIMPLEMODECHANGE (SBN_FIRST-0) - -HWND WINAPI CreateStatusWindowA (LONG, LPCSTR, HWND, UINT); -HWND WINAPI CreateStatusWindowW (LONG, LPCWSTR, HWND, UINT); -#define CreateStatusWindow WINELIB_NAME_AW(CreateStatusWindow) -VOID WINAPI DrawStatusTextA (HDC, LPCRECT, LPCSTR, UINT); -VOID WINAPI DrawStatusTextW (HDC, LPCRECT, LPCWSTR, UINT); -#define DrawStatusText WINELIB_NAME_AW(DrawStatusText) -VOID WINAPI MenuHelp (UINT, WPARAM, LPARAM, HMENU, - HINSTANCE, HWND, UINT*); - -typedef struct tagCOLORSCHEME -{ - DWORD dwSize; - COLORREF clrBtnHighlight; /* highlight color */ - COLORREF clrBtnShadow; /* shadow color */ -} COLORSCHEME, *LPCOLORSCHEME; - -/************************************************************************** - * Drag List control - */ - -typedef struct tagDRAGLISTINFO -{ - UINT uNotification; - HWND hWnd; - POINT ptCursor; -} DRAGLISTINFO, *LPDRAGLISTINFO; - -#define DL_BEGINDRAG (WM_USER+133) -#define DL_DRAGGING (WM_USER+134) -#define DL_DROPPED (WM_USER+135) -#define DL_CANCELDRAG (WM_USER+136) - -#define DL_CURSORSET 0 -#define DL_STOPCURSOR 1 -#define DL_COPYCURSOR 2 -#define DL_MOVECURSOR 3 - -#define DRAGLISTMSGSTRINGA "commctrl_DragListMsg" -#if defined(__GNUC__) -# define DRAGLISTMSGSTRINGW (const WCHAR []){ 'c','o','m','m','c','t','r','l', \ - '_','D','r','a','g','L','i','s','t','M','s','g',0 } -#elif defined(_MSC_VER) -# define DRAGLISTMSGSTRINGW L"commctrl_DragListMsg" -#else -static const WCHAR DRAGLISTMSGSTRINGW[] = { 'c','o','m','m','c','t','r','l', - '_','D','r','a','g','L','i','s','t','M','s','g',0 }; +#define IMAGELISTDRAWPARAMS_V3_SIZE CCSIZEOF_STRUCT(IMAGELISTDRAWPARAMS,dwRop) #endif -#define DRAGLISTMSGSTRING WINELIB_NAME_AW(DRAGLISTMSGSTRING) -BOOL WINAPI MakeDragList (HWND); -VOID WINAPI DrawInsert (HWND, HWND, INT); -INT WINAPI LBItemFromPt (HWND, POINT, BOOL); - - -/* UpDown */ - -#define UPDOWN_CLASSA "msctls_updown32" -# define UPDOWN_CLASSW L"msctls_updown32" -#define UPDOWN_CLASS WINELIB_NAME_AW(UPDOWN_CLASS) - -typedef struct _UDACCEL -{ - UINT nSec; - UINT nInc; -} UDACCEL, *LPUDACCEL; - -#define UD_MAXVAL 0x7fff -#define UD_MINVAL 0x8001 - -#define UDS_WRAP 0x0001 -#define UDS_SETBUDDYINT 0x0002 -#define UDS_ALIGNRIGHT 0x0004 -#define UDS_ALIGNLEFT 0x0008 -#define UDS_AUTOBUDDY 0x0010 -#define UDS_ARROWKEYS 0x0020 -#define UDS_HORZ 0x0040 -#define UDS_NOTHOUSANDS 0x0080 -#define UDS_HOTTRACK 0x0100 - -#define UDN_FIRST (0U-721) -#define UDN_LAST (0U-740) -#define UDN_DELTAPOS (UDN_FIRST-1) - -#define UDM_SETRANGE (WM_USER+101) -#define UDM_GETRANGE (WM_USER+102) -#define UDM_SETPOS (WM_USER+103) -#define UDM_GETPOS (WM_USER+104) -#define UDM_SETBUDDY (WM_USER+105) -#define UDM_GETBUDDY (WM_USER+106) -#define UDM_SETACCEL (WM_USER+107) -#define UDM_GETACCEL (WM_USER+108) -#define UDM_SETBASE (WM_USER+109) -#define UDM_GETBASE (WM_USER+110) -#define UDM_SETRANGE32 (WM_USER+111) -#define UDM_GETRANGE32 (WM_USER+112) -#define UDM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define UDM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define UDM_SETPOS32 (WM_USER+113) -#define UDM_GETPOS32 (WM_USER+114) - - -#define NMUPDOWN NM_UPDOWN -#define LPNMUPDOWN LPNM_UPDOWN - -typedef struct tagNM_UPDOWN -{ - NMHDR hdr; - int iPos; - int iDelta; -} NM_UPDOWN, *LPNM_UPDOWN; - -HWND WINAPI CreateUpDownControl (DWORD, INT, INT, INT, INT, - HWND, INT, HINSTANCE, HWND, - INT, INT, INT); - -/* Progress Bar */ - -#define PROGRESS_CLASSA "msctls_progress32" -# define PROGRESS_CLASSW L"msctls_progress32" -#define PROGRESS_CLASS WINELIB_NAME_AW(PROGRESS_CLASS) - -#define PBM_SETRANGE (WM_USER+1) -#define PBM_SETPOS (WM_USER+2) -#define PBM_DELTAPOS (WM_USER+3) -#define PBM_SETSTEP (WM_USER+4) -#define PBM_STEPIT (WM_USER+5) -#define PBM_SETRANGE32 (WM_USER+6) -#define PBM_GETRANGE (WM_USER+7) -#define PBM_GETPOS (WM_USER+8) -#define PBM_SETBARCOLOR (WM_USER+9) -#define PBM_SETMARQUEE (WM_USER+10) -#define PBM_GETBKCOLOR (WM_USER+14) -#define PBM_GETBARCOLOR (WM_USER+15) -#define PBM_SETBKCOLOR CCM_SETBKCOLOR - -#define PBS_SMOOTH 0x01 -#define PBS_VERTICAL 0x04 -#define PBS_MARQUEE 0x08 - -typedef struct -{ - INT iLow; - INT iHigh; -} PBRANGE, *PPBRANGE; - - -/* ImageList */ - -struct _IMAGELIST; -typedef struct _IMAGELIST *HIMAGELIST; - -#define CLR_NONE 0xFFFFFFFF -#define CLR_DEFAULT 0xFF000000 -#define CLR_HILIGHT CLR_DEFAULT - -#define ILC_MASK 0x0001 -#define ILC_COLOR 0x0000 -#define ILC_COLORDDB 0x00FE -#define ILC_COLOR4 0x0004 -#define ILC_COLOR8 0x0008 -#define ILC_COLOR16 0x0010 -#define ILC_COLOR24 0x0018 -#define ILC_COLOR32 0x0020 -#define ILC_PALETTE 0x0800 /* no longer supported by M$ */ -#define ILC_MIRROR 0x2000 +#define ILC_MASK 0x1 +#define ILC_COLOR 0x0 +#define ILC_COLORDDB 0xfe +#define ILC_COLOR4 0x4 +#define ILC_COLOR8 0x8 +#define ILC_COLOR16 0x10 +#define ILC_COLOR24 0x18 +#define ILC_COLOR32 0x20 +#define ILC_PALETTE 0x800 +#define ILC_MIRROR 0x2000 #define ILC_PERITEMMIRROR 0x8000 -#define ILD_NORMAL 0x0000 -#define ILD_TRANSPARENT 0x0001 -#define ILD_BLEND25 0x0002 -#define ILD_BLEND50 0x0004 -#define ILD_MASK 0x0010 -#define ILD_IMAGE 0x0020 -#define ILD_ROP 0x0040 -#define ILD_OVERLAYMASK 0x0F00 + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_Create(int cx,int cy,UINT flags,int cInitial,int cGrow); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Destroy(HIMAGELIST himl); + WINCOMMCTRLAPI int WINAPI ImageList_GetImageCount(HIMAGELIST himl); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_SetImageCount(HIMAGELIST himl,UINT uNewCount); + WINCOMMCTRLAPI int WINAPI ImageList_Add(HIMAGELIST himl,HBITMAP hbmImage,HBITMAP hbmMask); + WINCOMMCTRLAPI int WINAPI ImageList_ReplaceIcon(HIMAGELIST himl,int i,HICON hicon); + WINCOMMCTRLAPI COLORREF WINAPI ImageList_SetBkColor(HIMAGELIST himl,COLORREF clrBk); + WINCOMMCTRLAPI COLORREF WINAPI ImageList_GetBkColor(HIMAGELIST himl); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_SetOverlayImage(HIMAGELIST himl,int iImage,int iOverlay); +#define ImageList_AddIcon(himl,hicon) ImageList_ReplaceIcon(himl,-1,hicon) + +#define ILD_NORMAL 0x0 +#define ILD_TRANSPARENT 0x1 +#define ILD_MASK 0x10 +#define ILD_IMAGE 0x20 +#define ILD_ROP 0x40 +#define ILD_BLEND25 0x2 +#define ILD_BLEND50 0x4 +#define ILD_OVERLAYMASK 0xf00 +#define INDEXTOOVERLAYMASK(i) ((i) << 8) #define ILD_PRESERVEALPHA 0x1000 -#define ILD_SCALE 0x2000 -#define ILD_DPISCALE 0x4000 -#define ILD_ASYNC 0x8000 +#define ILD_SCALE 0x2000 +#define ILD_DPISCALE 0x4000 -#define ILD_SELECTED ILD_BLEND50 -#define ILD_FOCUS ILD_BLEND25 -#define ILD_BLEND ILD_BLEND50 +#define ILD_SELECTED ILD_BLEND50 +#define ILD_FOCUS ILD_BLEND25 +#define ILD_BLEND ILD_BLEND50 +#define CLR_HILIGHT CLR_DEFAULT -#define INDEXTOOVERLAYMASK(i) ((i)<<8) -#define INDEXTOSTATEIMAGEMASK(i) ((i)<<12) +#define ILS_NORMAL 0x0 +#define ILS_GLOW 0x1 +#define ILS_SHADOW 0x2 +#define ILS_SATURATE 0x4 +#define ILS_ALPHA 0x8 -#define ILCF_MOVE (0x00000000) -#define ILCF_SWAP (0x00000001) + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Draw(HIMAGELIST himl,int i,HDC hdcDst,int x,int y,UINT fStyle); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Replace(HIMAGELIST himl,int i,HBITMAP hbmImage,HBITMAP hbmMask); + WINCOMMCTRLAPI int WINAPI ImageList_AddMasked(HIMAGELIST himl,HBITMAP hbmImage,COLORREF crMask); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DrawEx(HIMAGELIST himl,int i,HDC hdcDst,int x,int y,int dx,int dy,COLORREF rgbBk,COLORREF rgbFg,UINT fStyle); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DrawIndirect(IMAGELISTDRAWPARAMS *pimldp); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Remove(HIMAGELIST himl,int i); + WINCOMMCTRLAPI HICON WINAPI ImageList_GetIcon(HIMAGELIST himl,int i,UINT flags); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_LoadImageA(HINSTANCE hi,LPCSTR lpbmp,int cx,int cGrow,COLORREF crMask,UINT uType,UINT uFlags); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_LoadImageW(HINSTANCE hi,LPCWSTR lpbmp,int cx,int cGrow,COLORREF crMask,UINT uType,UINT uFlags); -#define ILGT_NORMAL 0x0000 -#define ILGT_ASYNC 0x0001 +#ifdef UNICODE +#define ImageList_LoadImage ImageList_LoadImageW +#else +#define ImageList_LoadImage ImageList_LoadImageA +#endif -#define ILS_NORMAL 0x0000 -#define ILS_GLOW 0x0001 -#define ILS_SHADOW 0x0002 -#define ILS_SATURATE 0x0004 -#define ILS_ALPHA 0x0008 - -typedef struct _IMAGEINFO -{ - HBITMAP hbmImage; - HBITMAP hbmMask; - INT Unused1; - INT Unused2; - RECT rcImage; -} IMAGEINFO, *LPIMAGEINFO; - - -typedef struct _IMAGELISTDRAWPARAMS -{ - DWORD cbSize; - HIMAGELIST himl; - INT i; - HDC hdcDst; - INT x; - INT y; - INT cx; - INT cy; - INT xBitmap; /* x offest from the upperleft of bitmap */ - INT yBitmap; /* y offset from the upperleft of bitmap */ - COLORREF rgbBk; - COLORREF rgbFg; - UINT fStyle; - DWORD dwRop; - DWORD fState; - DWORD Frame; - DWORD crEffect; -} IMAGELISTDRAWPARAMS, *LPIMAGELISTDRAWPARAMS; - - -HRESULT WINAPI HIMAGELIST_QueryInterface(HIMAGELIST,REFIID,void **); -INT WINAPI ImageList_Add(HIMAGELIST,HBITMAP,HBITMAP); -INT WINAPI ImageList_AddMasked(HIMAGELIST,HBITMAP,COLORREF); -BOOL WINAPI ImageList_BeginDrag(HIMAGELIST,INT,INT,INT); -BOOL WINAPI ImageList_Copy(HIMAGELIST,INT,HIMAGELIST,INT,UINT); -HIMAGELIST WINAPI ImageList_Create(INT,INT,UINT,INT,INT); -BOOL WINAPI ImageList_Destroy(HIMAGELIST); -BOOL WINAPI ImageList_DragEnter(HWND,INT,INT); -BOOL WINAPI ImageList_DragLeave(HWND); -BOOL WINAPI ImageList_DragMove(INT,INT); -BOOL WINAPI ImageList_DragShowNolock (BOOL); -BOOL WINAPI ImageList_Draw(HIMAGELIST,INT,HDC,INT,INT,UINT); -BOOL WINAPI ImageList_DrawEx(HIMAGELIST,INT,HDC,INT,INT,INT, - INT,COLORREF,COLORREF,UINT); -BOOL WINAPI ImageList_DrawIndirect(IMAGELISTDRAWPARAMS*); -HIMAGELIST WINAPI ImageList_Duplicate(HIMAGELIST); -VOID WINAPI ImageList_EndDrag(VOID); -COLORREF WINAPI ImageList_GetBkColor(HIMAGELIST); -HIMAGELIST WINAPI ImageList_GetDragImage(POINT*,POINT*); -HICON WINAPI ImageList_GetIcon(HIMAGELIST,INT,UINT); -BOOL WINAPI ImageList_GetIconSize(HIMAGELIST,INT*,INT*); -INT WINAPI ImageList_GetImageCount(HIMAGELIST); -BOOL WINAPI ImageList_GetImageInfo(HIMAGELIST,INT,IMAGEINFO*); -BOOL WINAPI ImageList_GetImageRect(HIMAGELIST,INT,LPRECT); -HIMAGELIST WINAPI ImageList_LoadImageA(HINSTANCE,LPCSTR,INT,INT, - COLORREF,UINT,UINT); -HIMAGELIST WINAPI ImageList_LoadImageW(HINSTANCE,LPCWSTR,INT,INT, - COLORREF,UINT,UINT); -#define ImageList_LoadImage WINELIB_NAME_AW(ImageList_LoadImage) -HIMAGELIST WINAPI ImageList_Merge(HIMAGELIST,INT,HIMAGELIST,INT,INT,INT); -BOOL WINAPI ImageList_Remove(HIMAGELIST,INT); -BOOL WINAPI ImageList_Replace(HIMAGELIST,INT,HBITMAP,HBITMAP); -INT WINAPI ImageList_ReplaceIcon(HIMAGELIST,INT,HICON); -COLORREF WINAPI ImageList_SetBkColor(HIMAGELIST,COLORREF); -BOOL WINAPI ImageList_SetDragCursorImage(HIMAGELIST,INT,INT,INT); - -BOOL WINAPI ImageList_SetIconSize(HIMAGELIST,INT,INT); -BOOL WINAPI ImageList_SetImageCount(HIMAGELIST,UINT); -BOOL WINAPI ImageList_SetOverlayImage(HIMAGELIST,INT,INT); +#define ILCF_MOVE 0x0 +#define ILCF_SWAP 0x1 + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Copy(HIMAGELIST himlDst,int iDst,HIMAGELIST himlSrc,int iSrc,UINT uFlags); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_BeginDrag(HIMAGELIST himlTrack,int iTrack,int dxHotspot,int dyHotspot); + WINCOMMCTRLAPI void WINAPI ImageList_EndDrag(); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DragEnter(HWND hwndLock,int x,int y); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DragLeave(HWND hwndLock); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DragMove(int x,int y); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_SetDragCursorImage(HIMAGELIST himlDrag,int iDrag,int dxHotspot,int dyHotspot); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_DragShowNolock(WINBOOL fShow); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_GetDragImage(POINT *ppt,POINT *pptHotspot); +#define ImageList_RemoveAll(himl) ImageList_Remove(himl,-1) +#define ImageList_ExtractIcon(hi,himl,i) ImageList_GetIcon(himl,i,0) +#define ImageList_LoadBitmap(hi,lpbmp,cx,cGrow,crMask) ImageList_LoadImage(hi,lpbmp,cx,cGrow,crMask,IMAGE_BITMAP,0) #ifdef __IStream_INTERFACE_DEFINED__ -HIMAGELIST WINAPI ImageList_Read(LPSTREAM); -BOOL WINAPI ImageList_Write(HIMAGELIST, LPSTREAM); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_Read(LPSTREAM pstm); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_Write(HIMAGELIST himl,LPSTREAM pstm); +#define ILP_NORMAL 0 +#define ILP_DOWNLEVEL 1 + WINCOMMCTRLAPI HRESULT WINAPI ImageList_ReadEx(DWORD dwFlags,LPSTREAM pstm,REFIID riid,PVOID *ppv); + WINCOMMCTRLAPI HRESULT WINAPI ImageList_WriteEx(HIMAGELIST himl,DWORD dwFlags,LPSTREAM pstm); #endif -#define ImageList_AddIcon(himl,hicon) ImageList_ReplaceIcon(himl,-1,hicon) -#define ImageList_ExtractIcon(hi,himl,i) ImageList_GetIcon(himl,i,0) -#define ImageList_LoadBitmap(hi,lpbmp,cx,cGrow,crMask) \ - ImageList_LoadImage(hi,lpbmp,cx,cGrow,crMask,IMAGE_BITMAP,0) -#define ImageList_RemoveAll(himl) ImageList_Remove(himl,-1) - - -#ifndef WM_MOUSEHOVER -#define WM_MOUSEHOVER 0x02A1 -#define WM_MOUSELEAVE 0x02A3 +#ifndef IMAGEINFO + typedef struct _IMAGEINFO { + HBITMAP hbmImage; + HBITMAP hbmMask; + int Unused1; + int Unused2; + RECT rcImage; + } IMAGEINFO,*LPIMAGEINFO; #endif -#ifndef TME_HOVER - -#define TME_HOVER 0x00000001 -#define TME_LEAVE 0x00000002 -#define TME_NONCLIENT 0x00000010 -#define TME_QUERY 0x40000000 -#define TME_CANCEL 0x80000000 - - -#define HOVER_DEFAULT 0xFFFFFFFF - -typedef struct tagTRACKMOUSEEVENT { - DWORD cbSize; - DWORD dwFlags; - HWND hwndTrack; - DWORD dwHoverTime; -} TRACKMOUSEEVENT, *LPTRACKMOUSEEVENT; - + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_GetIconSize(HIMAGELIST himl,int *cx,int *cy); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_SetIconSize(HIMAGELIST himl,int cx,int cy); + WINCOMMCTRLAPI WINBOOL WINAPI ImageList_GetImageInfo(HIMAGELIST himl,int i,IMAGEINFO *pImageInfo); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_Merge(HIMAGELIST himl1,int i1,HIMAGELIST himl2,int i2,int dx,int dy); + WINCOMMCTRLAPI HIMAGELIST WINAPI ImageList_Duplicate(HIMAGELIST himl); #endif -BOOL WINAPI _TrackMouseEvent(LPTRACKMOUSEEVENT lpEventTrack); +#ifndef NOHEADER -/* Flat Scrollbar control */ +#define WC_HEADERA "SysHeader32" +#define WC_HEADERW L"SysHeader32" -#define FLATSB_CLASSA "flatsb_class32" -#if defined(__GNUC__) -# define FLATSB_CLASSW (const WCHAR []){ 'f','l','a','t','s','b','_', \ - 'c','l','a','s','s','3','2',0 } -#elif defined(_MSC_VER) -# define FLATSB_CLASSW L"flatsb_class32" +#ifdef UNICODE +#define WC_HEADER WC_HEADERW #else -static const WCHAR FLATSB_CLASSW[] = { 'f','l','a','t','s','b','_', - 'c','l','a','s','s','3','2',0 }; +#define WC_HEADER WC_HEADERA #endif -#define FLATSB_CLASS WINELIB_NAME_AW(FLATSB_CLASS) -#define WSB_PROP_CYVSCROLL 0x00000001L -#define WSB_PROP_CXHSCROLL 0x00000002L -#define WSB_PROP_CYHSCROLL 0x00000004L -#define WSB_PROP_CXVSCROLL 0x00000008L -#define WSB_PROP_CXHTHUMB 0x00000010L -#define WSB_PROP_CYVTHUMB 0x00000020L -#define WSB_PROP_VBKGCOLOR 0x00000040L -#define WSB_PROP_HBKGCOLOR 0x00000080L -#define WSB_PROP_VSTYLE 0x00000100L -#define WSB_PROP_HSTYLE 0x00000200L -#define WSB_PROP_WINSTYLE 0x00000400L -#define WSB_PROP_PALETTE 0x00000800L -#define WSB_PROP_MASK 0x00000FFFL +#define HDS_HORZ 0x0 +#define HDS_BUTTONS 0x2 +#define HDS_HOTTRACK 0x4 +#define HDS_HIDDEN 0x8 +#define HDS_DRAGDROP 0x40 +#define HDS_FULLDRAG 0x80 +#define HDS_FILTERBAR 0x100 +#define HDS_FLAT 0x200 +#if (_WIN32_WINNT >= 0x0600) +#define HDS_CHECKBOXES 0x400 +#define HDS_NOSIZING 0x800 +#define HDS_OVERFLOW 0x1000 +#endif -#define FSB_REGULAR_MODE 0 -#define FSB_ENCARTA_MODE 1 -#define FSB_FLAT_MODE 2 +#define HDFT_ISSTRING 0x0 +#define HDFT_ISNUMBER 0x1 +#define HDFT_HASNOVALUE 0x8000 -BOOL WINAPI FlatSB_EnableScrollBar(HWND, INT, UINT); -BOOL WINAPI FlatSB_ShowScrollBar(HWND, INT, BOOL); -BOOL WINAPI FlatSB_GetScrollRange(HWND, INT, LPINT, LPINT); -BOOL WINAPI FlatSB_GetScrollInfo(HWND, INT, LPSCROLLINFO); -INT WINAPI FlatSB_GetScrollPos(HWND, INT); -BOOL WINAPI FlatSB_GetScrollProp(HWND, INT, LPINT); -INT WINAPI FlatSB_SetScrollPos(HWND, INT, INT, BOOL); -INT WINAPI FlatSB_SetScrollInfo(HWND, INT, LPSCROLLINFO, BOOL); -INT WINAPI FlatSB_SetScrollRange(HWND, INT, INT, INT, BOOL); -BOOL WINAPI FlatSB_SetScrollProp(HWND, UINT, INT, BOOL); -BOOL WINAPI InitializeFlatSB(HWND); -HRESULT WINAPI UninitializeFlatSB(HWND); +#ifdef UNICODE +#define HD_TEXTFILTER HD_TEXTFILTERW +#define HDTEXTFILTER HD_TEXTFILTERW +#define LPHD_TEXTFILTER LPHD_TEXTFILTERW +#define LPHDTEXTFILTER LPHD_TEXTFILTERW +#else +#define HD_TEXTFILTER HD_TEXTFILTERA +#define HDTEXTFILTER HD_TEXTFILTERA +#define LPHD_TEXTFILTER LPHD_TEXTFILTERA +#define LPHDTEXTFILTER LPHD_TEXTFILTERA +#endif -/* Subclassing stuff */ -typedef LRESULT (CALLBACK *SUBCLASSPROC)(HWND, UINT, WPARAM, LPARAM, UINT_PTR, DWORD_PTR); -BOOL WINAPI SetWindowSubclass(HWND, SUBCLASSPROC, UINT_PTR, DWORD_PTR); -BOOL WINAPI GetWindowSubclass(HWND, SUBCLASSPROC, UINT_PTR, DWORD_PTR*); -BOOL WINAPI RemoveWindowSubclass(HWND, SUBCLASSPROC, UINT_PTR); -LRESULT WINAPI DefSubclassProc(HWND, UINT, WPARAM, LPARAM); - -int WINAPI DrawShadowText(HDC, LPCWSTR, UINT, RECT*, DWORD, COLORREF, COLORREF, int, int); - -/* Header control */ - -#define WC_HEADERA "SysHeader32" -# define WC_HEADERW L"SysHeader32" -#define WC_HEADER WINELIB_NAME_AW(WC_HEADER) - -#define HDS_HORZ 0x0000 -#define HDS_BUTTONS 0x0002 -#define HDS_HOTTRACK 0x0004 -#define HDS_HIDDEN 0x0008 -#define HDS_DRAGDROP 0x0040 -#define HDS_FULLDRAG 0x0080 -#define HDS_FILTERBAR 0x0100 -#define HDS_FLAT 0x0200 -#define HDS_CHECKBOXES 0x0400 -#define HDS_NOSIZING 0x0800 -#define HDS_OVERFLOW 0x1000 - -#define HDI_WIDTH 0x0001 -#define HDI_HEIGHT HDI_WIDTH -#define HDI_TEXT 0x0002 -#define HDI_FORMAT 0x0004 -#define HDI_LPARAM 0x0008 -#define HDI_BITMAP 0x0010 -#define HDI_IMAGE 0x0020 -#define HDI_DI_SETITEM 0x0040 -#define HDI_ORDER 0x0080 -#define HDI_FILTER 0x0100 -#define HDI_STATE 0x0200 - -#define HDIS_FOCUSED 0x00000001 - -#define HDF_LEFT 0x0000 -#define HDF_RIGHT 0x0001 -#define HDF_CENTER 0x0002 -#define HDF_JUSTIFYMASK 0x0003 -#define HDF_RTLREADING 0x0004 -#define HDF_CHECKBOX 0x0040 -#define HDF_CHECKED 0x0080 -#define HDF_FIXEDWIDTH 0x0100 -#define HDF_SORTDOWN 0x0200 -#define HDF_SORTUP 0x0400 -#define HDF_IMAGE 0x0800 -#define HDF_BITMAP_ON_RIGHT 0x1000 -#define HDF_BITMAP 0x2000 -#define HDF_STRING 0x4000 -#define HDF_OWNERDRAW 0x8000 -#define HDF_SPLITBUTTON 0x1000000 - -#define HHT_NOWHERE 0x0001 -#define HHT_ONHEADER 0x0002 -#define HHT_ONDIVIDER 0x0004 -#define HHT_ONDIVOPEN 0x0008 -#define HHT_ONFILTER 0x0010 -#define HHT_ONFILTERBUTTON 0x0020 -#define HHT_ABOVE 0x0100 -#define HHT_BELOW 0x0200 -#define HHT_TORIGHT 0x0400 -#define HHT_TOLEFT 0x0800 -#define HHT_ONITEMSTATEICON 0x1000 -#define HHT_ONDROPDOWN 0x2000 -#define HHT_ONOVERFLOW 0x4000 - -#define HDM_FIRST 0x1200 -#define HDM_GETITEMCOUNT (HDM_FIRST+0) -#define HDM_INSERTITEMA (HDM_FIRST+1) -#define HDM_INSERTITEMW (HDM_FIRST+10) -#define HDM_INSERTITEM WINELIB_NAME_AW(HDM_INSERTITEM) -#define HDM_DELETEITEM (HDM_FIRST+2) -#define HDM_GETITEMA (HDM_FIRST+3) -#define HDM_GETITEMW (HDM_FIRST+11) -#define HDM_GETITEM WINELIB_NAME_AW(HDM_GETITEM) -#define HDM_SETITEMA (HDM_FIRST+4) -#define HDM_SETITEMW (HDM_FIRST+12) -#define HDM_SETITEM WINELIB_NAME_AW(HDM_SETITEM) -#define HDM_LAYOUT (HDM_FIRST+5) -#define HDM_HITTEST (HDM_FIRST+6) -#define HDM_GETITEMRECT (HDM_FIRST+7) -#define HDM_SETIMAGELIST (HDM_FIRST+8) -#define HDM_GETIMAGELIST (HDM_FIRST+9) - -#define HDM_ORDERTOINDEX (HDM_FIRST+15) -#define HDM_CREATEDRAGIMAGE (HDM_FIRST+16) -#define HDM_GETORDERARRAY (HDM_FIRST+17) -#define HDM_SETORDERARRAY (HDM_FIRST+18) -#define HDM_SETHOTDIVIDER (HDM_FIRST+19) -#define HDM_SETBITMAPMARGIN (HDM_FIRST+20) -#define HDM_GETBITMAPMARGIN (HDM_FIRST+21) -#define HDM_SETFILTERCHANGETIMEOUT (HDM_FIRST+22) -#define HDM_EDITFILTER (HDM_FIRST+23) -#define HDM_CLEARFILTER (HDM_FIRST+24) -#define HDM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define HDM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT - -#define HDN_FIRST (0U-300U) -#define HDN_LAST (0U-399U) -#define HDN_ITEMCHANGINGA (HDN_FIRST-0) -#define HDN_ITEMCHANGINGW (HDN_FIRST-20) -#define HDN_ITEMCHANGING WINELIB_NAME_AW(HDN_ITEMCHANGING) -#define HDN_ITEMCHANGEDA (HDN_FIRST-1) -#define HDN_ITEMCHANGEDW (HDN_FIRST-21) -#define HDN_ITEMCHANGED WINELIB_NAME_AW(HDN_ITEMCHANGED) -#define HDN_ITEMCLICKA (HDN_FIRST-2) -#define HDN_ITEMCLICKW (HDN_FIRST-22) -#define HDN_ITEMCLICK WINELIB_NAME_AW(HDN_ITEMCLICK) -#define HDN_ITEMDBLCLICKA (HDN_FIRST-3) -#define HDN_ITEMDBLCLICKW (HDN_FIRST-23) -#define HDN_ITEMDBLCLICK WINELIB_NAME_AW(HDN_ITEMDBLCLICK) -#define HDN_DIVIDERDBLCLICKA (HDN_FIRST-5) -#define HDN_DIVIDERDBLCLICKW (HDN_FIRST-25) -#define HDN_DIVIDERDBLCLICK WINELIB_NAME_AW(HDN_DIVIDERDBLCLICK) -#define HDN_BEGINTRACKA (HDN_FIRST-6) -#define HDN_BEGINTRACKW (HDN_FIRST-26) -#define HDN_BEGINTRACK WINELIB_NAME_AW(HDN_BEGINTRACK) -#define HDN_ENDTRACKA (HDN_FIRST-7) -#define HDN_ENDTRACKW (HDN_FIRST-27) -#define HDN_ENDTRACK WINELIB_NAME_AW(HDN_ENDTRACK) -#define HDN_TRACKA (HDN_FIRST-8) -#define HDN_TRACKW (HDN_FIRST-28) -#define HDN_TRACK WINELIB_NAME_AW(HDN_TRACK) -#define HDN_GETDISPINFOA (HDN_FIRST-9) -#define HDN_GETDISPINFOW (HDN_FIRST-29) -#define HDN_GETDISPINFO WINELIB_NAME_AW(HDN_GETDISPINFO) -#define HDN_BEGINDRAG (HDN_FIRST-10) -#define HDN_ENDDRAG (HDN_FIRST-11) -#define HDN_FILTERCHANGE (HDN_FIRST-12) -#define HDN_FILTERBTNCLICK (HDN_FIRST-13) -#define HDN_BEGINFILTEREDIT (HDN_FIRST-14) -#define HDN_ENDFILTEREDIT (HDN_FIRST-15) -#define HDN_ITEMSTATEICONCLICK (HDN_FIRST-16) -#define HDN_ITEMKEYDOWN (HDN_FIRST-17) - -typedef struct _HD_LAYOUT -{ - RECT *prc; - WINDOWPOS *pwpos; -} HDLAYOUT, *LPHDLAYOUT; - -#define HD_LAYOUT HDLAYOUT - -typedef struct _HD_ITEMA -{ - UINT mask; - INT cxy; - LPSTR pszText; - HBITMAP hbm; - INT cchTextMax; - INT fmt; - LPARAM lParam; - /* (_WIN32_IE >= 0x0300) */ - INT iImage; - INT iOrder; - /* (_WIN32_IE >= 0x0500) */ - UINT type; - LPVOID pvFilter; - /* (_WIN32_WINNT >= 0x0600) */ - UINT state; -} HDITEMA, *LPHDITEMA; - -typedef struct _HD_ITEMW -{ - UINT mask; - INT cxy; - LPWSTR pszText; - HBITMAP hbm; - INT cchTextMax; - INT fmt; - LPARAM lParam; - /* (_WIN32_IE >= 0x0300) */ - INT iImage; - INT iOrder; - /* (_WIN32_IE >= 0x0500) */ - UINT type; - LPVOID pvFilter; - /* (_WIN32_WINNT >= 0x0600) */ - UINT state; -} HDITEMW, *LPHDITEMW; - -#define HDITEM WINELIB_NAME_AW(HDITEM) -#define LPHDITEM WINELIB_NAME_AW(LPHDITEM) -#define HD_ITEM HDITEM - -#define HDITEM_V1_SIZEA CCSIZEOF_STRUCT(HDITEMA, lParam) -#define HDITEM_V1_SIZEW CCSIZEOF_STRUCT(HDITEMW, lParam) -#define HDITEM_V1_SIZE WINELIB_NAME_AW(HDITEM_V1_SIZE) - -#define HDFT_ISSTRING 0x0000 -#define HDFT_ISNUMBER 0x0001 -#define HDFT_HASNOVALUE 0x8000 - -typedef struct _HD_TEXTFILTERA -{ + typedef struct _HD_TEXTFILTERA { LPSTR pszText; INT cchTextMax; -} HD_TEXTFILTERA, *LPHD_TEXTFILTERA; + } HD_TEXTFILTERA,*LPHD_TEXTFILTERA; -typedef struct _HD_TEXTFILTERW -{ + typedef struct _HD_TEXTFILTERW { LPWSTR pszText; INT cchTextMax; -} HD_TEXTFILTERW, *LPHD_TEXTFILTERW; + } HD_TEXTFILTERW,*LPHD_TEXTFILTERW; -#define HD_TEXTFILTER WINELIB_NAME_AW(HD_TEXTFILTER) -#define HDTEXTFILTER WINELIB_NAME_AW(HD_TEXTFILTER) -#define LPHD_TEXTFILTER WINELIB_NAME_AW(LPHD_TEXTFILTER) -#define LPHDTEXTFILTER WINELIB_NAME_AW(LPHD_TEXTFILTER) +#define HD_ITEMA HDITEMA +#define HD_ITEMW HDITEMW +#define HD_ITEM HDITEM -typedef struct _HD_HITTESTINFO -{ + typedef struct _HD_ITEMA { + UINT mask; + int cxy; + LPSTR pszText; + HBITMAP hbm; + int cchTextMax; + int fmt; + LPARAM lParam; + int iImage; + int iOrder; + UINT type; + void *pvFilter; + } HDITEMA,*LPHDITEMA; + +#define HDITEMA_V1_SIZE CCSIZEOF_STRUCT(HDITEMA,lParam) +#define HDITEMW_V1_SIZE CCSIZEOF_STRUCT(HDITEMW,lParam) + + typedef struct _HD_ITEMW { + UINT mask; + int cxy; + LPWSTR pszText; + HBITMAP hbm; + int cchTextMax; + int fmt; + LPARAM lParam; + int iImage; + int iOrder; + UINT type; + void *pvFilter; + } HDITEMW,*LPHDITEMW; + +#ifdef UNICODE +#define HDITEM HDITEMW +#define LPHDITEM LPHDITEMW +#define HDITEM_V1_SIZE HDITEMW_V1_SIZE +#else +#define HDITEM HDITEMA +#define LPHDITEM LPHDITEMA +#define HDITEM_V1_SIZE HDITEMA_V1_SIZE +#endif + +#define HDI_WIDTH 0x1 +#define HDI_HEIGHT HDI_WIDTH +#define HDI_TEXT 0x2 +#define HDI_FORMAT 0x4 +#define HDI_LPARAM 0x8 +#define HDI_BITMAP 0x10 +#define HDI_IMAGE 0x20 +#define HDI_DI_SETITEM 0x40 +#define HDI_ORDER 0x80 +#define HDI_FILTER 0x100 + +#define HDF_LEFT 0x0 +#define HDF_RIGHT 0x1 +#define HDF_CENTER 0x2 +#define HDF_JUSTIFYMASK 0x3 +#define HDF_RTLREADING 0x4 + +#define HDF_OWNERDRAW 0x8000 +#define HDF_STRING 0x4000 +#define HDF_BITMAP 0x2000 +#define HDF_BITMAP_ON_RIGHT 0x1000 +#define HDF_IMAGE 0x800 +#define HDF_SORTUP 0x400 +#define HDF_SORTDOWN 0x200 +#if (_WIN32_WINNT >= 0x0600) +#define HDF_CHECKBOX 0x40 +#define HDF_CHECKED 0x80 +#define HDF_FIXEDWIDTH 0x100 +#define HDF_SPLITBUTTON 0x1000000 +#endif + +#define HDM_GETITEMCOUNT (HDM_FIRST+0) +#define Header_GetItemCount(hwndHD) (int)SNDMSG((hwndHD),HDM_GETITEMCOUNT,0,0L) + +#define HDM_INSERTITEMA (HDM_FIRST+1) +#define HDM_INSERTITEMW (HDM_FIRST+10) + +#ifdef UNICODE +#define HDM_INSERTITEM HDM_INSERTITEMW +#else +#define HDM_INSERTITEM HDM_INSERTITEMA +#endif + +#define Header_InsertItem(hwndHD,i,phdi) (int)SNDMSG((hwndHD),HDM_INSERTITEM,(WPARAM)(int)(i),(LPARAM)(const HD_ITEM *)(phdi)) + +#define HDM_DELETEITEM (HDM_FIRST+2) +#define Header_DeleteItem(hwndHD,i) (WINBOOL)SNDMSG((hwndHD),HDM_DELETEITEM,(WPARAM)(int)(i),0L) + +#define HDM_GETITEMA (HDM_FIRST+3) +#define HDM_GETITEMW (HDM_FIRST+11) + +#ifdef UNICODE +#define HDM_GETITEM HDM_GETITEMW +#else +#define HDM_GETITEM HDM_GETITEMA +#endif + +#define Header_GetItem(hwndHD,i,phdi) (WINBOOL)SNDMSG((hwndHD),HDM_GETITEM,(WPARAM)(int)(i),(LPARAM)(HD_ITEM *)(phdi)) + +#define HDM_SETITEMA (HDM_FIRST+4) +#define HDM_SETITEMW (HDM_FIRST+12) + +#ifdef UNICODE +#define HDM_SETITEM HDM_SETITEMW +#else +#define HDM_SETITEM HDM_SETITEMA +#endif + +#define Header_SetItem(hwndHD,i,phdi) (WINBOOL)SNDMSG((hwndHD),HDM_SETITEM,(WPARAM)(int)(i),(LPARAM)(const HD_ITEM *)(phdi)) + +#define HD_LAYOUT HDLAYOUT + + typedef struct _HD_LAYOUT { + RECT *prc; + WINDOWPOS *pwpos; + } HDLAYOUT,*LPHDLAYOUT; + +#define HDM_LAYOUT (HDM_FIRST+5) +#define Header_Layout(hwndHD,playout) (WINBOOL)SNDMSG((hwndHD),HDM_LAYOUT,0,(LPARAM)(HD_LAYOUT *)(playout)) + +#define HHT_NOWHERE 0x1 +#define HHT_ONHEADER 0x2 +#define HHT_ONDIVIDER 0x4 +#define HHT_ONDIVOPEN 0x8 +#define HHT_ONFILTER 0x10 +#define HHT_ONFILTERBUTTON 0x20 +#define HHT_ABOVE 0x100 +#define HHT_BELOW 0x200 +#define HHT_TORIGHT 0x400 +#define HHT_TOLEFT 0x800 + +#define HD_HITTESTINFO HDHITTESTINFO + + typedef struct _HD_HITTESTINFO { POINT pt; - UINT flags; - INT iItem; -} HDHITTESTINFO, *LPHDHITTESTINFO; + UINT flags; + int iItem; + } HDHITTESTINFO,*LPHDHITTESTINFO; -#define HD_HITTESTINFO HDHITTESTINFO +#define HDM_HITTEST (HDM_FIRST+6) -typedef struct tagNMHEADERA -{ - NMHDR hdr; - INT iItem; - INT iButton; +#define HDM_GETITEMRECT (HDM_FIRST+7) +#define Header_GetItemRect(hwnd,iItem,lprc) (WINBOOL)SNDMSG((hwnd),HDM_GETITEMRECT,(WPARAM)(iItem),(LPARAM)(lprc)) + +#define HDM_SETIMAGELIST (HDM_FIRST+8) +#define Header_SetImageList(hwnd,himl) (HIMAGELIST)SNDMSG((hwnd),HDM_SETIMAGELIST,0,(LPARAM)(himl)) + +#define HDM_GETIMAGELIST (HDM_FIRST+9) +#define Header_GetImageList(hwnd) (HIMAGELIST)SNDMSG((hwnd),HDM_GETIMAGELIST,0,0) + +#define HDM_ORDERTOINDEX (HDM_FIRST+15) +#define Header_OrderToIndex(hwnd,i) (int)SNDMSG((hwnd),HDM_ORDERTOINDEX,(WPARAM)(i),0) + +#define HDM_CREATEDRAGIMAGE (HDM_FIRST+16) +#define Header_CreateDragImage(hwnd,i) (HIMAGELIST)SNDMSG((hwnd),HDM_CREATEDRAGIMAGE,(WPARAM)(i),0) + +#define HDM_GETORDERARRAY (HDM_FIRST+17) +#define Header_GetOrderArray(hwnd,iCount,lpi) (WINBOOL)SNDMSG((hwnd),HDM_GETORDERARRAY,(WPARAM)(iCount),(LPARAM)(lpi)) + +#define HDM_SETORDERARRAY (HDM_FIRST+18) +#define Header_SetOrderArray(hwnd,iCount,lpi) (WINBOOL)SNDMSG((hwnd),HDM_SETORDERARRAY,(WPARAM)(iCount),(LPARAM)(lpi)) + +#define HDM_SETHOTDIVIDER (HDM_FIRST+19) +#define Header_SetHotDivider(hwnd,fPos,dw) (int)SNDMSG((hwnd),HDM_SETHOTDIVIDER,(WPARAM)(fPos),(LPARAM)(dw)) + +#define HDM_SETBITMAPMARGIN (HDM_FIRST+20) +#define Header_SetBitmapMargin(hwnd,iWidth) (int)SNDMSG((hwnd),HDM_SETBITMAPMARGIN,(WPARAM)(iWidth),0) + +#define HDM_GETBITMAPMARGIN (HDM_FIRST+21) +#define Header_GetBitmapMargin(hwnd) (int)SNDMSG((hwnd),HDM_GETBITMAPMARGIN,0,0) + +#define HDM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define Header_SetUnicodeFormat(hwnd,fUnicode) (WINBOOL)SNDMSG((hwnd),HDM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) + +#define HDM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define Header_GetUnicodeFormat(hwnd) (WINBOOL)SNDMSG((hwnd),HDM_GETUNICODEFORMAT,0,0) + +#define HDM_SETFILTERCHANGETIMEOUT (HDM_FIRST+22) +#define Header_SetFilterChangeTimeout(hwnd,i) (int)SNDMSG((hwnd),HDM_SETFILTERCHANGETIMEOUT,0,(LPARAM)(i)) + +#define HDM_EDITFILTER (HDM_FIRST+23) +#define Header_EditFilter(hwnd,i,fDiscardChanges) (int)SNDMSG((hwnd),HDM_EDITFILTER,(WPARAM)(i),MAKELPARAM(fDiscardChanges,0)) + +#define HDM_CLEARFILTER (HDM_FIRST+24) +#define Header_ClearFilter(hwnd,i) (int)SNDMSG((hwnd),HDM_CLEARFILTER,(WPARAM)(i),0) +#define Header_ClearAllFilters(hwnd) (int)SNDMSG((hwnd),HDM_CLEARFILTER,(WPARAM)-1,0) + +#define HDN_ITEMCHANGINGA (HDN_FIRST-0) +#define HDN_ITEMCHANGINGW (HDN_FIRST-20) +#define HDN_ITEMCHANGEDA (HDN_FIRST-1) +#define HDN_ITEMCHANGEDW (HDN_FIRST-21) +#define HDN_ITEMCLICKA (HDN_FIRST-2) +#define HDN_ITEMCLICKW (HDN_FIRST-22) +#define HDN_ITEMDBLCLICKA (HDN_FIRST-3) +#define HDN_ITEMDBLCLICKW (HDN_FIRST-23) +#define HDN_DIVIDERDBLCLICKA (HDN_FIRST-5) +#define HDN_DIVIDERDBLCLICKW (HDN_FIRST-25) +#define HDN_BEGINTRACKA (HDN_FIRST-6) +#define HDN_BEGINTRACKW (HDN_FIRST-26) +#define HDN_ENDTRACKA (HDN_FIRST-7) +#define HDN_ENDTRACKW (HDN_FIRST-27) +#define HDN_TRACKA (HDN_FIRST-8) +#define HDN_TRACKW (HDN_FIRST-28) +#define HDN_GETDISPINFOA (HDN_FIRST-9) +#define HDN_GETDISPINFOW (HDN_FIRST-29) +#define HDN_BEGINDRAG (HDN_FIRST-10) +#define HDN_ENDDRAG (HDN_FIRST-11) +#define HDN_FILTERCHANGE (HDN_FIRST-12) +#define HDN_FILTERBTNCLICK (HDN_FIRST-13) + +#ifdef UNICODE +#define HDN_ITEMCHANGING HDN_ITEMCHANGINGW +#define HDN_ITEMCHANGED HDN_ITEMCHANGEDW +#define HDN_ITEMCLICK HDN_ITEMCLICKW +#define HDN_ITEMDBLCLICK HDN_ITEMDBLCLICKW +#define HDN_DIVIDERDBLCLICK HDN_DIVIDERDBLCLICKW +#define HDN_BEGINTRACK HDN_BEGINTRACKW +#define HDN_ENDTRACK HDN_ENDTRACKW +#define HDN_TRACK HDN_TRACKW +#define HDN_GETDISPINFO HDN_GETDISPINFOW +#else +#define HDN_ITEMCHANGING HDN_ITEMCHANGINGA +#define HDN_ITEMCHANGED HDN_ITEMCHANGEDA +#define HDN_ITEMCLICK HDN_ITEMCLICKA +#define HDN_ITEMDBLCLICK HDN_ITEMDBLCLICKA +#define HDN_DIVIDERDBLCLICK HDN_DIVIDERDBLCLICKA +#define HDN_BEGINTRACK HDN_BEGINTRACKA +#define HDN_ENDTRACK HDN_ENDTRACKA +#define HDN_TRACK HDN_TRACKA +#define HDN_GETDISPINFO HDN_GETDISPINFOA +#endif + +#define HD_NOTIFYA NMHEADERA +#define HD_NOTIFYW NMHEADERW +#define HD_NOTIFY NMHEADER + + typedef struct tagNMHEADERA { + NMHDR hdr; + int iItem; + int iButton; HDITEMA *pitem; -} NMHEADERA, *LPNMHEADERA; + } NMHEADERA,*LPNMHEADERA; -typedef struct tagNMHEADERW -{ - NMHDR hdr; - INT iItem; - INT iButton; + typedef struct tagNMHEADERW { + NMHDR hdr; + int iItem; + int iButton; HDITEMW *pitem; -} NMHEADERW, *LPNMHEADERW; + } NMHEADERW,*LPNMHEADERW; -#define NMHEADER WINELIB_NAME_AW(NMHEADER) -#define LPNMHEADER WINELIB_NAME_AW(LPNMHEADER) -#define HD_NOTIFY NMHEADER +#ifdef UNICODE +#define NMHEADER NMHEADERW +#define LPNMHEADER LPNMHEADERW +#else +#define NMHEADER NMHEADERA +#define LPNMHEADER LPNMHEADERA +#endif -typedef struct tagNMHDDISPINFOA -{ - NMHDR hdr; - INT iItem; - UINT mask; - LPSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; -} NMHDDISPINFOA, *LPNMHDDISPINFOA; + typedef struct tagNMHDDISPINFOW { + NMHDR hdr; + int iItem; + UINT mask; + LPWSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + } NMHDDISPINFOW,*LPNMHDDISPINFOW; -typedef struct tagNMHDDISPINFOW -{ - NMHDR hdr; - INT iItem; - UINT mask; - LPWSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; -} NMHDDISPINFOW, *LPNMHDDISPINFOW; + typedef struct tagNMHDDISPINFOA { + NMHDR hdr; + int iItem; + UINT mask; + LPSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + } NMHDDISPINFOA,*LPNMHDDISPINFOA; -#define NMHDDISPINFO WINELIB_NAME_AW(NMHDDISPINFO) -#define LPNMHDDISPINFO WINELIB_NAME_AW(LPNMHDDISPINFO) +#ifdef UNICODE +#define NMHDDISPINFO NMHDDISPINFOW +#define LPNMHDDISPINFO LPNMHDDISPINFOW +#else +#define NMHDDISPINFO NMHDDISPINFOA +#define LPNMHDDISPINFO LPNMHDDISPINFOA +#endif -typedef struct tagNMHDFILTERBTNCLICK -{ + typedef struct tagNMHDFILTERBTNCLICK { NMHDR hdr; INT iItem; RECT rc; -} NMHDFILTERBTNCLICK, *LPNMHDFILTERBTNCLICK; + } NMHDFILTERBTNCLICK,*LPNMHDFILTERBTNCLICK; +#endif -#define Header_GetItemCount(hwndHD) \ - (INT)SNDMSG((hwndHD),HDM_GETITEMCOUNT,0,0L) -#define Header_InsertItemA(hwndHD,i,phdi) \ - (INT)SNDMSGA((hwndHD),HDM_INSERTITEMA,(WPARAM)(INT)(i),(LPARAM)(const HDITEMA*)(phdi)) -#define Header_InsertItemW(hwndHD,i,phdi) \ - (INT)SNDMSGW((hwndHD),HDM_INSERTITEMW,(WPARAM)(INT)(i),(LPARAM)(const HDITEMW*)(phdi)) -#define Header_InsertItem WINELIB_NAME_AW(Header_InsertItem) -#define Header_DeleteItem(hwndHD,i) \ - (BOOL)SNDMSG((hwndHD),HDM_DELETEITEM,(WPARAM)(INT)(i),0L) -#define Header_GetItemA(hwndHD,i,phdi) \ - (BOOL)SNDMSGA((hwndHD),HDM_GETITEMA,(WPARAM)(INT)(i),(LPARAM)(HDITEMA*)(phdi)) -#define Header_GetItemW(hwndHD,i,phdi) \ - (BOOL)SNDMSGW((hwndHD),HDM_GETITEMW,(WPARAM)(INT)(i),(LPARAM)(HDITEMW*)(phdi)) -#define Header_GetItem WINELIB_NAME_AW(Header_GetItem) -#define Header_SetItemA(hwndHD,i,phdi) \ - (BOOL)SNDMSGA((hwndHD),HDM_SETITEMA,(WPARAM)(INT)(i),(LPARAM)(const HDITEMA*)(phdi)) -#define Header_SetItemW(hwndHD,i,phdi) \ - (BOOL)SNDMSGW((hwndHD),HDM_SETITEMW,(WPARAM)(INT)(i),(LPARAM)(const HDITEMW*)(phdi)) -#define Header_SetItem WINELIB_NAME_AW(Header_SetItem) -#define Header_Layout(hwndHD,playout) \ - (BOOL)SNDMSG((hwndHD),HDM_LAYOUT,0,(LPARAM)(LPHDLAYOUT)(playout)) -#define Header_GetItemRect(hwnd,iItem,lprc) \ - (BOOL)SNDMSG((hwnd),HDM_GETITEMRECT,(WPARAM)iItem,(LPARAM)lprc) -#define Header_SetImageList(hwnd,himl) \ - (HIMAGELIST)SNDMSG((hwnd),HDM_SETIMAGELIST,0,(LPARAM)himl) -#define Header_GetImageList(hwnd) \ - (HIMAGELIST)SNDMSG((hwnd),HDM_GETIMAGELIST,0,0) -#define Header_OrderToIndex(hwnd,i) \ - (INT)SNDMSG((hwnd),HDM_ORDERTOINDEX,(WPARAM)i,0) -#define Header_CreateDragImage(hwnd,i) \ - (HIMAGELIST)SNDMSG((hwnd),HDM_CREATEDRAGIMAGE,(WPARAM)i,0) -#define Header_GetOrderArray(hwnd,iCount,lpi) \ - (BOOL)SNDMSG((hwnd),HDM_GETORDERARRAY,(WPARAM)iCount,(LPARAM)lpi) -#define Header_SetOrderArray(hwnd,iCount,lpi) \ - (BOOL)SNDMSG((hwnd),HDM_SETORDERARRAY,(WPARAM)iCount,(LPARAM)lpi) -#define Header_SetHotDivider(hwnd,fPos,dw) \ - (INT)SNDMSG((hwnd),HDM_SETHOTDIVIDER,(WPARAM)fPos,(LPARAM)dw) -#define Header_SetUnicodeFormat(hwnd,fUnicode) \ - (BOOL)SNDMSG((hwnd),HDM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) -#define Header_GetUnicodeFormat(hwnd) \ - (BOOL)SNDMSG((hwnd),HDM_GETUNICODEFORMAT,0,0) +#ifndef NOTOOLBAR -/* Win32 5.1 Button Theme */ -#define WC_BUTTONA "Button" -# define WC_BUTTONW L"Button" -#define WC_BUTTON WINELIB_NAME_AW(WC_BUTTON) +#define TOOLBARCLASSNAMEW L"ToolbarWindow32" +#define TOOLBARCLASSNAMEA "ToolbarWindow32" -#define BCN_FIRST (0U-1250U) -#define BCN_LAST (0U-1350U) +#ifdef UNICODE +#define TOOLBARCLASSNAME TOOLBARCLASSNAMEW +#else +#define TOOLBARCLASSNAME TOOLBARCLASSNAMEA +#endif -#define BCN_HOTITEMCHANGE (BCN_FIRST + 0x0001) + typedef struct _TBBUTTON { + int iBitmap; + int idCommand; + BYTE fsState; + BYTE fsStyle; +#ifdef _WIN64 + BYTE bReserved[6]; +#else + BYTE bReserved[2]; +#endif + DWORD_PTR dwData; + INT_PTR iString; + } TBBUTTON,NEAR *PTBBUTTON,*LPTBBUTTON; + typedef const TBBUTTON *LPCTBBUTTON; -typedef struct tagNMBCHOTITEM -{ - NMHDR hdr; - DWORD dwFlags; -} NMBCHOTITEM, *LPNMBCHOTITEM; + typedef struct _COLORMAP { + COLORREF from; + COLORREF to; + } COLORMAP,*LPCOLORMAP; -#define BST_HOT 0x0200 + WINCOMMCTRLAPI HWND WINAPI CreateToolbarEx(HWND hwnd,DWORD ws,UINT wID,int nBitmaps,HINSTANCE hBMInst,UINT_PTR wBMID,LPCTBBUTTON lpButtons,int iNumButtons,int dxButton,int dyButton,int dxBitmap,int dyBitmap,UINT uStructSize); + WINCOMMCTRLAPI HBITMAP WINAPI CreateMappedBitmap(HINSTANCE hInstance,INT_PTR idBitmap,UINT wFlags,LPCOLORMAP lpColorMap,int iNumMaps); -/* Toolbar */ +#define CMB_MASKED 0x2 +#define TBSTATE_CHECKED 0x1 +#define TBSTATE_PRESSED 0x2 +#define TBSTATE_ENABLED 0x4 +#define TBSTATE_HIDDEN 0x8 +#define TBSTATE_INDETERMINATE 0x10 +#define TBSTATE_WRAP 0x20 +#define TBSTATE_ELLIPSES 0x40 +#define TBSTATE_MARKED 0x80 -#define TOOLBARCLASSNAMEA "ToolbarWindow32" -# define TOOLBARCLASSNAMEW L"ToolbarWindow32" +#define TBSTYLE_BUTTON 0x0 +#define TBSTYLE_SEP 0x1 +#define TBSTYLE_CHECK 0x2 +#define TBSTYLE_GROUP 0x4 +#define TBSTYLE_CHECKGROUP (TBSTYLE_GROUP | TBSTYLE_CHECK) +#define TBSTYLE_DROPDOWN 0x8 +#define TBSTYLE_AUTOSIZE 0x10 +#define TBSTYLE_NOPREFIX 0x20 +#define TBSTYLE_TOOLTIPS 0x100 +#define TBSTYLE_WRAPABLE 0x200 +#define TBSTYLE_ALTDRAG 0x400 +#define TBSTYLE_FLAT 0x800 +#define TBSTYLE_LIST 0x1000 +#define TBSTYLE_CUSTOMERASE 0x2000 +#define TBSTYLE_REGISTERDROP 0x4000 +#define TBSTYLE_TRANSPARENT 0x8000 +#define TBSTYLE_EX_DRAWDDARROWS 0x1 -#define TOOLBARCLASSNAME WINELIB_NAME_AW(TOOLBARCLASSNAME) +#define BTNS_BUTTON TBSTYLE_BUTTON +#define BTNS_SEP TBSTYLE_SEP +#define BTNS_CHECK TBSTYLE_CHECK +#define BTNS_GROUP TBSTYLE_GROUP +#define BTNS_CHECKGROUP TBSTYLE_CHECKGROUP +#define BTNS_DROPDOWN TBSTYLE_DROPDOWN +#define BTNS_AUTOSIZE TBSTYLE_AUTOSIZE +#define BTNS_NOPREFIX TBSTYLE_NOPREFIX +#define BTNS_SHOWTEXT 0x40 +#define BTNS_WHOLEDROPDOWN 0x80 -#define CMB_MASKED 0x02 +#define TBSTYLE_EX_MIXEDBUTTONS 0x8 +#define TBSTYLE_EX_HIDECLIPPEDBUTTONS 0x10 +#define TBSTYLE_EX_DOUBLEBUFFER 0x80 -#define TBSTATE_CHECKED 0x01 -#define TBSTATE_PRESSED 0x02 -#define TBSTATE_ENABLED 0x04 -#define TBSTATE_HIDDEN 0x08 -#define TBSTATE_INDETERMINATE 0x10 -#define TBSTATE_WRAP 0x20 -#define TBSTATE_ELLIPSES 0x40 -#define TBSTATE_MARKED 0x80 - - -/* as of _WIN32_IE >= 0x0500 the following symbols are obsolete, - * "everyone" should use the BTNS_... stuff below - */ -#define TBSTYLE_BUTTON 0x00 -#define TBSTYLE_SEP 0x01 -#define TBSTYLE_CHECK 0x02 -#define TBSTYLE_GROUP 0x04 -#define TBSTYLE_CHECKGROUP (TBSTYLE_GROUP | TBSTYLE_CHECK) -#define TBSTYLE_DROPDOWN 0x08 -#define TBSTYLE_AUTOSIZE 0x10 -#define TBSTYLE_NOPREFIX 0x20 -#define BTNS_BUTTON TBSTYLE_BUTTON -#define BTNS_SEP TBSTYLE_SEP -#define BTNS_CHECK TBSTYLE_CHECK -#define BTNS_GROUP TBSTYLE_GROUP -#define BTNS_CHECKGROUP TBSTYLE_CHECKGROUP -#define BTNS_DROPDOWN TBSTYLE_DROPDOWN -#define BTNS_AUTOSIZE TBSTYLE_AUTOSIZE -#define BTNS_NOPREFIX TBSTYLE_NOPREFIX -#define BTNS_SHOWTEXT 0x40 /* ignored unless TBSTYLE_EX_MIXEDB set */ -#define BTNS_WHOLEDROPDOWN 0x80 /* draw dropdown arrow, but without split arrow section */ - -#define TBSTYLE_TOOLTIPS 0x0100 -#define TBSTYLE_WRAPABLE 0x0200 -#define TBSTYLE_ALTDRAG 0x0400 -#define TBSTYLE_FLAT 0x0800 -#define TBSTYLE_LIST 0x1000 -#define TBSTYLE_CUSTOMERASE 0x2000 -#define TBSTYLE_REGISTERDROP 0x4000 -#define TBSTYLE_TRANSPARENT 0x8000 -#define TBSTYLE_EX_DRAWDDARROWS 0x00000001 -#define TBSTYLE_EX_UNDOC1 0x00000004 /* similar to TBSTYLE_WRAPABLE */ -#define TBSTYLE_EX_MIXEDBUTTONS 0x00000008 -#define TBSTYLE_EX_HIDECLIPPEDBUTTONS 0x00000010 /* don't show partially obscured buttons */ -#define TBSTYLE_EX_DOUBLEBUFFER 0x00000080 /* Double Buffer the toolbar */ - -#define TBIF_IMAGE 0x00000001 -#define TBIF_TEXT 0x00000002 -#define TBIF_STATE 0x00000004 -#define TBIF_STYLE 0x00000008 -#define TBIF_LPARAM 0x00000010 -#define TBIF_COMMAND 0x00000020 -#define TBIF_SIZE 0x00000040 -#define TBIF_BYINDEX 0x80000000 - -#define TBBF_LARGE 0x0001 - -#define TB_ENABLEBUTTON (WM_USER+1) -#define TB_CHECKBUTTON (WM_USER+2) -#define TB_PRESSBUTTON (WM_USER+3) -#define TB_HIDEBUTTON (WM_USER+4) -#define TB_INDETERMINATE (WM_USER+5) -#define TB_MARKBUTTON (WM_USER+6) -#define TB_ISBUTTONENABLED (WM_USER+9) -#define TB_ISBUTTONCHECKED (WM_USER+10) -#define TB_ISBUTTONPRESSED (WM_USER+11) -#define TB_ISBUTTONHIDDEN (WM_USER+12) -#define TB_ISBUTTONINDETERMINATE (WM_USER+13) -#define TB_ISBUTTONHIGHLIGHTED (WM_USER+14) -#define TB_SETSTATE (WM_USER+17) -#define TB_GETSTATE (WM_USER+18) -#define TB_ADDBITMAP (WM_USER+19) -#define TB_ADDBUTTONSA (WM_USER+20) -#define TB_ADDBUTTONSW (WM_USER+68) -#define TB_ADDBUTTONS WINELIB_NAME_AW(TB_ADDBUTTONS) -#define TB_HITTEST (WM_USER+69) -#define TB_INSERTBUTTONA (WM_USER+21) -#define TB_INSERTBUTTONW (WM_USER+67) -#define TB_INSERTBUTTON WINELIB_NAME_AW(TB_INSERTBUTTON) -#define TB_DELETEBUTTON (WM_USER+22) -#define TB_GETBUTTON (WM_USER+23) -#define TB_BUTTONCOUNT (WM_USER+24) -#define TB_COMMANDTOINDEX (WM_USER+25) -#define TB_SAVERESTOREA (WM_USER+26) -#define TB_SAVERESTOREW (WM_USER+76) -#define TB_SAVERESTORE WINELIB_NAME_AW(TB_SAVERESTORE) -#define TB_CUSTOMIZE (WM_USER+27) -#define TB_ADDSTRINGA (WM_USER+28) -#define TB_ADDSTRINGW (WM_USER+77) -#define TB_ADDSTRING WINELIB_NAME_AW(TB_ADDSTRING) -#define TB_GETITEMRECT (WM_USER+29) -#define TB_BUTTONSTRUCTSIZE (WM_USER+30) -#define TB_SETBUTTONSIZE (WM_USER+31) -#define TB_SETBITMAPSIZE (WM_USER+32) -#define TB_AUTOSIZE (WM_USER+33) -#define TB_GETTOOLTIPS (WM_USER+35) -#define TB_SETTOOLTIPS (WM_USER+36) -#define TB_SETPARENT (WM_USER+37) -#define TB_SETROWS (WM_USER+39) -#define TB_GETROWS (WM_USER+40) -#define TB_GETBITMAPFLAGS (WM_USER+41) -#define TB_SETCMDID (WM_USER+42) -#define TB_CHANGEBITMAP (WM_USER+43) -#define TB_GETBITMAP (WM_USER+44) -#define TB_GETBUTTONTEXTA (WM_USER+45) -#define TB_GETBUTTONTEXTW (WM_USER+75) -#define TB_GETBUTTONTEXT WINELIB_NAME_AW(TB_GETBUTTONTEXT) -#define TB_REPLACEBITMAP (WM_USER+46) -#define TB_SETINDENT (WM_USER+47) -#define TB_SETIMAGELIST (WM_USER+48) -#define TB_GETIMAGELIST (WM_USER+49) -#define TB_LOADIMAGES (WM_USER+50) -#define TB_GETRECT (WM_USER+51) /* wParam is the Cmd instead of index */ -#define TB_SETHOTIMAGELIST (WM_USER+52) -#define TB_GETHOTIMAGELIST (WM_USER+53) -#define TB_SETDISABLEDIMAGELIST (WM_USER+54) -#define TB_GETDISABLEDIMAGELIST (WM_USER+55) -#define TB_SETSTYLE (WM_USER+56) -#define TB_GETSTYLE (WM_USER+57) -#define TB_GETBUTTONSIZE (WM_USER+58) -#define TB_SETBUTTONWIDTH (WM_USER+59) -#define TB_SETMAXTEXTROWS (WM_USER+60) -#define TB_GETTEXTROWS (WM_USER+61) -#define TB_GETOBJECT (WM_USER+62) -#define TB_GETBUTTONINFOW (WM_USER+63) -#define TB_GETBUTTONINFOA (WM_USER+65) -#define TB_GETBUTTONINFO WINELIB_NAME_AW(TB_GETBUTTONINFO) -#define TB_SETBUTTONINFOW (WM_USER+64) -#define TB_SETBUTTONINFOA (WM_USER+66) -#define TB_SETBUTTONINFO WINELIB_NAME_AW(TB_SETBUTTONINFO) -#define TB_SETDRAWTEXTFLAGS (WM_USER+70) -#define TB_GETHOTITEM (WM_USER+71) -#define TB_SETHOTITEM (WM_USER+72) -#define TB_SETANCHORHIGHLIGHT (WM_USER+73) -#define TB_GETANCHORHIGHLIGHT (WM_USER+74) -#define TB_MAPACCELERATORA (WM_USER+78) -#define TB_MAPACCELERATORW (WM_USER+90) -#define TB_MAPACCELERATOR WINELIB_NAME_AW(TB_MAPACCELERATOR) -#define TB_GETINSERTMARK (WM_USER+79) -#define TB_SETINSERTMARK (WM_USER+80) -#define TB_INSERTMARKHITTEST (WM_USER+81) -#define TB_MOVEBUTTON (WM_USER+82) -#define TB_GETMAXSIZE (WM_USER+83) -#define TB_SETEXTENDEDSTYLE (WM_USER+84) -#define TB_GETEXTENDEDSTYLE (WM_USER+85) -#define TB_GETPADDING (WM_USER+86) -#define TB_SETPADDING (WM_USER+87) -#define TB_SETINSERTMARKCOLOR (WM_USER+88) -#define TB_GETINSERTMARKCOLOR (WM_USER+89) -#define TB_SETCOLORSCHEME CCM_SETCOLORSCHEME -#define TB_GETCOLORSCHEME CCM_GETCOLORSCHEME -#define TB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define TB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define TB_GETSTRINGW (WM_USER+91) -#define TB_GETSTRINGA (WM_USER+92) -#define TB_GETSTRING WINELIB_NAME_AW(TB_GETSTRING) - -/* undocumented messages in Toolbar */ -/* #ifdef __WINESRC__ */ -#define TB_UNKWN45D (WM_USER+93) -#define TB_SETHOTITEM2 (WM_USER+94) -#define TB_SETLISTGAP (WM_USER+96) -#define TB_GETIMAGELISTCOUNT (WM_USER+98) -#define TB_GETIDEALSIZE (WM_USER+99) -#define TB_UNKWN464 (WM_USER+100) -/* #endif */ - -#define TB_GETMETRICS (WM_USER+101) -#define TB_SETMETRICS (WM_USER+102) -#define TB_SETWINDOWTHEME CCM_SETWINDOWTHEME - -#define TBN_FIRST (0U-700U) -#define TBN_LAST (0U-720U) -#define TBN_GETBUTTONINFOA (TBN_FIRST-0) -#define TBN_GETBUTTONINFOW (TBN_FIRST-20) -#define TBN_GETBUTTONINFO WINELIB_NAME_AW(TBN_GETBUTTONINFO) -#define TBN_BEGINDRAG (TBN_FIRST-1) -#define TBN_ENDDRAG (TBN_FIRST-2) -#define TBN_BEGINADJUST (TBN_FIRST-3) -#define TBN_ENDADJUST (TBN_FIRST-4) -#define TBN_RESET (TBN_FIRST-5) -#define TBN_QUERYINSERT (TBN_FIRST-6) -#define TBN_QUERYDELETE (TBN_FIRST-7) -#define TBN_TOOLBARCHANGE (TBN_FIRST-8) -#define TBN_CUSTHELP (TBN_FIRST-9) -#define TBN_DROPDOWN (TBN_FIRST-10) -#define TBN_GETOBJECT (TBN_FIRST-12) -#define TBN_HOTITEMCHANGE (TBN_FIRST-13) -#define TBN_DRAGOUT (TBN_FIRST-14) -#define TBN_DELETINGBUTTON (TBN_FIRST-15) -#define TBN_GETDISPINFOA (TBN_FIRST-16) -#define TBN_GETDISPINFOW (TBN_FIRST-17) -#define TBN_GETDISPINFO WINELIB_NAME_AW(TBN_GETDISPINFO) -#define TBN_GETINFOTIPA (TBN_FIRST-18) -#define TBN_GETINFOTIPW (TBN_FIRST-19) -#define TBN_GETINFOTIP WINELIB_NAME_AW(TBN_GETINFOTIP) -#define TBN_RESTORE (TBN_FIRST-21) -#define TBN_SAVE (TBN_FIRST-22) -#define TBN_INITCUSTOMIZE (TBN_FIRST-23) -#define TBN_WRAPHOTITEM (TBN_FIRST-24) /* this is undocumented and the name is a guess */ -#define TBNRF_HIDEHELP 0x00000001 - - -/* Return values from TBN_DROPDOWN */ -#define TBDDRET_DEFAULT 0 -#define TBDDRET_NODEFAULT 1 -#define TBDDRET_TREATPRESSED 2 - -typedef struct _NMTBCUSTOMDRAW -{ + typedef struct _NMTBCUSTOMDRAW { NMCUSTOMDRAW nmcd; HBRUSH hbrMonoDither; HBRUSH hbrLines; @@ -1263,183 +861,409 @@ typedef struct _NMTBCUSTOMDRAW int nStringBkMode; int nHLStringBkMode; int iListGap; -} NMTBCUSTOMDRAW, *LPNMTBCUSTOMDRAW; + } NMTBCUSTOMDRAW,*LPNMTBCUSTOMDRAW; -/* return flags for Toolbar NM_CUSTOMDRAW notifications */ -#define TBCDRF_NOEDGES 0x00010000 /* Don't draw button edges */ -#define TBCDRF_HILITEHOTTRACK 0x00020000 /* Use color of the button bkgnd */ - /* when hottracked */ -#define TBCDRF_NOOFFSET 0x00040000 /* No offset button if pressed */ -#define TBCDRF_NOMARK 0x00080000 /* Don't draw default highlight */ - /* for TBSTATE_MARKED */ -#define TBCDRF_NOETCHEDEFFECT 0x00100000 /* No etched effect for */ - /* disabled items */ -#define TBCDRF_BLENDICON 0x00200000 /* ILD_BLEND50 on the icon image */ -#define TBCDRF_NOBACKGROUND 0x00400000 /* ILD_BLEND50 on the icon image */ -#define TBCDRF_USECDCOLORS 0x00800000 +#define TBCDRF_NOEDGES 0x10000 +#define TBCDRF_HILITEHOTTRACK 0x20000 +#define TBCDRF_NOOFFSET 0x40000 +#define TBCDRF_NOMARK 0x80000 +#define TBCDRF_NOETCHEDEFFECT 0x100000 +#define TBCDRF_BLENDICON 0x200000 +#define TBCDRF_NOBACKGROUND 0x400000 -/* This is just for old CreateToolbar. */ -/* Don't use it in new programs. */ -typedef struct _OLDTBBUTTON { - INT iBitmap; - INT idCommand; - BYTE fsState; - BYTE fsStyle; - BYTE bReserved[2]; - DWORD dwData; -} OLDTBBUTTON, *POLDTBBUTTON, *LPOLDTBBUTTON; -typedef const OLDTBBUTTON *LPCOLDTBBUTTON; +#define TB_ENABLEBUTTON (WM_USER+1) +#define TB_CHECKBUTTON (WM_USER+2) +#define TB_PRESSBUTTON (WM_USER+3) +#define TB_HIDEBUTTON (WM_USER+4) +#define TB_INDETERMINATE (WM_USER+5) +#define TB_MARKBUTTON (WM_USER+6) +#define TB_ISBUTTONENABLED (WM_USER+9) +#define TB_ISBUTTONCHECKED (WM_USER+10) +#define TB_ISBUTTONPRESSED (WM_USER+11) +#define TB_ISBUTTONHIDDEN (WM_USER+12) +#define TB_ISBUTTONINDETERMINATE (WM_USER+13) +#define TB_ISBUTTONHIGHLIGHTED (WM_USER+14) +#define TB_SETSTATE (WM_USER+17) +#define TB_GETSTATE (WM_USER+18) +#define TB_ADDBITMAP (WM_USER+19) - -typedef struct _TBBUTTON { - INT iBitmap; - INT idCommand; - BYTE fsState; - BYTE fsStyle; -#ifdef _WIN64 - BYTE bReserved[6]; -#else - BYTE bReserved[2]; -#endif - DWORD_PTR dwData; - INT_PTR iString; -} TBBUTTON, *PTBBUTTON, *LPTBBUTTON; -typedef const TBBUTTON *LPCTBBUTTON; - - -typedef struct _COLORMAP { - COLORREF from; - COLORREF to; -} COLORMAP, *LPCOLORMAP; - - -typedef struct tagTBADDBITMAP { + typedef struct tagTBADDBITMAP { HINSTANCE hInst; - UINT_PTR nID; -} TBADDBITMAP, *LPTBADDBITMAP; + UINT_PTR nID; + } TBADDBITMAP,*LPTBADDBITMAP; -#define HINST_COMMCTRL ((HINSTANCE)-1) -#define IDB_STD_SMALL_COLOR 0 -#define IDB_STD_LARGE_COLOR 1 -#define IDB_VIEW_SMALL_COLOR 4 -#define IDB_VIEW_LARGE_COLOR 5 -#define IDB_HIST_SMALL_COLOR 8 -#define IDB_HIST_LARGE_COLOR 9 +#define HINST_COMMCTRL ((HINSTANCE)-1) +#define IDB_STD_SMALL_COLOR 0 +#define IDB_STD_LARGE_COLOR 1 +#define IDB_VIEW_SMALL_COLOR 4 +#define IDB_VIEW_LARGE_COLOR 5 +#define IDB_HIST_SMALL_COLOR 8 +#define IDB_HIST_LARGE_COLOR 9 -#define STD_CUT 0 -#define STD_COPY 1 -#define STD_PASTE 2 -#define STD_UNDO 3 -#define STD_REDOW 4 -#define STD_DELETE 5 -#define STD_FILENEW 6 -#define STD_FILEOPEN 7 -#define STD_FILESAVE 8 -#define STD_PRINTPRE 9 -#define STD_PROPERTIES 10 -#define STD_HELP 11 -#define STD_FIND 12 -#define STD_REPLACE 13 -#define STD_PRINT 14 +#define STD_CUT 0 +#define STD_COPY 1 +#define STD_PASTE 2 +#define STD_UNDO 3 +#define STD_REDOW 4 +#define STD_DELETE 5 +#define STD_FILENEW 6 +#define STD_FILEOPEN 7 +#define STD_FILESAVE 8 +#define STD_PRINTPRE 9 +#define STD_PROPERTIES 10 +#define STD_HELP 11 +#define STD_FIND 12 +#define STD_REPLACE 13 +#define STD_PRINT 14 -#define VIEW_LARGEICONS 0 -#define VIEW_SMALLICONS 1 -#define VIEW_LIST 2 -#define VIEW_DETAILS 3 -#define VIEW_SORTNAME 4 -#define VIEW_SORTSIZE 5 -#define VIEW_SORTDATE 6 -#define VIEW_SORTTYPE 7 -#define VIEW_PARENTFOLDER 8 -#define VIEW_NETCONNECT 9 -#define VIEW_NETDISCONNECT 10 -#define VIEW_NEWFOLDER 11 -#define VIEW_VIEWMENU 12 +#define VIEW_LARGEICONS 0 +#define VIEW_SMALLICONS 1 +#define VIEW_LIST 2 +#define VIEW_DETAILS 3 +#define VIEW_SORTNAME 4 +#define VIEW_SORTSIZE 5 +#define VIEW_SORTDATE 6 +#define VIEW_SORTTYPE 7 +#define VIEW_PARENTFOLDER 8 +#define VIEW_NETCONNECT 9 +#define VIEW_NETDISCONNECT 10 +#define VIEW_NEWFOLDER 11 +#define VIEW_VIEWMENU 12 +#define HIST_BACK 0 +#define HIST_FORWARD 1 +#define HIST_FAVORITES 2 +#define HIST_ADDTOFAVORITES 3 +#define HIST_VIEWTREE 4 -#define HIST_BACK 0 -#define HIST_FORWARD 1 -#define HIST_FAVORITES 2 -#define HIST_ADDTOFAVORITES 3 -#define HIST_VIEWTREE 4 +#define TB_ADDBUTTONSA (WM_USER+20) +#define TB_INSERTBUTTONA (WM_USER+21) +#define TB_DELETEBUTTON (WM_USER+22) +#define TB_GETBUTTON (WM_USER+23) +#define TB_BUTTONCOUNT (WM_USER+24) +#define TB_COMMANDTOINDEX (WM_USER+25) -typedef struct tagTBSAVEPARAMSA { - HKEY hkr; + typedef struct tagTBSAVEPARAMSA { + HKEY hkr; LPCSTR pszSubKey; LPCSTR pszValueName; -} TBSAVEPARAMSA, *LPTBSAVEPARAMSA; + } TBSAVEPARAMSA,*LPTBSAVEPARAMSA; -typedef struct tagTBSAVEPARAMSW { - HKEY hkr; + typedef struct tagTBSAVEPARAMSW { + HKEY hkr; LPCWSTR pszSubKey; LPCWSTR pszValueName; -} TBSAVEPARAMSW, *LPTBSAVEPARAMSW; + } TBSAVEPARAMSW,*LPTBSAVEPARAMW; -#define TBSAVEPARAMS WINELIB_NAME_AW(TBSAVEPARAMS) -#define LPTBSAVEPARAMS WINELIB_NAME_AW(LPTBSAVEPARAMS) +#ifdef UNICODE +#define TBSAVEPARAMS TBSAVEPARAMSW +#define LPTBSAVEPARAMS LPTBSAVEPARAMSW +#else +#define TBSAVEPARAMS TBSAVEPARAMSA +#define LPTBSAVEPARAMS LPTBSAVEPARAMSA +#endif -typedef struct -{ +#define TB_SAVERESTOREA (WM_USER+26) +#define TB_SAVERESTOREW (WM_USER+76) +#define TB_CUSTOMIZE (WM_USER+27) +#define TB_ADDSTRINGA (WM_USER+28) +#define TB_ADDSTRINGW (WM_USER+77) +#define TB_GETITEMRECT (WM_USER+29) +#define TB_BUTTONSTRUCTSIZE (WM_USER+30) +#define TB_SETBUTTONSIZE (WM_USER+31) +#define TB_SETBITMAPSIZE (WM_USER+32) +#define TB_AUTOSIZE (WM_USER+33) +#define TB_GETTOOLTIPS (WM_USER+35) +#define TB_SETTOOLTIPS (WM_USER+36) +#define TB_SETPARENT (WM_USER+37) +#define TB_SETROWS (WM_USER+39) +#define TB_GETROWS (WM_USER+40) +#define TB_SETCMDID (WM_USER+42) +#define TB_CHANGEBITMAP (WM_USER+43) +#define TB_GETBITMAP (WM_USER+44) +#define TB_GETBUTTONTEXTA (WM_USER+45) +#define TB_GETBUTTONTEXTW (WM_USER+75) +#define TB_REPLACEBITMAP (WM_USER+46) +#define TB_SETINDENT (WM_USER+47) +#define TB_SETIMAGELIST (WM_USER+48) +#define TB_GETIMAGELIST (WM_USER+49) +#define TB_LOADIMAGES (WM_USER+50) +#define TB_GETRECT (WM_USER+51) +#define TB_SETHOTIMAGELIST (WM_USER+52) +#define TB_GETHOTIMAGELIST (WM_USER+53) +#define TB_SETDISABLEDIMAGELIST (WM_USER+54) +#define TB_GETDISABLEDIMAGELIST (WM_USER+55) +#define TB_SETSTYLE (WM_USER+56) +#define TB_GETSTYLE (WM_USER+57) +#define TB_GETBUTTONSIZE (WM_USER+58) +#define TB_SETBUTTONWIDTH (WM_USER+59) +#define TB_SETMAXTEXTROWS (WM_USER+60) +#define TB_GETTEXTROWS (WM_USER+61) + +#ifdef UNICODE +#define TB_GETBUTTONTEXT TB_GETBUTTONTEXTW +#define TB_SAVERESTORE TB_SAVERESTOREW +#define TB_ADDSTRING TB_ADDSTRINGW +#else +#define TB_GETBUTTONTEXT TB_GETBUTTONTEXTA +#define TB_SAVERESTORE TB_SAVERESTOREA +#define TB_ADDSTRING TB_ADDSTRINGA +#endif +#define TB_GETOBJECT (WM_USER+62) +#define TB_GETHOTITEM (WM_USER+71) +#define TB_SETHOTITEM (WM_USER+72) +#define TB_SETANCHORHIGHLIGHT (WM_USER+73) +#define TB_GETANCHORHIGHLIGHT (WM_USER+74) +#define TB_MAPACCELERATORA (WM_USER+78) + + typedef struct { + int iButton; + DWORD dwFlags; + } TBINSERTMARK,*LPTBINSERTMARK; +#define TBIMHT_AFTER 0x1 +#define TBIMHT_BACKGROUND 0x2 + +#define TB_GETINSERTMARK (WM_USER+79) +#define TB_SETINSERTMARK (WM_USER+80) +#define TB_INSERTMARKHITTEST (WM_USER+81) +#define TB_MOVEBUTTON (WM_USER+82) +#define TB_GETMAXSIZE (WM_USER+83) +#define TB_SETEXTENDEDSTYLE (WM_USER+84) +#define TB_GETEXTENDEDSTYLE (WM_USER+85) +#define TB_GETPADDING (WM_USER+86) +#define TB_SETPADDING (WM_USER+87) +#define TB_SETINSERTMARKCOLOR (WM_USER+88) +#define TB_GETINSERTMARKCOLOR (WM_USER+89) + +#define TB_SETCOLORSCHEME CCM_SETCOLORSCHEME +#define TB_GETCOLORSCHEME CCM_GETCOLORSCHEME + +#define TB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define TB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT + +#define TB_MAPACCELERATORW (WM_USER+90) +#ifdef UNICODE +#define TB_MAPACCELERATOR TB_MAPACCELERATORW +#else +#define TB_MAPACCELERATOR TB_MAPACCELERATORA +#endif + + typedef struct { + HINSTANCE hInstOld; + UINT_PTR nIDOld; + HINSTANCE hInstNew; + UINT_PTR nIDNew; + int nButtons; + } TBREPLACEBITMAP,*LPTBREPLACEBITMAP; + +#define TBBF_LARGE 0x1 + +#define TB_GETBITMAPFLAGS (WM_USER+41) + +#define TBIF_IMAGE 0x1 +#define TBIF_TEXT 0x2 +#define TBIF_STATE 0x4 +#define TBIF_STYLE 0x8 +#define TBIF_LPARAM 0x10 +#define TBIF_COMMAND 0x20 +#define TBIF_SIZE 0x40 +#define TBIF_BYINDEX 0x80000000 + + typedef struct { UINT cbSize; - DWORD dwMask; - INT idCommand; - INT iImage; - BYTE fsState; - BYTE fsStyle; - WORD cx; + DWORD dwMask; + int idCommand; + int iImage; + BYTE fsState; + BYTE fsStyle; + WORD cx; DWORD_PTR lParam; - LPSTR pszText; - INT cchText; -} TBBUTTONINFOA, *LPTBBUTTONINFOA; + LPSTR pszText; + int cchText; + } TBBUTTONINFOA,*LPTBBUTTONINFOA; -typedef struct -{ + typedef struct { UINT cbSize; - DWORD dwMask; - INT idCommand; - INT iImage; - BYTE fsState; - BYTE fsStyle; - WORD cx; + DWORD dwMask; + int idCommand; + int iImage; + BYTE fsState; + BYTE fsStyle; + WORD cx; DWORD_PTR lParam; LPWSTR pszText; - INT cchText; -} TBBUTTONINFOW, *LPTBBUTTONINFOW; + int cchText; + } TBBUTTONINFOW,*LPTBBUTTONINFOW; -#define TBBUTTONINFO WINELIB_NAME_AW(TBBUTTONINFO) -#define LPTBBUTTONINFO WINELIB_NAME_AW(LPTBBUTTONINFO) +#ifdef UNICODE +#define TBBUTTONINFO TBBUTTONINFOW +#define LPTBBUTTONINFO LPTBBUTTONINFOW +#else +#define TBBUTTONINFO TBBUTTONINFOA +#define LPTBBUTTONINFO LPTBBUTTONINFOA +#endif -typedef struct tagNMTBHOTITEM -{ +#define TB_GETBUTTONINFOW (WM_USER+63) +#define TB_SETBUTTONINFOW (WM_USER+64) +#define TB_GETBUTTONINFOA (WM_USER+65) +#define TB_SETBUTTONINFOA (WM_USER+66) +#ifdef UNICODE +#define TB_GETBUTTONINFO TB_GETBUTTONINFOW +#define TB_SETBUTTONINFO TB_SETBUTTONINFOW +#else +#define TB_GETBUTTONINFO TB_GETBUTTONINFOA +#define TB_SETBUTTONINFO TB_SETBUTTONINFOA +#endif + +#define TB_INSERTBUTTONW (WM_USER+67) +#define TB_ADDBUTTONSW (WM_USER+68) + +#define TB_HITTEST (WM_USER+69) + +#ifdef UNICODE +#define TB_INSERTBUTTON TB_INSERTBUTTONW +#define TB_ADDBUTTONS TB_ADDBUTTONSW +#else +#define TB_INSERTBUTTON TB_INSERTBUTTONA +#define TB_ADDBUTTONS TB_ADDBUTTONSA +#endif + +#define TB_SETDRAWTEXTFLAGS (WM_USER+70) + +#define TB_GETSTRINGW (WM_USER+91) +#define TB_GETSTRINGA (WM_USER+92) +#ifdef UNICODE +#define TB_GETSTRING TB_GETSTRINGW +#else +#define TB_GETSTRING TB_GETSTRINGA +#endif + +#define TB_SETHOTITEM2 (WM_USER+94) +#define TB_SETLISTGAP (WM_USER+96) +#define TB_GETIMAGELISTCOUNT (WM_USER+98) +#define TB_GETIDEALSIZE (WM_USER+99) +#define TB_TRANSLATEACCELERATOR CCM_TRANSLATEACCELERATOR + +#define TBMF_PAD 0x1 +#define TBMF_BARPAD 0x2 +#define TBMF_BUTTONSPACING 0x4 + + typedef struct { + UINT cbSize; + DWORD dwMask; + int cxPad; + int cyPad; + int cxBarPad; + int cyBarPad; + int cxButtonSpacing; + int cyButtonSpacing; + } TBMETRICS,*LPTBMETRICS; + +#define TB_GETMETRICS (WM_USER+101) +#define TB_SETMETRICS (WM_USER+102) +#define TB_SETWINDOWTHEME CCM_SETWINDOWTHEME + +#define TBN_GETBUTTONINFOA (TBN_FIRST-0) +#define TBN_BEGINDRAG (TBN_FIRST-1) +#define TBN_ENDDRAG (TBN_FIRST-2) +#define TBN_BEGINADJUST (TBN_FIRST-3) +#define TBN_ENDADJUST (TBN_FIRST-4) +#define TBN_RESET (TBN_FIRST-5) +#define TBN_QUERYINSERT (TBN_FIRST-6) +#define TBN_QUERYDELETE (TBN_FIRST-7) +#define TBN_TOOLBARCHANGE (TBN_FIRST-8) +#define TBN_CUSTHELP (TBN_FIRST-9) +#define TBN_DROPDOWN (TBN_FIRST - 10) +#define TBN_GETOBJECT (TBN_FIRST - 12) + typedef struct tagNMTBHOTITEM { NMHDR hdr; int idOld; int idNew; DWORD dwFlags; -} NMTBHOTITEM, *LPNMTBHOTITEM; + } NMTBHOTITEM,*LPNMTBHOTITEM; -typedef struct tagNMTBGETINFOTIPA -{ - NMHDR hdr; - LPSTR pszText; - INT cchTextMax; - INT iItem; +#define HICF_OTHER 0x0 +#define HICF_MOUSE 0x1 +#define HICF_ARROWKEYS 0x2 +#define HICF_ACCELERATOR 0x4 +#define HICF_DUPACCEL 0x8 +#define HICF_ENTERING 0x10 +#define HICF_LEAVING 0x20 +#define HICF_RESELECT 0x40 +#define HICF_LMOUSE 0x80 +#define HICF_TOGGLEDROPDOWN 0x100 + +#define TBN_HOTITEMCHANGE (TBN_FIRST - 13) +#define TBN_DRAGOUT (TBN_FIRST - 14) +#define TBN_DELETINGBUTTON (TBN_FIRST - 15) +#define TBN_GETDISPINFOA (TBN_FIRST - 16) +#define TBN_GETDISPINFOW (TBN_FIRST - 17) +#define TBN_GETINFOTIPA (TBN_FIRST - 18) +#define TBN_GETINFOTIPW (TBN_FIRST - 19) +#define TBN_GETBUTTONINFOW (TBN_FIRST - 20) +#define TBN_RESTORE (TBN_FIRST - 21) +#define TBN_SAVE (TBN_FIRST - 22) +#define TBN_INITCUSTOMIZE (TBN_FIRST - 23) +#define TBN_WRAPHOTITEM (TBN_FIRST - 24) +#define TBN_DUPACCELERATOR (TBN_FIRST - 25) +#define TBN_WRAPACCELERATOR (TBN_FIRST - 26) +#define TBN_DRAGOVER (TBN_FIRST - 27) +#define TBN_MAPACCELERATOR (TBN_FIRST - 28) +#define TBNRF_HIDEHELP 0x1 +#define TBNRF_ENDCUSTOMIZE 0x2 + + typedef struct tagNMTBSAVE { + NMHDR hdr; + DWORD *pData; + DWORD *pCurrent; + UINT cbData; + int iItem; + int cButtons; + TBBUTTON tbButton; + } NMTBSAVE,*LPNMTBSAVE; + + typedef struct tagNMTBRESTORE { + NMHDR hdr; + DWORD *pData; + DWORD *pCurrent; + UINT cbData; + int iItem; + int cButtons; + int cbBytesPerRecord; + TBBUTTON tbButton; + } NMTBRESTORE,*LPNMTBRESTORE; + + typedef struct tagNMTBGETINFOTIPA { + NMHDR hdr; + LPSTR pszText; + int cchTextMax; + int iItem; LPARAM lParam; -} NMTBGETINFOTIPA, *LPNMTBGETINFOTIPA; + } NMTBGETINFOTIPA,*LPNMTBGETINFOTIPA; -typedef struct tagNMTBGETINFOTIPW -{ - NMHDR hdr; + typedef struct tagNMTBGETINFOTIPW { + NMHDR hdr; LPWSTR pszText; - INT cchTextMax; - INT iItem; + int cchTextMax; + int iItem; LPARAM lParam; -} NMTBGETINFOTIPW, *LPNMTBGETINFOTIPW; + } NMTBGETINFOTIPW,*LPNMTBGETINFOTIPW; -#define NMTBGETINFOTIP WINELIB_NAME_AW(NMTBGETINFOTIP) -#define LPNMTBGETINFOTIP WINELIB_NAME_AW(LPNMTBGETINFOTIP) +#ifdef UNICODE +#define TBN_GETINFOTIP TBN_GETINFOTIPW +#define NMTBGETINFOTIP NMTBGETINFOTIPW +#define LPNMTBGETINFOTIP LPNMTBGETINFOTIPW +#else +#define TBN_GETINFOTIP TBN_GETINFOTIPA +#define NMTBGETINFOTIP NMTBGETINFOTIPA +#define LPNMTBGETINFOTIP LPNMTBGETINFOTIPA +#endif -typedef struct -{ +#define TBNF_IMAGE 0x1 +#define TBNF_TEXT 0x2 +#define TBNF_DI_SETITEM 0x10000000 + + typedef struct { NMHDR hdr; DWORD dwMask; int idCommand; @@ -1447,10 +1271,9 @@ typedef struct int iImage; LPSTR pszText; int cchText; -} NMTBDISPINFOA, *LPNMTBDISPINFOA; + } NMTBDISPINFOA,*LPNMTBDISPINFOA; -typedef struct -{ + typedef struct { NMHDR hdr; DWORD dwMask; int idCommand; @@ -1458,266 +1281,350 @@ typedef struct int iImage; LPWSTR pszText; int cchText; -} NMTBDISPINFOW, *LPNMTBDISPINFOW; + } NMTBDISPINFOW,*LPNMTBDISPINFOW; -#define NMTBDISPINFO WINELIB_NAME_AW(NMTBDISPINFO) -#define LPNMTBDISPINFO WINELIB_NAME_AW(LPNMTBDISPINFO) +#ifdef UNICODE +#define TBN_GETDISPINFO TBN_GETDISPINFOW +#define NMTBDISPINFO NMTBDISPINFOW +#define LPNMTBDISPINFO LPNMTBDISPINFOW +#else +#define TBN_GETDISPINFO TBN_GETDISPINFOA +#define NMTBDISPINFO NMTBDISPINFOA +#define LPNMTBDISPINFO LPNMTBDISPINFOA +#endif -/* contents of dwMask in the NMTBDISPINFO structure */ -#define TBNF_IMAGE 0x00000001 -#define TBNF_TEXT 0x00000002 -#define TBNF_DI_SETITEM 0x10000000 +#define TBDDRET_DEFAULT 0 +#define TBDDRET_NODEFAULT 1 +#define TBDDRET_TREATPRESSED 2 +#ifdef UNICODE +#define TBN_GETBUTTONINFO TBN_GETBUTTONINFOW +#else +#define TBN_GETBUTTONINFO TBN_GETBUTTONINFOA +#endif -typedef struct tagNMTOOLBARA -{ - NMHDR hdr; - INT iItem; - TBBUTTON tbButton; - INT cchText; - LPSTR pszText; - RECT rcButton; /* Version 5.80 */ -} NMTOOLBARA, *LPNMTOOLBARA, TBNOTIFYA, *LPTBNOTIFYA; +#define TBNOTIFYA NMTOOLBARA +#define TBNOTIFYW NMTOOLBARW +#define LPTBNOTIFYA LPNMTOOLBARA +#define LPTBNOTIFYW LPNMTOOLBARW -typedef struct tagNMTOOLBARW -{ - NMHDR hdr; - INT iItem; - TBBUTTON tbButton; - INT cchText; - LPWSTR pszText; - RECT rcButton; /* Version 5.80 */ -} NMTOOLBARW, *LPNMTOOLBARW, TBNOTIFYW, *LPTBNOTIFYW; +#define TBNOTIFY NMTOOLBAR +#define LPTBNOTIFY LPNMTOOLBAR -#define NMTOOLBAR WINELIB_NAME_AW(NMTOOLBAR) -#define LPNMTOOLBAR WINELIB_NAME_AW(LPNMTOOLBAR) -#define TBNOTIFY WINELIB_NAME_AW(TBNOTIFY) -#define LPTBNOTIFY WINELIB_NAME_AW(LPTBNOTIFY) - -typedef struct -{ - HINSTANCE hInstOld; - UINT_PTR nIDOld; - HINSTANCE hInstNew; - UINT_PTR nIDNew; - INT nButtons; -} TBREPLACEBITMAP, *LPTBREPLACEBITMAP; - -#define HICF_OTHER 0x00000000 -#define HICF_MOUSE 0x00000001 /* Triggered by mouse */ -#define HICF_ARROWKEYS 0x00000002 /* Triggered by arrow keys */ -#define HICF_ACCELERATOR 0x00000004 /* Triggered by accelerator */ -#define HICF_DUPACCEL 0x00000008 /* This accelerator is not unique */ -#define HICF_ENTERING 0x00000010 /* idOld is invalid */ -#define HICF_LEAVING 0x00000020 /* idNew is invalid */ -#define HICF_RESELECT 0x00000040 /* hot item reselected */ -#define HICF_LMOUSE 0x00000080 /* left mouse button selected */ -#define HICF_TOGGLEDROPDOWN 0x00000100 /* Toggle button's dropdown state */ - -typedef struct -{ - int iButton; - DWORD dwFlags; -} TBINSERTMARK, *LPTBINSERTMARK; -#define TBIMHT_AFTER 0x00000001 /* TRUE = insert After iButton, otherwise before */ -#define TBIMHT_BACKGROUND 0x00000002 /* TRUE if and only if missed buttons completely */ - -typedef struct tagNMTBSAVE -{ + typedef struct tagNMTOOLBARA { NMHDR hdr; - DWORD* pData; - DWORD* pCurrent; - UINT cbData; int iItem; - int cButtons; TBBUTTON tbButton; -} NMTBSAVE, *LPNMTBSAVE; + int cchText; + LPSTR pszText; + RECT rcButton; + } NMTOOLBARA,*LPNMTOOLBARA; -typedef struct tagNMTBRESTORE -{ + typedef struct tagNMTOOLBARW { NMHDR hdr; - DWORD* pData; - DWORD* pCurrent; - UINT cbData; int iItem; - int cButtons; - int cbBytesPerRecord; TBBUTTON tbButton; -} NMTBRESTORE, *LPNMTBRESTORE; + int cchText; + LPWSTR pszText; + RECT rcButton; + } NMTOOLBARW,*LPNMTOOLBARW; -#define TBMF_PAD 0x00000001 -#define TBMF_BARPAD 0x00000002 -#define TBMF_BUTTONSPACING 0x00000004 +#ifdef UNICODE +#define NMTOOLBAR NMTOOLBARW +#define LPNMTOOLBAR LPNMTOOLBARW +#else +#define NMTOOLBAR NMTOOLBARA +#define LPNMTOOLBAR LPNMTOOLBARA +#endif +#endif -typedef struct -{ +#ifndef NOREBAR + +#define REBARCLASSNAMEW L"ReBarWindow32" +#define REBARCLASSNAMEA "ReBarWindow32" + +#ifdef UNICODE +#define REBARCLASSNAME REBARCLASSNAMEW +#else +#define REBARCLASSNAME REBARCLASSNAMEA +#endif + +#define RBIM_IMAGELIST 0x1 + +#define RBS_TOOLTIPS 0x100 +#define RBS_VARHEIGHT 0x200 +#define RBS_BANDBORDERS 0x400 +#define RBS_FIXEDORDER 0x800 +#define RBS_REGISTERDROP 0x1000 +#define RBS_AUTOSIZE 0x2000 +#define RBS_VERTICALGRIPPER 0x4000 +#define RBS_DBLCLKTOGGLE 0x8000 + + typedef struct tagREBARINFO { UINT cbSize; - DWORD dwMask; - INT cxPad; - INT cyPad; - INT cxBarPad; - INT cyBarPad; - INT cxButtonSpacing; - INT cyButtonSpacing; -} TBMETRICS, *LPTBMETRICS; - -/* these are undocumented and the names are guesses */ -typedef struct -{ - NMHDR hdr; - HWND hwndDialog; -} NMTBINITCUSTOMIZE; - -typedef struct -{ - NMHDR hdr; - INT idNew; - INT iDirection; /* left is -1, right is 1 */ - DWORD dwReason; /* HICF_* */ -} NMTBWRAPHOTITEM; - - -HWND WINAPI -CreateToolbar(HWND, DWORD, UINT, INT, HINSTANCE, - UINT, LPCTBBUTTON, INT); - -HWND WINAPI -CreateToolbarEx(HWND, DWORD, UINT, INT, - HINSTANCE, UINT_PTR, LPCTBBUTTON, - INT, INT, INT, INT, INT, UINT); - -HBITMAP WINAPI -CreateMappedBitmap (HINSTANCE, INT_PTR, UINT, LPCOLORMAP, INT); - - -/* Tool tips */ - -#define TOOLTIPS_CLASSA "tooltips_class32" -# define TOOLTIPS_CLASSW L"tooltips_class32" -#define TOOLTIPS_CLASS WINELIB_NAME_AW(TOOLTIPS_CLASS) - -#if (_WIN32_WINNT >= 0x501) -#define BUTTON_IMAGELIST_ALIGN_LEFT 0 -#define BUTTON_IMAGELIST_ALIGN_RIGHT 1 -#define BUTTON_IMAGELIST_ALIGN_TOP 2 -#define BUTTON_IMAGELIST_ALIGN_BOTTOM 3 -#define BUTTON_IMAGELIST_ALIGN_CENTER 4 - -typedef struct -{ + UINT fMask; +#ifndef NOIMAGEAPIS HIMAGELIST himl; - RECT margin; - UINT uAlign; -} BUTTON_IMAGELIST, *PBUTTON_IMAGELIST; +#else + HANDLE himl; +#endif + } REBARINFO,*LPREBARINFO; -#define BCM_FIRST 0x1600 -#define BCM_GETIDEALSIZE (BCM_FIRST + 1) -#define BCM_SETIMAGELIST (BCM_FIRST + 2) -#endif /* _WIN32_WINNT */ +#define RBBS_BREAK 0x1 +#define RBBS_FIXEDSIZE 0x2 +#define RBBS_CHILDEDGE 0x4 +#define RBBS_HIDDEN 0x8 +#define RBBS_NOVERT 0x10 +#define RBBS_FIXEDBMP 0x20 +#define RBBS_VARIABLEHEIGHT 0x40 +#define RBBS_GRIPPERALWAYS 0x80 +#define RBBS_NOGRIPPER 0x100 +#define RBBS_USECHEVRON 0x200 +#define RBBS_HIDETITLE 0x400 +#define RBBS_TOPALIGN 0x800 -#define INFOTIPSIZE 1024 +#define RBBIM_STYLE 0x1 +#define RBBIM_COLORS 0x2 +#define RBBIM_TEXT 0x4 +#define RBBIM_IMAGE 0x8 +#define RBBIM_CHILD 0x10 +#define RBBIM_CHILDSIZE 0x20 +#define RBBIM_SIZE 0x40 +#define RBBIM_BACKGROUND 0x80 +#define RBBIM_ID 0x100 +#define RBBIM_IDEALSIZE 0x200 +#define RBBIM_LPARAM 0x400 +#define RBBIM_HEADERSIZE 0x800 -#define TTS_ALWAYSTIP 0x01 -#define TTS_NOPREFIX 0x02 -#define TTS_NOANIMATE 0x10 -#define TTS_NOFADE 0x20 -#define TTS_BALLOON 0x40 -#define TTS_CLOSE 0x80 -#define TTS_USEVISUALSTYLE 0x100 + typedef struct tagREBARBANDINFOA { + UINT cbSize; + UINT fMask; + UINT fStyle; + COLORREF clrFore; + COLORREF clrBack; + LPSTR lpText; + UINT cch; + int iImage; + HWND hwndChild; + UINT cxMinChild; + UINT cyMinChild; + UINT cx; + HBITMAP hbmBack; + UINT wID; + UINT cyChild; + UINT cyMaxChild; + UINT cyIntegral; + UINT cxIdeal; + LPARAM lParam; + UINT cxHeader; + } REBARBANDINFOA,*LPREBARBANDINFOA; + typedef REBARBANDINFOA CONST *LPCREBARBANDINFOA; -#define TTF_IDISHWND 0x0001 -#define TTF_CENTERTIP 0x0002 -#define TTF_RTLREADING 0x0004 -#define TTF_SUBCLASS 0x0010 -#define TTF_TRACK 0x0020 -#define TTF_ABSOLUTE 0x0080 -#define TTF_TRANSPARENT 0x0100 -#define TTF_DI_SETITEM 0x8000 /* valid only on the TTN_NEEDTEXT callback */ +#define REBARBANDINFOA_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOA,wID) +#define REBARBANDINFOW_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOW,wID) +#define REBARBANDINFOA_V6_SIZE CCSIZEOF_STRUCT(REBARBANDINFOA,cxHeader) +#define REBARBANDINFOW_V6_SIZE CCSIZEOF_STRUCT(REBARBANDINFOW,cxHeader) + typedef struct tagREBARBANDINFOW { + UINT cbSize; + UINT fMask; + UINT fStyle; + COLORREF clrFore; + COLORREF clrBack; + LPWSTR lpText; + UINT cch; + int iImage; + HWND hwndChild; + UINT cxMinChild; + UINT cyMinChild; + UINT cx; + HBITMAP hbmBack; + UINT wID; + UINT cyChild; + UINT cyMaxChild; + UINT cyIntegral; + UINT cxIdeal; + LPARAM lParam; + UINT cxHeader; + } REBARBANDINFOW,*LPREBARBANDINFOW; + typedef REBARBANDINFOW CONST *LPCREBARBANDINFOW; -#define TTDT_AUTOMATIC 0 -#define TTDT_RESHOW 1 -#define TTDT_AUTOPOP 2 -#define TTDT_INITIAL 3 +#ifdef UNICODE +#define REBARBANDINFO REBARBANDINFOW +#define LPREBARBANDINFO LPREBARBANDINFOW +#define LPCREBARBANDINFO LPCREBARBANDINFOW +#define REBARBANDINFO_V3_SIZE REBARBANDINFOW_V3_SIZE +#else +#define REBARBANDINFO REBARBANDINFOA +#define LPREBARBANDINFO LPREBARBANDINFOA +#define LPCREBARBANDINFO LPCREBARBANDINFOA +#define REBARBANDINFO_V3_SIZE REBARBANDINFOA_V3_SIZE +#endif +#define RB_INSERTBANDA (WM_USER+1) +#define RB_DELETEBAND (WM_USER+2) +#define RB_GETBARINFO (WM_USER+3) +#define RB_SETBARINFO (WM_USER+4) +#define RB_SETBANDINFOA (WM_USER+6) +#define RB_SETPARENT (WM_USER+7) +#define RB_HITTEST (WM_USER+8) +#define RB_GETRECT (WM_USER+9) +#define RB_INSERTBANDW (WM_USER+10) +#define RB_SETBANDINFOW (WM_USER+11) +#define RB_GETBANDCOUNT (WM_USER+12) +#define RB_GETROWCOUNT (WM_USER+13) +#define RB_GETROWHEIGHT (WM_USER+14) +#define RB_IDTOINDEX (WM_USER+16) +#define RB_GETTOOLTIPS (WM_USER+17) +#define RB_SETTOOLTIPS (WM_USER+18) +#define RB_SETBKCOLOR (WM_USER+19) +#define RB_GETBKCOLOR (WM_USER+20) +#define RB_SETTEXTCOLOR (WM_USER+21) +#define RB_GETTEXTCOLOR (WM_USER+22) -#define TTI_NONE 0 -#define TTI_INFO 1 -#define TTI_WARNING 2 -#define TTI_ERROR 3 +#define RBSTR_CHANGERECT 0x1 +#define RB_SIZETORECT (WM_USER+23) +#define RB_SETCOLORSCHEME CCM_SETCOLORSCHEME +#define RB_GETCOLORSCHEME CCM_GETCOLORSCHEME -#define TTM_ACTIVATE (WM_USER+1) -#define TTM_SETDELAYTIME (WM_USER+3) -#define TTM_ADDTOOLA (WM_USER+4) -#define TTM_ADDTOOLW (WM_USER+50) -#define TTM_ADDTOOL WINELIB_NAME_AW(TTM_ADDTOOL) -#define TTM_DELTOOLA (WM_USER+5) -#define TTM_DELTOOLW (WM_USER+51) -#define TTM_DELTOOL WINELIB_NAME_AW(TTM_DELTOOL) -#define TTM_NEWTOOLRECTA (WM_USER+6) -#define TTM_NEWTOOLRECTW (WM_USER+52) -#define TTM_NEWTOOLRECT WINELIB_NAME_AW(TTM_NEWTOOLRECT) -#define TTM_RELAYEVENT (WM_USER+7) -#define TTM_GETTOOLINFOA (WM_USER+8) -#define TTM_GETTOOLINFOW (WM_USER+53) -#define TTM_GETTOOLINFO WINELIB_NAME_AW(TTM_GETTOOLINFO) -#define TTM_SETTOOLINFOA (WM_USER+9) -#define TTM_SETTOOLINFOW (WM_USER+54) -#define TTM_SETTOOLINFO WINELIB_NAME_AW(TTM_SETTOOLINFO) -#define TTM_HITTESTA (WM_USER+10) -#define TTM_HITTESTW (WM_USER+55) -#define TTM_HITTEST WINELIB_NAME_AW(TTM_HITTEST) -#define TTM_GETTEXTA (WM_USER+11) -#define TTM_GETTEXTW (WM_USER+56) -#define TTM_GETTEXT WINELIB_NAME_AW(TTM_GETTEXT) -#define TTM_UPDATETIPTEXTA (WM_USER+12) -#define TTM_UPDATETIPTEXTW (WM_USER+57) -#define TTM_UPDATETIPTEXT WINELIB_NAME_AW(TTM_UPDATETIPTEXT) -#define TTM_GETTOOLCOUNT (WM_USER+13) -#define TTM_ENUMTOOLSA (WM_USER+14) -#define TTM_ENUMTOOLSW (WM_USER+58) -#define TTM_ENUMTOOLS WINELIB_NAME_AW(TTM_ENUMTOOLS) -#define TTM_GETCURRENTTOOLA (WM_USER+15) -#define TTM_GETCURRENTTOOLW (WM_USER+59) -#define TTM_GETCURRENTTOOL WINELIB_NAME_AW(TTM_GETCURRENTTOOL) -#define TTM_WINDOWFROMPOINT (WM_USER+16) -#define TTM_TRACKACTIVATE (WM_USER+17) -#define TTM_TRACKPOSITION (WM_USER+18) -#define TTM_SETTIPBKCOLOR (WM_USER+19) -#define TTM_SETTIPTEXTCOLOR (WM_USER+20) -#define TTM_GETDELAYTIME (WM_USER+21) -#define TTM_GETTIPBKCOLOR (WM_USER+22) -#define TTM_GETTIPTEXTCOLOR (WM_USER+23) -#define TTM_SETMAXTIPWIDTH (WM_USER+24) -#define TTM_GETMAXTIPWIDTH (WM_USER+25) -#define TTM_SETMARGIN (WM_USER+26) -#define TTM_GETMARGIN (WM_USER+27) -#define TTM_POP (WM_USER+28) -#define TTM_UPDATE (WM_USER+29) -#define TTM_GETBUBBLESIZE (WM_USER+30) -#define TTM_ADJUSTRECT (WM_USER+31) -#define TTM_SETTITLEA (WM_USER+32) -#define TTM_SETTITLEW (WM_USER+33) -#define TTM_SETTITLE WINELIB_NAME_AW(TTM_SETTITLE) -#define TTM_POPUP (WM_USER+34) -#define TTM_GETTITLE (WM_USER+35) -#define TTM_SETWINDOWTHEME CCM_SETWINDOWTHEME +#ifdef UNICODE +#define RB_INSERTBAND RB_INSERTBANDW +#define RB_SETBANDINFO RB_SETBANDINFOW +#else +#define RB_INSERTBAND RB_INSERTBANDA +#define RB_SETBANDINFO RB_SETBANDINFOA +#endif +#define RB_BEGINDRAG (WM_USER+24) +#define RB_ENDDRAG (WM_USER+25) +#define RB_DRAGMOVE (WM_USER+26) +#define RB_GETBARHEIGHT (WM_USER+27) +#define RB_GETBANDINFOW (WM_USER+28) +#define RB_GETBANDINFOA (WM_USER+29) -#define TTN_FIRST (0U-520U) -#define TTN_LAST (0U-549U) -#define TTN_GETDISPINFOA (TTN_FIRST-0) -#define TTN_GETDISPINFOW (TTN_FIRST-10) -#define TTN_GETDISPINFO WINELIB_NAME_AW(TTN_GETDISPINFO) -#define TTN_SHOW (TTN_FIRST-1) -#define TTN_POP (TTN_FIRST-2) +#ifdef UNICODE +#define RB_GETBANDINFO RB_GETBANDINFOW +#else +#define RB_GETBANDINFO RB_GETBANDINFOA +#endif -#define TTN_NEEDTEXT TTN_GETDISPINFO -#define TTN_NEEDTEXTA TTN_GETDISPINFOA -#define TTN_NEEDTEXTW TTN_GETDISPINFOW +#define RB_MINIMIZEBAND (WM_USER+30) +#define RB_MAXIMIZEBAND (WM_USER+31) +#define RB_GETDROPTARGET (CCM_GETDROPTARGET) +#define RB_GETBANDBORDERS (WM_USER+34) +#define RB_SHOWBAND (WM_USER+35) +#define RB_SETPALETTE (WM_USER+37) +#define RB_GETPALETTE (WM_USER+38) +#define RB_MOVEBAND (WM_USER+39) +#define RB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define RB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define RB_GETBANDMARGINS (WM_USER+40) +#define RB_SETWINDOWTHEME CCM_SETWINDOWTHEME +#define RB_PUSHCHEVRON (WM_USER+43) -typedef struct tagTOOLINFOA { +#define RBN_HEIGHTCHANGE (RBN_FIRST - 0) +#define RBN_GETOBJECT (RBN_FIRST - 1) +#define RBN_LAYOUTCHANGED (RBN_FIRST - 2) +#define RBN_AUTOSIZE (RBN_FIRST - 3) +#define RBN_BEGINDRAG (RBN_FIRST - 4) +#define RBN_ENDDRAG (RBN_FIRST - 5) +#define RBN_DELETINGBAND (RBN_FIRST - 6) +#define RBN_DELETEDBAND (RBN_FIRST - 7) +#define RBN_CHILDSIZE (RBN_FIRST - 8) +#define RBN_CHEVRONPUSHED (RBN_FIRST - 10) +#define RBN_MINMAX (RBN_FIRST - 21) +#define RBN_AUTOBREAK (RBN_FIRST - 22) + + typedef struct tagNMREBARCHILDSIZE { + NMHDR hdr; + UINT uBand; + UINT wID; + RECT rcChild; + RECT rcBand; + } NMREBARCHILDSIZE,*LPNMREBARCHILDSIZE; + + typedef struct tagNMREBAR { + NMHDR hdr; + DWORD dwMask; + UINT uBand; + UINT fStyle; + UINT wID; + LPARAM lParam; + } NMREBAR,*LPNMREBAR; + +#define RBNM_ID 0x1 +#define RBNM_STYLE 0x2 +#define RBNM_LPARAM 0x4 + + typedef struct tagNMRBAUTOSIZE { + NMHDR hdr; + WINBOOL fChanged; + RECT rcTarget; + RECT rcActual; + } NMRBAUTOSIZE,*LPNMRBAUTOSIZE; + + typedef struct tagNMREBARCHEVRON { + NMHDR hdr; + UINT uBand; + UINT wID; + LPARAM lParam; + RECT rc; + LPARAM lParamNM; + } NMREBARCHEVRON,*LPNMREBARCHEVRON; + +#define RBAB_AUTOSIZE 0x1 +#define RBAB_ADDBAND 0x2 + + typedef struct tagNMREBARAUTOBREAK { + NMHDR hdr; + UINT uBand; + UINT wID; + LPARAM lParam; + UINT uMsg; + UINT fStyleCurrent; + WINBOOL fAutoBreak; + } NMREBARAUTOBREAK,*LPNMREBARAUTOBREAK; + +#define RBHT_NOWHERE 0x1 +#define RBHT_CAPTION 0x2 +#define RBHT_CLIENT 0x3 +#define RBHT_GRABBER 0x4 +#define RBHT_CHEVRON 0x8 + + typedef struct _RB_HITTESTINFO { + POINT pt; + UINT flags; + int iBand; + } RBHITTESTINFO,*LPRBHITTESTINFO; +#endif + +#ifndef NOTOOLTIPS + +#define TOOLTIPS_CLASSW L"tooltips_class32" +#define TOOLTIPS_CLASSA "tooltips_class32" +#ifdef UNICODE +#define TOOLTIPS_CLASS TOOLTIPS_CLASSW +#else +#define TOOLTIPS_CLASS TOOLTIPS_CLASSA +#endif + +#define LPTOOLINFOA LPTTTOOLINFOA +#define LPTOOLINFOW LPTTTOOLINFOW +#define TOOLINFOA TTTOOLINFOA +#define TOOLINFOW TTTOOLINFOW + +#define LPTOOLINFO LPTTTOOLINFO +#define TOOLINFO TTTOOLINFO + +#define TTTOOLINFOA_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA,lpszText) +#define TTTOOLINFOW_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW,lpszText) +#define TTTOOLINFOA_V2_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA,lParam) +#define TTTOOLINFOW_V2_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW,lParam) +#define TTTOOLINFOA_V3_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA,lpReserved) +#define TTTOOLINFOW_V3_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW,lpReserved) + + typedef struct tagTOOLINFOA { UINT cbSize; UINT uFlags; HWND hwnd; @@ -1727,9 +1634,9 @@ typedef struct tagTOOLINFOA { LPSTR lpszText; LPARAM lParam; void *lpReserved; -} TTTOOLINFOA, *LPTOOLINFOA, *PTOOLINFOA, *LPTTTOOLINFOA; + } TTTOOLINFOA,NEAR *PTOOLINFOA,*LPTTTOOLINFOA; -typedef struct tagTOOLINFOW { + typedef struct tagTOOLINFOW { UINT cbSize; UINT uFlags; HWND hwnd; @@ -1739,1742 +1646,1403 @@ typedef struct tagTOOLINFOW { LPWSTR lpszText; LPARAM lParam; void *lpReserved; -} TTTOOLINFOW, *LPTOOLINFOW, *PTOOLINFOW, *LPTTTOOLINFOW; + } TTTOOLINFOW,NEAR *PTOOLINFOW,*LPTTTOOLINFOW; -#define TTTOOLINFO WINELIB_NAME_AW(TTTOOLINFO) -#define TOOLINFO WINELIB_NAME_AW(TTTOOLINFO) -#define PTOOLINFO WINELIB_NAME_AW(PTOOLINFO) -#define LPTTTOOLINFO WINELIB_NAME_AW(LPTTTOOLINFO) -#define LPTOOLINFO WINELIB_NAME_AW(LPTOOLINFO) +#ifdef UNICODE +#define TTTOOLINFO TTTOOLINFOW +#define PTOOLINFO PTOOLINFOW +#define LPTTTOOLINFO LPTTTOOLINFOW +#define TTTOOLINFO_V1_SIZE TTTOOLINFOW_V1_SIZE +#else +#define PTOOLINFO PTOOLINFOA +#define TTTOOLINFO TTTOOLINFOA +#define LPTTTOOLINFO LPTTTOOLINFOA +#define TTTOOLINFO_V1_SIZE TTTOOLINFOA_V1_SIZE +#endif -#define TTTOOLINFOA_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA, lpszText) -#define TTTOOLINFOW_V1_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW, lpszText) -#define TTTOOLINFO_V1_SIZE CCSIZEOF_STRUCT(WINELIB_NAME_AW(TTTOOLINFO), lpszText) -#define TTTOOLINFOA_V2_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA, lParam) -#define TTTOOLINFOW_V2_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW, lParam) -#define TTTOOLINFOA_V3_SIZE CCSIZEOF_STRUCT(TTTOOLINFOA, lpReserved) -#define TTTOOLINFOW_V3_SIZE CCSIZEOF_STRUCT(TTTOOLINFOW, lpReserved) +#define TTS_ALWAYSTIP 0x1 +#define TTS_NOPREFIX 0x2 +#define TTS_NOANIMATE 0x10 +#define TTS_NOFADE 0x20 +#define TTS_BALLOON 0x40 +#define TTS_CLOSE 0x80 -typedef struct _TT_HITTESTINFOA -{ - HWND hwnd; - POINT pt; - TTTOOLINFOA ti; -} TTHITTESTINFOA, *LPTTHITTESTINFOA; -#define LPHITTESTINFOA LPTTHITTESTINFOA +#define TTF_IDISHWND 0x1 +#define TTF_CENTERTIP 0x2 +#define TTF_RTLREADING 0x4 +#define TTF_SUBCLASS 0x10 +#define TTF_TRACK 0x20 +#define TTF_ABSOLUTE 0x80 +#define TTF_TRANSPARENT 0x100 +#define TTF_PARSELINKS 0x1000 +#define TTF_DI_SETITEM 0x8000 -typedef struct _TT_HITTESTINFOW -{ - HWND hwnd; - POINT pt; - TTTOOLINFOW ti; -} TTHITTESTINFOW, *LPTTHITTESTINFOW; -#define LPHITTESTINFOW LPTTHITTESTINFOW +#define TTDT_AUTOMATIC 0 +#define TTDT_RESHOW 1 +#define TTDT_AUTOPOP 2 +#define TTDT_INITIAL 3 -#define TTHITTESTINFO WINELIB_NAME_AW(TTHITTESTINFO) -#define LPTTHITTESTINFO WINELIB_NAME_AW(LPTTHITTESTINFO) -#define LPHITTESTINFO WINELIB_NAME_AW(LPHITTESTINFO) +#define TTI_NONE 0 +#define TTI_INFO 1 +#define TTI_WARNING 2 +#define TTI_ERROR 3 -typedef struct tagNMTTDISPINFOA -{ - NMHDR hdr; - LPSTR lpszText; - CHAR szText[80]; - HINSTANCE hinst; - UINT uFlags; - LPARAM lParam; -} NMTTDISPINFOA, *LPNMTTDISPINFOA; +#define TTM_ACTIVATE (WM_USER+1) +#define TTM_SETDELAYTIME (WM_USER+3) +#define TTM_ADDTOOLA (WM_USER+4) +#define TTM_ADDTOOLW (WM_USER+50) +#define TTM_DELTOOLA (WM_USER+5) +#define TTM_DELTOOLW (WM_USER+51) +#define TTM_NEWTOOLRECTA (WM_USER+6) +#define TTM_NEWTOOLRECTW (WM_USER+52) +#define TTM_RELAYEVENT (WM_USER+7) -typedef struct tagNMTTDISPINFOW -{ - NMHDR hdr; - LPWSTR lpszText; - WCHAR szText[80]; - HINSTANCE hinst; - UINT uFlags; - LPARAM lParam; -} NMTTDISPINFOW, *LPNMTTDISPINFOW; +#define TTM_GETTOOLINFOA (WM_USER+8) +#define TTM_GETTOOLINFOW (WM_USER+53) -#define NMTTDISPINFO WINELIB_NAME_AW(NMTTDISPINFO) -#define LPNMTTDISPINFO WINELIB_NAME_AW(LPNMTTDISPINFO) +#define TTM_SETTOOLINFOA (WM_USER+9) +#define TTM_SETTOOLINFOW (WM_USER+54) -#define NMTTDISPINFO_V1_SIZEA CCSIZEOF_STRUCT(NMTTDISPINFOA, uFlags) -#define NMTTDISPINFO_V1_SIZEW CCSIZEOF_STRUCT(NMTTDISPINFOW, uFlags) -#define NMTTDISPINFO_V1_SIZE WINELIB_NAME_AW(NMTTDISPINFO_V1_SIZE) +#define TTM_HITTESTA (WM_USER +10) +#define TTM_HITTESTW (WM_USER +55) +#define TTM_GETTEXTA (WM_USER +11) +#define TTM_GETTEXTW (WM_USER +56) +#define TTM_UPDATETIPTEXTA (WM_USER +12) +#define TTM_UPDATETIPTEXTW (WM_USER +57) +#define TTM_GETTOOLCOUNT (WM_USER +13) +#define TTM_ENUMTOOLSA (WM_USER +14) +#define TTM_ENUMTOOLSW (WM_USER +58) +#define TTM_GETCURRENTTOOLA (WM_USER+15) +#define TTM_GETCURRENTTOOLW (WM_USER+59) +#define TTM_WINDOWFROMPOINT (WM_USER+16) +#define TTM_TRACKACTIVATE (WM_USER+17) +#define TTM_TRACKPOSITION (WM_USER+18) +#define TTM_SETTIPBKCOLOR (WM_USER+19) +#define TTM_SETTIPTEXTCOLOR (WM_USER+20) +#define TTM_GETDELAYTIME (WM_USER+21) +#define TTM_GETTIPBKCOLOR (WM_USER+22) +#define TTM_GETTIPTEXTCOLOR (WM_USER+23) +#define TTM_SETMAXTIPWIDTH (WM_USER+24) +#define TTM_GETMAXTIPWIDTH (WM_USER+25) +#define TTM_SETMARGIN (WM_USER+26) +#define TTM_GETMARGIN (WM_USER+27) +#define TTM_POP (WM_USER+28) +#define TTM_UPDATE (WM_USER+29) +#define TTM_GETBUBBLESIZE (WM_USER+30) +#define TTM_ADJUSTRECT (WM_USER+31) +#define TTM_SETTITLEA (WM_USER+32) +#define TTM_SETTITLEW (WM_USER+33) -typedef struct _TTGETTITLE -{ +#define TTM_POPUP (WM_USER+34) +#define TTM_GETTITLE (WM_USER+35) + typedef struct _TTGETTITLE { DWORD dwSize; UINT uTitleBitmap; UINT cch; - WCHAR* pszTitle; -} TTGETTITLE, *PTTGETTITLE; + WCHAR *pszTitle; + } TTGETTITLE,*PTTGETTITLE; -#define TOOLTIPTEXTW NMTTDISPINFOW -#define TOOLTIPTEXTA NMTTDISPINFOA -#define TOOLTIPTEXT NMTTDISPINFO -#define LPTOOLTIPTEXTW LPNMTTDISPINFOW -#define LPTOOLTIPTEXTA LPNMTTDISPINFOA -#define LPTOOLTIPTEXT LPNMTTDISPINFO - - -/* Rebar control */ - -#define REBARCLASSNAMEA "ReBarWindow32" -#if defined(__GNUC__) -# define REBARCLASSNAMEW (const WCHAR []){ 'R','e','B','a','r', \ - 'W','i','n','d','o','w','3','2',0 } -#elif defined(_MSC_VER) -# define REBARCLASSNAMEW L"ReBarWindow32" +#ifdef UNICODE +#define TTM_ADDTOOL TTM_ADDTOOLW +#define TTM_DELTOOL TTM_DELTOOLW +#define TTM_NEWTOOLRECT TTM_NEWTOOLRECTW +#define TTM_GETTOOLINFO TTM_GETTOOLINFOW +#define TTM_SETTOOLINFO TTM_SETTOOLINFOW +#define TTM_HITTEST TTM_HITTESTW +#define TTM_GETTEXT TTM_GETTEXTW +#define TTM_UPDATETIPTEXT TTM_UPDATETIPTEXTW +#define TTM_ENUMTOOLS TTM_ENUMTOOLSW +#define TTM_GETCURRENTTOOL TTM_GETCURRENTTOOLW +#define TTM_SETTITLE TTM_SETTITLEW #else -static const WCHAR REBARCLASSNAMEW[] = { 'R','e','B','a','r', - 'W','i','n','d','o','w','3','2',0 }; +#define TTM_ADDTOOL TTM_ADDTOOLA +#define TTM_DELTOOL TTM_DELTOOLA +#define TTM_NEWTOOLRECT TTM_NEWTOOLRECTA +#define TTM_GETTOOLINFO TTM_GETTOOLINFOA +#define TTM_SETTOOLINFO TTM_SETTOOLINFOA +#define TTM_HITTEST TTM_HITTESTA +#define TTM_GETTEXT TTM_GETTEXTA +#define TTM_UPDATETIPTEXT TTM_UPDATETIPTEXTA +#define TTM_ENUMTOOLS TTM_ENUMTOOLSA +#define TTM_GETCURRENTTOOL TTM_GETCURRENTTOOLA +#define TTM_SETTITLE TTM_SETTITLEA #endif -#define REBARCLASSNAME WINELIB_NAME_AW(REBARCLASSNAME) +#define TTM_SETWINDOWTHEME CCM_SETWINDOWTHEME -#define RBS_TOOLTIPS 0x0100 -#define RBS_VARHEIGHT 0x0200 -#define RBS_BANDBORDERS 0x0400 -#define RBS_FIXEDORDER 0x0800 -#define RBS_REGISTERDROP 0x1000 -#define RBS_AUTOSIZE 0x2000 -#define RBS_VERTICALGRIPPER 0x4000 -#define RBS_DBLCLKTOGGLE 0x8000 +#define LPHITTESTINFOW LPTTHITTESTINFOW +#define LPHITTESTINFOA LPTTHITTESTINFOA +#define LPHITTESTINFO LPTTHITTESTINFO -#define RBIM_IMAGELIST 0x00000001 - -#define RBBIM_STYLE 0x00000001 -#define RBBIM_COLORS 0x00000002 -#define RBBIM_TEXT 0x00000004 -#define RBBIM_IMAGE 0x00000008 -#define RBBIM_CHILD 0x00000010 -#define RBBIM_CHILDSIZE 0x00000020 -#define RBBIM_SIZE 0x00000040 -#define RBBIM_BACKGROUND 0x00000080 -#define RBBIM_ID 0x00000100 -#define RBBIM_IDEALSIZE 0x00000200 -#define RBBIM_LPARAM 0x00000400 -#define RBBIM_HEADERSIZE 0x00000800 - -#define RBBS_BREAK 0x00000001 -#define RBBS_FIXEDSIZE 0x00000002 -#define RBBS_CHILDEDGE 0x00000004 -#define RBBS_HIDDEN 0x00000008 -#define RBBS_NOVERT 0x00000010 -#define RBBS_FIXEDBMP 0x00000020 -#define RBBS_VARIABLEHEIGHT 0x00000040 -#define RBBS_GRIPPERALWAYS 0x00000080 -#define RBBS_NOGRIPPER 0x00000100 -#define RBBS_USECHEVRON 0x00000200 -#define RBBS_HIDETITLE 0x00000400 -#define RBBS_TOPALIGN 0x00000800 - -#define RBNM_ID 0x00000001 -#define RBNM_STYLE 0x00000002 -#define RBNM_LPARAM 0x00000004 - -#define RBHT_NOWHERE 0x0001 -#define RBHT_CAPTION 0x0002 -#define RBHT_CLIENT 0x0003 -#define RBHT_GRABBER 0x0004 -#define RBHT_CHEVRON 0x0008 - -#define RB_INSERTBANDA (WM_USER+1) -#define RB_INSERTBANDW (WM_USER+10) -#define RB_INSERTBAND WINELIB_NAME_AW(RB_INSERTBAND) -#define RB_DELETEBAND (WM_USER+2) -#define RB_GETBARINFO (WM_USER+3) -#define RB_SETBARINFO (WM_USER+4) -#define RB_SETBANDINFOA (WM_USER+6) -#define RB_SETBANDINFOW (WM_USER+11) -#define RB_SETBANDINFO WINELIB_NAME_AW(RB_SETBANDINFO) -#define RB_SETPARENT (WM_USER+7) -#define RB_HITTEST (WM_USER+8) -#define RB_GETRECT (WM_USER+9) -#define RB_GETBANDCOUNT (WM_USER+12) -#define RB_GETROWCOUNT (WM_USER+13) -#define RB_GETROWHEIGHT (WM_USER+14) -#define RB_IDTOINDEX (WM_USER+16) -#define RB_GETTOOLTIPS (WM_USER+17) -#define RB_SETTOOLTIPS (WM_USER+18) -#define RB_SETBKCOLOR (WM_USER+19) -#define RB_GETBKCOLOR (WM_USER+20) -#define RB_SETTEXTCOLOR (WM_USER+21) -#define RB_GETTEXTCOLOR (WM_USER+22) -#define RB_SIZETORECT (WM_USER+23) -#define RB_BEGINDRAG (WM_USER+24) -#define RB_ENDDRAG (WM_USER+25) -#define RB_DRAGMOVE (WM_USER+26) -#define RB_GETBARHEIGHT (WM_USER+27) -#define RB_GETBANDINFOW (WM_USER+28) -#define RB_GETBANDINFOA (WM_USER+29) -#define RB_GETBANDINFO WINELIB_NAME_AW(RB_GETBANDINFO) -#define RB_MINIMIZEBAND (WM_USER+30) -#define RB_MAXIMIZEBAND (WM_USER+31) -#define RB_GETBANDBORDERS (WM_USER+34) -#define RB_SHOWBAND (WM_USER+35) -#define RB_SETPALETTE (WM_USER+37) -#define RB_GETPALETTE (WM_USER+38) -#define RB_MOVEBAND (WM_USER+39) -#define RB_GETBANDMARGINS (WM_USER+40) -#define RB_PUSHCHEVRON (WM_USER+43) -#define RB_GETDROPTARGET CCM_GETDROPTARGET -#define RB_SETCOLORSCHEME CCM_SETCOLORSCHEME -#define RB_GETCOLORSCHEME CCM_GETCOLORSCHEME -#define RB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define RB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define RB_SETWINDOWTHEME CCM_SETWINDOWTHEME - -#define RBN_FIRST (0U-831U) -#define RBN_LAST (0U-859U) -#define RBN_HEIGHTCHANGE (RBN_FIRST-0) -#define RBN_GETOBJECT (RBN_FIRST-1) -#define RBN_LAYOUTCHANGED (RBN_FIRST-2) -#define RBN_AUTOSIZE (RBN_FIRST-3) -#define RBN_BEGINDRAG (RBN_FIRST-4) -#define RBN_ENDDRAG (RBN_FIRST-5) -#define RBN_DELETINGBAND (RBN_FIRST-6) -#define RBN_DELETEDBAND (RBN_FIRST-7) -#define RBN_CHILDSIZE (RBN_FIRST-8) -#define RBN_CHEVRONPUSHED (RBN_FIRST-10) -#define RBN_MINMAX (RBN_FIRST-21) -#define RBN_AUTOBREAK (RBN_FIRST-22) - -#define RBSTR_CHANGERECT 0x0001 - -typedef struct tagREBARINFO -{ - UINT cbSize; - UINT fMask; - HIMAGELIST himl; -} REBARINFO, *LPREBARINFO; - -typedef struct tagREBARBANDINFOA -{ - UINT cbSize; - UINT fMask; - UINT fStyle; - COLORREF clrFore; - COLORREF clrBack; - LPSTR lpText; - UINT cch; - INT iImage; - HWND hwndChild; - UINT cxMinChild; - UINT cyMinChild; - UINT cx; - HBITMAP hbmBack; - UINT wID; - UINT cyChild; - UINT cyMaxChild; - UINT cyIntegral; - UINT cxIdeal; - LPARAM lParam; - UINT cxHeader; - /* _WIN32_WINNT >= 0x0600 */ - RECT rcChevronLocation; - UINT uChevronState; -} REBARBANDINFOA, *LPREBARBANDINFOA; - -typedef REBARBANDINFOA const *LPCREBARBANDINFOA; - -typedef struct tagREBARBANDINFOW -{ - UINT cbSize; - UINT fMask; - UINT fStyle; - COLORREF clrFore; - COLORREF clrBack; - LPWSTR lpText; - UINT cch; - INT iImage; - HWND hwndChild; - UINT cxMinChild; - UINT cyMinChild; - UINT cx; - HBITMAP hbmBack; - UINT wID; - UINT cyChild; - UINT cyMaxChild; - UINT cyIntegral; - UINT cxIdeal; - LPARAM lParam; - UINT cxHeader; - /* _WIN32_WINNT >= 0x0600 */ - RECT rcChevronLocation; - UINT uChevronState; -} REBARBANDINFOW, *LPREBARBANDINFOW; - -typedef REBARBANDINFOW const *LPCREBARBANDINFOW; - -#define REBARBANDINFO WINELIB_NAME_AW(REBARBANDINFO) -#define LPREBARBANDINFO WINELIB_NAME_AW(LPREBARBANDINFO) -#define LPCREBARBANDINFO WINELIB_NAME_AW(LPCREBARBANDINFO) - -#define REBARBANDINFOA_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOA, wID) -#define REBARBANDINFOW_V3_SIZE CCSIZEOF_STRUCT(REBARBANDINFOW, wID) -#define REBARBANDINFO_V3_SIZE CCSIZEOF_STRUCT(WINELIB_NAME_AW(REBARBANDINFO), wID) -#define REBARBANDINFOA_V6_SIZE CCSIZEOF_STRUCT(REBARBANDINFOA, cxHeader) -#define REBARBANDINFOW_V6_SIZE CCSIZEOF_STRUCT(REBARBANDINFOW, cxHeader) -#define REBARBANDINFO_V6_SIZE CCSIZEOF_STRUCT(WINELIB_NAME_AW(REBARBANDINFO), cxHeader) - -typedef struct tagNMREBARCHILDSIZE -{ - NMHDR hdr; - UINT uBand; - UINT wID; - RECT rcChild; - RECT rcBand; -} NMREBARCHILDSIZE, *LPNMREBARCHILDSIZE; - -typedef struct tagNMREBAR -{ - NMHDR hdr; - DWORD dwMask; - UINT uBand; - UINT fStyle; - UINT wID; - LPARAM lParam; -} NMREBAR, *LPNMREBAR; - -typedef struct tagNMRBAUTOSIZE -{ - NMHDR hdr; - BOOL fChanged; - RECT rcTarget; - RECT rcActual; -} NMRBAUTOSIZE, *LPNMRBAUTOSIZE; - -typedef struct tagNMREBARCHEVRON -{ - NMHDR hdr; - UINT uBand; - UINT wID; - LPARAM lParam; - RECT rc; - LPARAM lParamNM; -} NMREBARCHEVRON, *LPNMREBARCHEVRON; - -typedef struct _RB_HITTESTINFO -{ + typedef struct _TT_HITTESTINFOA { + HWND hwnd; POINT pt; - UINT flags; - INT iBand; -} RBHITTESTINFO, *LPRBHITTESTINFO; + TTTOOLINFOA ti; + } TTHITTESTINFOA,*LPTTHITTESTINFOA; -#define RBAB_AUTOSIZE 0x0001 -#define RBAB_ADDBAND 0x0002 + typedef struct _TT_HITTESTINFOW { + HWND hwnd; + POINT pt; + TTTOOLINFOW ti; + } TTHITTESTINFOW,*LPTTHITTESTINFOW; -typedef struct tagNMREBARAUTOBREAK -{ - NMHDR hdr; - UINT uBand; - UINT wID; - LPARAM lParam; - UINT uMsg; - UINT fStyleCurrent; - BOOL fAutoBreak; -} NMREBARAUTOBREAK, *LPNMREBARAUTOBREAK; - - -/* Trackbar control */ - -#define TRACKBAR_CLASSA "msctls_trackbar32" -#if defined(__GNUC__) -# define TRACKBAR_CLASSW (const WCHAR []){ 'm','s','c','t','l','s','_', \ - 't','r','a','c','k','b','a','r','3','2',0 } -#elif defined(_MSC_VER) -# define TRACKBAR_CLASSW L"msctls_trackbar32" +#ifdef UNICODE +#define TTHITTESTINFO TTHITTESTINFOW +#define LPTTHITTESTINFO LPTTHITTESTINFOW #else -static const WCHAR TRACKBAR_CLASSW[] = { 'm','s','c','t','l','s','_', - 't','r','a','c','k','b','a','r','3','2',0 }; +#define TTHITTESTINFO TTHITTESTINFOA +#define LPTTHITTESTINFO LPTTHITTESTINFOA #endif -#define TRACKBAR_CLASS WINELIB_NAME_AW(TRACKBAR_CLASS) -#define TBS_AUTOTICKS 0x0001 -#define TBS_VERT 0x0002 -#define TBS_HORZ 0x0000 -#define TBS_TOP 0x0004 -#define TBS_BOTTOM 0x0000 -#define TBS_LEFT 0x0004 -#define TBS_RIGHT 0x0000 -#define TBS_BOTH 0x0008 -#define TBS_NOTICKS 0x0010 -#define TBS_ENABLESELRANGE 0x0020 -#define TBS_FIXEDLENGTH 0x0040 -#define TBS_NOTHUMB 0x0080 -#define TBS_TOOLTIPS 0x0100 -#define TBS_REVERSED 0x0200 -#define TBS_DOWNISLEFT 0x0400 +#define TTN_GETDISPINFOA (TTN_FIRST - 0) +#define TTN_GETDISPINFOW (TTN_FIRST - 10) +#define TTN_SHOW (TTN_FIRST - 1) +#define TTN_POP (TTN_FIRST - 2) +#define TTN_LINKCLICK (TTN_FIRST - 3) -#define TBTS_TOP 0 -#define TBTS_LEFT 1 -#define TBTS_BOTTOM 2 -#define TBTS_RIGHT 3 - -#define TB_LINEUP 0 -#define TB_LINEDOWN 1 -#define TB_PAGEUP 2 -#define TB_PAGEDOWN 3 -#define TB_THUMBPOSITION 4 -#define TB_THUMBTRACK 5 -#define TB_TOP 6 -#define TB_BOTTOM 7 -#define TB_ENDTRACK 8 - -#define TBCD_TICS 0x0001 -#define TBCD_THUMB 0x0002 -#define TBCD_CHANNEL 0x0003 - -#define TBM_GETPOS (WM_USER) -#define TBM_GETRANGEMIN (WM_USER+1) -#define TBM_GETRANGEMAX (WM_USER+2) -#define TBM_GETTIC (WM_USER+3) -#define TBM_SETTIC (WM_USER+4) -#define TBM_SETPOS (WM_USER+5) -#define TBM_SETRANGE (WM_USER+6) -#define TBM_SETRANGEMIN (WM_USER+7) -#define TBM_SETRANGEMAX (WM_USER+8) -#define TBM_CLEARTICS (WM_USER+9) -#define TBM_SETSEL (WM_USER+10) -#define TBM_SETSELSTART (WM_USER+11) -#define TBM_SETSELEND (WM_USER+12) -#define TBM_GETPTICS (WM_USER+14) -#define TBM_GETTICPOS (WM_USER+15) -#define TBM_GETNUMTICS (WM_USER+16) -#define TBM_GETSELSTART (WM_USER+17) -#define TBM_GETSELEND (WM_USER+18) -#define TBM_CLEARSEL (WM_USER+19) -#define TBM_SETTICFREQ (WM_USER+20) -#define TBM_SETPAGESIZE (WM_USER+21) -#define TBM_GETPAGESIZE (WM_USER+22) -#define TBM_SETLINESIZE (WM_USER+23) -#define TBM_GETLINESIZE (WM_USER+24) -#define TBM_GETTHUMBRECT (WM_USER+25) -#define TBM_GETCHANNELRECT (WM_USER+26) -#define TBM_SETTHUMBLENGTH (WM_USER+27) -#define TBM_GETTHUMBLENGTH (WM_USER+28) -#define TBM_SETTOOLTIPS (WM_USER+29) -#define TBM_GETTOOLTIPS (WM_USER+30) -#define TBM_SETTIPSIDE (WM_USER+31) -#define TBM_SETBUDDY (WM_USER+32) -#define TBM_GETBUDDY (WM_USER+33) -#define TBM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define TBM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT - - -/* Pager control */ - -#define WC_PAGESCROLLERA "SysPager" -#if defined(__GNUC__) -# define WC_PAGESCROLLERW (const WCHAR []){ 'S','y','s','P','a','g','e','r',0 } -#elif defined(_MSC_VER) -# define WC_PAGESCROLLERW L"SysPager" +#ifdef UNICODE +#define TTN_GETDISPINFO TTN_GETDISPINFOW #else -static const WCHAR WC_PAGESCROLLERW[] = { 'S','y','s','P','a','g','e','r',0 }; +#define TTN_GETDISPINFO TTN_GETDISPINFOA #endif -#define WC_PAGESCROLLER WINELIB_NAME_AW(WC_PAGESCROLLER) -#define PGS_VERT 0x00000000 -#define PGS_HORZ 0x00000001 -#define PGS_AUTOSCROLL 0x00000002 -#define PGS_DRAGNDROP 0x00000004 +#define TTN_NEEDTEXT TTN_GETDISPINFO +#define TTN_NEEDTEXTA TTN_GETDISPINFOA +#define TTN_NEEDTEXTW TTN_GETDISPINFOW -#define PGF_INVISIBLE 0 -#define PGF_NORMAL 1 -#define PGF_GRAYED 2 -#define PGF_DEPRESSED 4 -#define PGF_HOT 8 +#define TOOLTIPTEXTW NMTTDISPINFOW +#define TOOLTIPTEXTA NMTTDISPINFOA +#define LPTOOLTIPTEXTA LPNMTTDISPINFOA +#define LPTOOLTIPTEXTW LPNMTTDISPINFOW -#define PGB_TOPORLEFT 0 -#define PGB_BOTTOMORRIGHT 1 +#define TOOLTIPTEXT NMTTDISPINFO +#define LPTOOLTIPTEXT LPNMTTDISPINFO -/* only used with PGN_SCROLL */ -#define PGF_SCROLLUP 1 -#define PGF_SCROLLDOWN 2 -#define PGF_SCROLLLEFT 4 -#define PGF_SCROLLRIGHT 8 +#define NMTTDISPINFOA_V1_SIZE CCSIZEOF_STRUCT(NMTTDISPINFOA,uFlags) +#define NMTTDISPINFOW_V1_SIZE CCSIZEOF_STRUCT(NMTTDISPINFOW,uFlags) -#define PGK_SHIFT 1 -#define PGK_CONTROL 2 -#define PGK_MENU 4 - -/* only used with PGN_CALCSIZE */ -#define PGF_CALCWIDTH 1 -#define PGF_CALCHEIGHT 2 - -#define PGM_FIRST 0x1400 -#define PGM_SETCHILD (PGM_FIRST+1) -#define PGM_RECALCSIZE (PGM_FIRST+2) -#define PGM_FORWARDMOUSE (PGM_FIRST+3) -#define PGM_SETBKCOLOR (PGM_FIRST+4) -#define PGM_GETBKCOLOR (PGM_FIRST+5) -#define PGM_SETBORDER (PGM_FIRST+6) -#define PGM_GETBORDER (PGM_FIRST+7) -#define PGM_SETPOS (PGM_FIRST+8) -#define PGM_GETPOS (PGM_FIRST+9) -#define PGM_SETBUTTONSIZE (PGM_FIRST+10) -#define PGM_GETBUTTONSIZE (PGM_FIRST+11) -#define PGM_GETBUTTONSTATE (PGM_FIRST+12) -#define PGM_GETDROPTARGET CCM_GETDROPTARGET - -#define PGN_FIRST (0U-900U) -#define PGN_LAST (0U-950U) -#define PGN_SCROLL (PGN_FIRST-1) -#define PGN_CALCSIZE (PGN_FIRST-2) - -#include - -typedef struct -{ + typedef struct tagNMTTDISPINFOA { NMHDR hdr; - WORD fwKeys; - RECT rcParent; - INT iDir; - INT iXpos; - INT iYpos; - INT iScroll; -} NMPGSCROLL, *LPNMPGSCROLL; + LPSTR lpszText; + char szText[80]; + HINSTANCE hinst; + UINT uFlags; + LPARAM lParam; + } NMTTDISPINFOA,*LPNMTTDISPINFOA; -#include - -typedef struct -{ + typedef struct tagNMTTDISPINFOW { NMHDR hdr; - DWORD dwFlag; - INT iWidth; - INT iHeight; -} NMPGCALCSIZE, *LPNMPGCALCSIZE; + LPWSTR lpszText; + WCHAR szText[80]; + HINSTANCE hinst; + UINT uFlags; + LPARAM lParam; + } NMTTDISPINFOW,*LPNMTTDISPINFOW; - -/* Treeview control */ - -#define WC_TREEVIEWA "SysTreeView32" -#if defined(__GNUC__) -# define WC_TREEVIEWW (const WCHAR []){ 'S','y','s', \ - 'T','r','e','e','V','i','e','w','3','2',0 } -#elif defined(_MSC_VER) -# define WC_TREEVIEWW L"SysTreeView32" +#ifdef UNICODE +#define NMTTDISPINFO NMTTDISPINFOW +#define LPNMTTDISPINFO LPNMTTDISPINFOW +#define NMTTDISPINFO_V1_SIZE NMTTDISPINFOW_V1_SIZE #else -static const WCHAR WC_TREEVIEWW[] = { 'S','y','s', - 'T','r','e','e','V','i','e','w','3','2',0 }; +#define NMTTDISPINFO NMTTDISPINFOA +#define LPNMTTDISPINFO LPNMTTDISPINFOA +#define NMTTDISPINFO_V1_SIZE NMTTDISPINFOA_V1_SIZE +#endif #endif -#define WC_TREEVIEW WINELIB_NAME_AW(WC_TREEVIEW) -#define TVSIL_NORMAL 0 -#define TVSIL_STATE 2 +#ifndef NOSTATUSBAR -#define TV_FIRST 0x1100 -#define TVM_INSERTITEMA (TV_FIRST+0) -#define TVM_INSERTITEMW (TV_FIRST+50) -#define TVM_INSERTITEM WINELIB_NAME_AW(TVM_INSERTITEM) -#define TVM_DELETEITEM (TV_FIRST+1) -#define TVM_EXPAND (TV_FIRST+2) -#define TVM_GETITEMRECT (TV_FIRST+4) -#define TVM_GETCOUNT (TV_FIRST+5) -#define TVM_GETINDENT (TV_FIRST+6) -#define TVM_SETINDENT (TV_FIRST+7) -#define TVM_GETIMAGELIST (TV_FIRST+8) -#define TVM_SETIMAGELIST (TV_FIRST+9) -#define TVM_GETNEXTITEM (TV_FIRST+10) -#define TVM_SELECTITEM (TV_FIRST+11) -#define TVM_GETITEMA (TV_FIRST+12) -#define TVM_GETITEMW (TV_FIRST+62) -#define TVM_GETITEM WINELIB_NAME_AW(TVM_GETITEM) -#define TVM_SETITEMA (TV_FIRST+13) -#define TVM_SETITEMW (TV_FIRST+63) -#define TVM_SETITEM WINELIB_NAME_AW(TVM_SETITEM) -#define TVM_EDITLABELA (TV_FIRST+14) -#define TVM_EDITLABELW (TV_FIRST+65) -#define TVM_EDITLABEL WINELIB_NAME_AW(TVM_EDITLABEL) -#define TVM_GETEDITCONTROL (TV_FIRST+15) -#define TVM_GETVISIBLECOUNT (TV_FIRST+16) -#define TVM_HITTEST (TV_FIRST+17) -#define TVM_CREATEDRAGIMAGE (TV_FIRST+18) -#define TVM_SORTCHILDREN (TV_FIRST+19) -#define TVM_ENSUREVISIBLE (TV_FIRST+20) -#define TVM_SORTCHILDRENCB (TV_FIRST+21) -#define TVM_ENDEDITLABELNOW (TV_FIRST+22) -#define TVM_GETISEARCHSTRINGA (TV_FIRST+23) -#define TVM_GETISEARCHSTRINGW (TV_FIRST+64) -#define TVM_GETISEARCHSTRING WINELIB_NAME_AW(TVM_GETISEARCHSTRING) -#define TVM_SETTOOLTIPS (TV_FIRST+24) -#define TVM_GETTOOLTIPS (TV_FIRST+25) -#define TVM_SETINSERTMARK (TV_FIRST+26) -#define TVM_SETITEMHEIGHT (TV_FIRST+27) -#define TVM_GETITEMHEIGHT (TV_FIRST+28) -#define TVM_SETBKCOLOR (TV_FIRST+29) -#define TVM_SETTEXTCOLOR (TV_FIRST+30) -#define TVM_GETBKCOLOR (TV_FIRST+31) -#define TVM_GETTEXTCOLOR (TV_FIRST+32) -#define TVM_SETSCROLLTIME (TV_FIRST+33) -#define TVM_GETSCROLLTIME (TV_FIRST+34) -#define TVM_UNKNOWN35 (TV_FIRST+35) -#define TVM_UNKNOWN36 (TV_FIRST+36) -#define TVM_SETINSERTMARKCOLOR (TV_FIRST+37) -#define TVM_GETINSERTMARKCOLOR (TV_FIRST+38) -#define TVM_GETITEMSTATE (TV_FIRST+39) -#define TVM_SETLINECOLOR (TV_FIRST+40) -#define TVM_GETLINECOLOR (TV_FIRST+41) -#define TVM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define TVM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define TVM_MAPACCIDTOHTREEITEM (TV_FIRST + 42) -#define TVM_MAPHTREEITEMTOACCID (TV_FIRST + 43) +#define SBARS_SIZEGRIP 0x100 +#define SBARS_TOOLTIPS 0x800 +#define SBT_TOOLTIPS 0x800 + WINCOMMCTRLAPI void WINAPI DrawStatusTextA(HDC hDC,LPCRECT lprc,LPCSTR pszText,UINT uFlags); + WINCOMMCTRLAPI void WINAPI DrawStatusTextW(HDC hDC,LPCRECT lprc,LPCWSTR pszText,UINT uFlags); -#define TVN_FIRST (0U-400U) -#define TVN_LAST (0U-499U) + WINCOMMCTRLAPI HWND WINAPI CreateStatusWindowA(LONG style,LPCSTR lpszText,HWND hwndParent,UINT wID); + WINCOMMCTRLAPI HWND WINAPI CreateStatusWindowW(LONG style,LPCWSTR lpszText,HWND hwndParent,UINT wID); -#define TVN_SELCHANGINGA (TVN_FIRST-1) -#define TVN_SELCHANGINGW (TVN_FIRST-50) -#define TVN_SELCHANGING WINELIB_NAME_AW(TVN_SELCHANGING) - -#define TVN_SELCHANGEDA (TVN_FIRST-2) -#define TVN_SELCHANGEDW (TVN_FIRST-51) -#define TVN_SELCHANGED WINELIB_NAME_AW(TVN_SELCHANGED) - -#define TVN_GETDISPINFOA (TVN_FIRST-3) -#define TVN_GETDISPINFOW (TVN_FIRST-52) -#define TVN_GETDISPINFO WINELIB_NAME_AW(TVN_GETDISPINFO) - -#define TVN_SETDISPINFOA (TVN_FIRST-4) -#define TVN_SETDISPINFOW (TVN_FIRST-53) -#define TVN_SETDISPINFO WINELIB_NAME_AW(TVN_SETDISPINFO) - -#define TVN_ITEMEXPANDINGA (TVN_FIRST-5) -#define TVN_ITEMEXPANDINGW (TVN_FIRST-54) -#define TVN_ITEMEXPANDING WINELIB_NAME_AW(TVN_ITEMEXPANDING) - -#define TVN_ITEMEXPANDEDA (TVN_FIRST-6) -#define TVN_ITEMEXPANDEDW (TVN_FIRST-55) -#define TVN_ITEMEXPANDED WINELIB_NAME_AW(TVN_ITEMEXPANDED) - -#define TVN_BEGINDRAGA (TVN_FIRST-7) -#define TVN_BEGINDRAGW (TVN_FIRST-56) -#define TVN_BEGINDRAG WINELIB_NAME_AW(TVN_BEGINDRAG) - -#define TVN_BEGINRDRAGA (TVN_FIRST-8) -#define TVN_BEGINRDRAGW (TVN_FIRST-57) -#define TVN_BEGINRDRAG WINELIB_NAME_AW(TVN_BEGINRDRAG) - -#define TVN_DELETEITEMA (TVN_FIRST-9) -#define TVN_DELETEITEMW (TVN_FIRST-58) -#define TVN_DELETEITEM WINELIB_NAME_AW(TVN_DELETEITEM) - -#define TVN_BEGINLABELEDITA (TVN_FIRST-10) -#define TVN_BEGINLABELEDITW (TVN_FIRST-59) -#define TVN_BEGINLABELEDIT WINELIB_NAME_AW(TVN_BEGINLABELEDIT) - -#define TVN_ENDLABELEDITA (TVN_FIRST-11) -#define TVN_ENDLABELEDITW (TVN_FIRST-60) -#define TVN_ENDLABELEDIT WINELIB_NAME_AW(TVN_ENDLABELEDIT) - -#define TVN_KEYDOWN (TVN_FIRST-12) - -#define TVN_GETINFOTIPA (TVN_FIRST-13) -#define TVN_GETINFOTIPW (TVN_FIRST-14) -#define TVN_GETINFOTIP WINELIB_NAME_AW(TVN_GETINFOTIP) - -#define TVN_SINGLEEXPAND (TVN_FIRST-15) - - - - - -#define TVIF_TEXT 0x0001 -#define TVIF_IMAGE 0x0002 -#define TVIF_PARAM 0x0004 -#define TVIF_STATE 0x0008 -#define TVIF_HANDLE 0x0010 -#define TVIF_SELECTEDIMAGE 0x0020 -#define TVIF_CHILDREN 0x0040 -#define TVIF_INTEGRAL 0x0080 -#define TVIF_DI_SETITEM 0x1000 - -#define TVI_ROOT ((HTREEITEM)-65536) -#define TVI_FIRST ((HTREEITEM)-65535) -#define TVI_LAST ((HTREEITEM)-65534) -#define TVI_SORT ((HTREEITEM)-65533) - -#define TVIS_FOCUSED 0x0001 -#define TVIS_SELECTED 0x0002 -#define TVIS_CUT 0x0004 -#define TVIS_DROPHILITED 0x0008 -#define TVIS_BOLD 0x0010 -#define TVIS_EXPANDED 0x0020 -#define TVIS_EXPANDEDONCE 0x0040 -#define TVIS_EXPANDPARTIAL 0x0080 -#define TVIS_OVERLAYMASK 0x0f00 -#define TVIS_STATEIMAGEMASK 0xf000 -#define TVIS_USERMASK 0xf000 - -#define TVHT_NOWHERE 0x0001 -#define TVHT_ONITEMICON 0x0002 -#define TVHT_ONITEMLABEL 0x0004 -#define TVHT_ONITEMINDENT 0x0008 -#define TVHT_ONITEMBUTTON 0x0010 -#define TVHT_ONITEMRIGHT 0x0020 -#define TVHT_ONITEMSTATEICON 0x0040 -#define TVHT_ONITEM 0x0046 -#define TVHT_ABOVE 0x0100 -#define TVHT_BELOW 0x0200 -#define TVHT_TORIGHT 0x0400 -#define TVHT_TOLEFT 0x0800 - -#define TVS_HASBUTTONS 0x0001 -#define TVS_HASLINES 0x0002 -#define TVS_LINESATROOT 0x0004 -#define TVS_EDITLABELS 0x0008 -#define TVS_DISABLEDRAGDROP 0x0010 -#define TVS_SHOWSELALWAYS 0x0020 -#define TVS_RTLREADING 0x0040 -#define TVS_NOTOOLTIPS 0x0080 -#define TVS_CHECKBOXES 0x0100 -#define TVS_TRACKSELECT 0x0200 -#define TVS_SINGLEEXPAND 0x0400 -#define TVS_INFOTIP 0x0800 -#define TVS_FULLROWSELECT 0x1000 -#define TVS_NOSCROLL 0x2000 -#define TVS_NONEVENHEIGHT 0x4000 -#define TVS_NOHSCROLL 0x8000 - -#define TVS_SHAREDIMAGELISTS 0x0000 -#define TVS_PRIVATEIMAGELISTS 0x0400 - - -#define TVE_COLLAPSE 0x0001 -#define TVE_EXPAND 0x0002 -#define TVE_TOGGLE 0x0003 -#define TVE_EXPANDPARTIAL 0x4000 -#define TVE_COLLAPSERESET 0x8000 - -#define TVGN_ROOT 0 -#define TVGN_NEXT 1 -#define TVGN_PREVIOUS 2 -#define TVGN_PARENT 3 -#define TVGN_CHILD 4 -#define TVGN_FIRSTVISIBLE 5 -#define TVGN_NEXTVISIBLE 6 -#define TVGN_PREVIOUSVISIBLE 7 -#define TVGN_DROPHILITE 8 -#define TVGN_CARET 9 -#define TVGN_LASTVISIBLE 10 -#define TVSI_NOSINGLEEXPAND 0x8000 - -#define TVC_UNKNOWN 0x00 -#define TVC_BYMOUSE 0x01 -#define TVC_BYKEYBOARD 0x02 - - -typedef struct _TREEITEM *HTREEITEM; - -typedef struct { - UINT mask; - HTREEITEM hItem; - UINT state; - UINT stateMask; - LPSTR pszText; - INT cchTextMax; - INT iImage; - INT iSelectedImage; - INT cChildren; - LPARAM lParam; -} TVITEMA, *LPTVITEMA; - -typedef struct { - UINT mask; - HTREEITEM hItem; - UINT state; - UINT stateMask; - LPWSTR pszText; - INT cchTextMax; - INT iImage; - INT iSelectedImage; - INT cChildren; - LPARAM lParam; -} TVITEMW, *LPTVITEMW; - -#define TV_ITEMA TVITEMA -#define TV_ITEMW TVITEMW -#define LPTV_ITEMA LPTVITEMA -#define LPTV_ITEMW LPTVITEMW - -#define TVITEM WINELIB_NAME_AW(TVITEM) -#define LPTVITEM WINELIB_NAME_AW(LPTVITEM) -#define TV_ITEM WINELIB_NAME_AW(TV_ITEM) -#define LPTV_ITEM WINELIB_NAME_AW(LPTV_ITEM) - -typedef struct { - UINT mask; - HTREEITEM hItem; - UINT state; - UINT stateMask; - LPSTR pszText; - INT cchTextMax; - INT iImage; - INT iSelectedImage; - INT cChildren; - LPARAM lParam; - INT iIntegral; - UINT uStateEx; /* _WIN32_IE >= 0x600 */ - HWND hwnd; /* _WIN32_IE >= 0x600 */ - INT iExpandedImage; /* _WIN32_IE >= 0x600 */ -} TVITEMEXA, *LPTVITEMEXA; - -typedef struct { - UINT mask; - HTREEITEM hItem; - UINT state; - UINT stateMask; - LPWSTR pszText; - INT cchTextMax; - INT iImage; - INT iSelectedImage; - INT cChildren; - LPARAM lParam; - INT iIntegral; - UINT uStateEx; /* _WIN32_IE >= 0x600 */ - HWND hwnd; /* _WIN32_IE >= 0x600 */ - INT iExpandedImage; /* _WIN32_IE >= 0x600 */ -} TVITEMEXW, *LPTVITEMEXW; - -#define TVITEMEX WINELIB_NAME_AW(TVITEMEX) -#define LPTVITEMEX WINELIB_NAME_AW(LPTVITEMEX) - -typedef struct tagTVINSERTSTRUCTA { - HTREEITEM hParent; - HTREEITEM hInsertAfter; - union { - TVITEMEXA itemex; - TVITEMA item; - } DUMMYUNIONNAME; -} TVINSERTSTRUCTA, *LPTVINSERTSTRUCTA; - -typedef struct tagTVINSERTSTRUCTW { - HTREEITEM hParent; - HTREEITEM hInsertAfter; - union { - TVITEMEXW itemex; - TVITEMW item; - } DUMMYUNIONNAME; -} TVINSERTSTRUCTW, *LPTVINSERTSTRUCTW; - -#define TVINSERTSTRUCT WINELIB_NAME_AW(TVINSERTSTRUCT) -#define LPTVINSERTSTRUCT WINELIB_NAME_AW(LPTVINSERTSTRUCT) - -#define TVINSERTSTRUCT_V1_SIZEA CCSIZEOF_STRUCT(TVINSERTSTRUCTA, item) -#define TVINSERTSTRUCT_V1_SIZEW CCSIZEOF_STRUCT(TVINSERTSTRUCTW, item) -#define TVINSERTSTRUCT_V1_SIZE WINELIB_NAME_AW(TVINSERTSTRUCT_V1_SIZE) - -#define TV_INSERTSTRUCT TVINSERTSTRUCT -#define TV_INSERTSTRUCTA TVINSERTSTRUCTA -#define TV_INSERTSTRUCTW TVINSERTSTRUCTW -#define LPTV_INSERTSTRUCT LPTVINSERTSTRUCT -#define LPTV_INSERTSTRUCTA LPTVINSERTSTRUCTA -#define LPTV_INSERTSTRUCTW LPTVINSERTSTRUCTW - - - -typedef struct tagNMTREEVIEWA { - NMHDR hdr; - UINT action; - TVITEMA itemOld; - TVITEMA itemNew; - POINT ptDrag; -} NMTREEVIEWA, *LPNMTREEVIEWA; - -typedef struct tagNMTREEVIEWW { - NMHDR hdr; - UINT action; - TVITEMW itemOld; - TVITEMW itemNew; - POINT ptDrag; -} NMTREEVIEWW, *LPNMTREEVIEWW; - -#define NMTREEVIEW WINELIB_NAME_AW(NMTREEVIEW) -#define NM_TREEVIEW WINELIB_NAME_AW(NMTREEVIEW) -#define NM_TREEVIEWA NMTREEVIEWA -#define NM_TREEVIEWW NMTREEVIEWW -#define LPNMTREEVIEW WINELIB_NAME_AW(LPNMTREEVIEW) - -#define LPNM_TREEVIEW LPNMTREEVIEW -#define LPNM_TREEVIEWA LPNMTREEVIEWA -#define LPNM_TREEVIEWW LPNMTREEVIEWW - -typedef struct tagTVDISPINFOA { - NMHDR hdr; - TVITEMA item; -} NMTVDISPINFOA, *LPNMTVDISPINFOA; - -typedef struct tagTVDISPINFOW { - NMHDR hdr; - TVITEMW item; -} NMTVDISPINFOW, *LPNMTVDISPINFOW; - -typedef struct tagTVDISPINFOEXA { - NMHDR hdr; - TVITEMEXA item; -} NMTVDISPINFOEXA, *LPNMTVDISPINFOEXA; - -typedef struct tagTVDISPINFOEXW { - NMHDR hdr; - TVITEMEXW item; -} NMTVDISPINFOEXW, *LPNMTVDISPINFOEXW; - -#define NMTVDISPINFO WINELIB_NAME_AW(NMTVDISPINFO) -#define LPNMTVDISPINFO WINELIB_NAME_AW(LPNMTVDISPINFO) -#define NMTVDISPINFOEX WINELIB_NAME_AW(NMTVDISPINFOEX) -#define LPNMTVDISPINFOEX WINELIB_NAME_AW(LPNMTVDISPINFOEX) -#define TV_DISPINFOA NMTVDISPINFOA -#define TV_DISPINFOW NMTVDISPINFOW -#define TV_DISPINFO NMTVDISPINFO - -typedef INT (CALLBACK *PFNTVCOMPARE)(LPARAM, LPARAM, LPARAM); - -typedef struct tagTVSORTCB -{ - HTREEITEM hParent; - PFNTVCOMPARE lpfnCompare; - LPARAM lParam; -} TVSORTCB, *LPTVSORTCB; - -#define TV_SORTCB TVSORTCB -#define LPTV_SORTCB LPTVSORTCB - -typedef struct tagTVHITTESTINFO { - POINT pt; - UINT flags; - HTREEITEM hItem; -} TVHITTESTINFO, *LPTVHITTESTINFO; - -#define TV_HITTESTINFO TVHITTESTINFO - - -/* Custom Draw Treeview */ - -#define NMTVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMTVCUSTOMDRAW, clrTextBk) - -#define TVCDRF_NOIMAGES 0x00010000 - -typedef struct tagNMTVCUSTOMDRAW -{ - NMCUSTOMDRAW nmcd; - COLORREF clrText; - COLORREF clrTextBk; - INT iLevel; /* IE>0x0400 */ -} NMTVCUSTOMDRAW, *LPNMTVCUSTOMDRAW; - -/* Treeview tooltips */ - -typedef struct tagNMTVGETINFOTIPA -{ - NMHDR hdr; - LPSTR pszText; - INT cchTextMax; - HTREEITEM hItem; - LPARAM lParam; -} NMTVGETINFOTIPA, *LPNMTVGETINFOTIPA; - -typedef struct tagNMTVGETINFOTIPW -{ - NMHDR hdr; - LPWSTR pszText; - INT cchTextMax; - HTREEITEM hItem; - LPARAM lParam; -} NMTVGETINFOTIPW, *LPNMTVGETINFOTIPW; - -#define NMTVGETINFOTIP WINELIB_NAME_AW(NMTVGETINFOTIP) -#define LPNMTVGETINFOTIP WINELIB_NAME_AW(LPNMTVGETINFOTIP) - -#include -typedef struct tagTVKEYDOWN -{ - NMHDR hdr; - WORD wVKey; - UINT flags; -} NMTVKEYDOWN, *LPNMTVKEYDOWN; -#include - -#define TV_KEYDOWN NMTVKEYDOWN - -#define TreeView_InsertItemA(hwnd, phdi) \ - (HTREEITEM)SNDMSGA((hwnd), TVM_INSERTITEMA, 0, \ - (LPARAM)(LPTVINSERTSTRUCTA)(phdi)) -#define TreeView_InsertItemW(hwnd,phdi) \ - (HTREEITEM)SNDMSGW((hwnd), TVM_INSERTITEMW, 0, \ - (LPARAM)(LPTVINSERTSTRUCTW)(phdi)) -#define TreeView_InsertItem WINELIB_NAME_AW(TreeView_InsertItem) - -#define TreeView_DeleteItem(hwnd, hItem) \ - (BOOL)SNDMSG((hwnd), TVM_DELETEITEM, 0, (LPARAM)(HTREEITEM)(hItem)) -#define TreeView_DeleteAllItems(hwnd) \ - (BOOL)SNDMSG((hwnd), TVM_DELETEITEM, 0, (LPARAM)TVI_ROOT) -#define TreeView_Expand(hwnd, hitem, code) \ - (BOOL)SNDMSG((hwnd), TVM_EXPAND, (WPARAM)code, \ - (LPARAM)(HTREEITEM)(hitem)) - -#define TreeView_GetItemRect(hwnd, hitem, prc, code) \ - (*(HTREEITEM *)prc = (hitem), (BOOL)SNDMSG((hwnd), \ - TVM_GETITEMRECT, (WPARAM)(code), (LPARAM)(RECT *)(prc))) - -#define TreeView_GetCount(hwnd) \ - (UINT)SNDMSG((hwnd), TVM_GETCOUNT, 0, 0) -#define TreeView_GetIndent(hwnd) \ - (UINT)SNDMSG((hwnd), TVM_GETINDENT, 0, 0) -#define TreeView_SetIndent(hwnd, indent) \ - (BOOL)SNDMSG((hwnd), TVM_SETINDENT, (WPARAM)indent, 0) - -#define TreeView_GetImageList(hwnd, iImage) \ - (HIMAGELIST)SNDMSG((hwnd), TVM_GETIMAGELIST, iImage, 0) - -#define TreeView_SetImageList(hwnd, himl, iImage) \ - (HIMAGELIST)SNDMSG((hwnd), TVM_SETIMAGELIST, iImage, \ - (LPARAM)(HIMAGELIST)(himl)) - -#define TreeView_GetNextItem(hwnd, hitem, code) \ - (HTREEITEM)SNDMSG((hwnd), TVM_GETNEXTITEM, (WPARAM)code,\ -(LPARAM)(HTREEITEM) (hitem)) - -#define TreeView_GetChild(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_CHILD) -#define TreeView_GetNextSibling(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_NEXT) -#define TreeView_GetPrevSibling(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_PREVIOUS) -#define TreeView_GetParent(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_PARENT) -#define TreeView_GetFirstVisible(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_FIRSTVISIBLE) -#define TreeView_GetLastVisible(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_LASTVISIBLE) -#define TreeView_GetNextVisible(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_NEXTVISIBLE) -#define TreeView_GetPrevVisible(hwnd, hitem) \ - TreeView_GetNextItem(hwnd, hitem , TVGN_PREVIOUSVISIBLE) -#define TreeView_GetSelection(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_CARET) -#define TreeView_GetDropHilight(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_DROPHILITE) -#define TreeView_GetRoot(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_ROOT) -#define TreeView_GetLastVisible(hwnd) \ - TreeView_GetNextItem(hwnd, NULL, TVGN_LASTVISIBLE) - - -#define TreeView_Select(hwnd, hitem, code) \ - (BOOL)SNDMSG((hwnd), TVM_SELECTITEM, (WPARAM)(code), \ -(LPARAM)(HTREEITEM)(hitem)) - - -#define TreeView_SelectItem(hwnd, hitem) \ - TreeView_Select(hwnd, hitem, TVGN_CARET) -#define TreeView_SelectDropTarget(hwnd, hitem) \ - TreeView_Select(hwnd, hitem, TVGN_DROPHILITE) -#define TreeView_SelectSetFirstVisible(hwnd, hitem) \ - TreeView_Select(hwnd, hitem, TVGN_FIRSTVISIBLE) - - -#define TreeView_GetItemA(hwnd, pitem) \ - (BOOL)SNDMSGA((hwnd), TVM_GETITEMA, 0, (LPARAM) (TVITEMA *)(pitem)) -#define TreeView_GetItemW(hwnd, pitem) \ - (BOOL)SNDMSGW((hwnd), TVM_GETITEMW, 0, (LPARAM) (TVITEMW *)(pitem)) -#define TreeView_GetItem WINELIB_NAME_AW(TreeView_GetItem) - -#define TreeView_SetItemA(hwnd, pitem) \ - (BOOL)SNDMSGA((hwnd), TVM_SETITEMA, 0, (LPARAM)(const TVITEMA *)(pitem)) -#define TreeView_SetItemW(hwnd, pitem) \ - (BOOL)SNDMSGW((hwnd), TVM_SETITEMW, 0, (LPARAM)(const TVITEMW *)(pitem)) -#define TreeView_SetItem WINELIB_NAME_AW(TreeView_SetItem) - -#define TreeView_EditLabel(hwnd, hitem) \ - (HWND)SNDMSG((hwnd), TVM_EDITLABEL, 0, (LPARAM)(HTREEITEM)(hitem)) - -#define TreeView_GetEditControl(hwnd) \ - (HWND)SNDMSG((hwnd), TVM_GETEDITCONTROL, 0, 0) - -#define TreeView_GetVisibleCount(hwnd) \ - (UINT)SNDMSG((hwnd), TVM_GETVISIBLECOUNT, 0, 0) - -#define TreeView_HitTest(hwnd, lpht) \ - (HTREEITEM)SNDMSG((hwnd), TVM_HITTEST, 0,\ -(LPARAM)(LPTVHITTESTINFO)(lpht)) - -#define TreeView_CreateDragImage(hwnd, hitem) \ - (HIMAGELIST)SNDMSG((hwnd), TVM_CREATEDRAGIMAGE, 0,\ -(LPARAM)(HTREEITEM)(hitem)) - -#define TreeView_SortChildren(hwnd, hitem, recurse) \ - (BOOL)SNDMSG((hwnd), TVM_SORTCHILDREN, (WPARAM)recurse,\ -(LPARAM)(HTREEITEM)(hitem)) - -#define TreeView_EnsureVisible(hwnd, hitem) \ - (BOOL)SNDMSG((hwnd), TVM_ENSUREVISIBLE, 0, (LPARAM)(UINT)(hitem)) - -#define TreeView_SortChildrenCB(hwnd, psort, recurse) \ - (BOOL)SNDMSG((hwnd), TVM_SORTCHILDRENCB, (WPARAM)recurse, \ - (LPARAM)(LPTV_SORTCB)(psort)) - -#define TreeView_EndEditLabelNow(hwnd, fCancel) \ - (BOOL)SNDMSG((hwnd), TVM_ENDEDITLABELNOW, (WPARAM)fCancel, 0) - -#define TreeView_GetISearchString(hwnd, lpsz) \ - (BOOL)SNDMSG((hwnd), TVM_GETISEARCHSTRING, 0, \ - (LPARAM)(LPTSTR)lpsz) - -#define TreeView_SetToolTips(hwnd, hwndTT) \ - (HWND)SNDMSG((hwnd), TVM_SETTOOLTIPS, (WPARAM)(hwndTT), 0) - -#define TreeView_GetToolTips(hwnd) \ - (HWND)SNDMSG((hwnd), TVM_GETTOOLTIPS, 0, 0) - -#define TreeView_SetItemHeight(hwnd, iHeight) \ - (INT)SNDMSG((hwnd), TVM_SETITEMHEIGHT, (WPARAM)iHeight, 0) - -#define TreeView_GetItemHeight(hwnd) \ - (INT)SNDMSG((hwnd), TVM_GETITEMHEIGHT, 0, 0) - -#define TreeView_SetBkColor(hwnd, clr) \ - (COLORREF)SNDMSG((hwnd), TVM_SETBKCOLOR, 0, (LPARAM)clr) - -#define TreeView_SetTextColor(hwnd, clr) \ - (COLORREF)SNDMSG((hwnd), TVM_SETTEXTCOLOR, 0, (LPARAM)clr) - -#define TreeView_GetBkColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), TVM_GETBKCOLOR, 0, 0) - -#define TreeView_GetTextColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), TVM_GETTEXTCOLOR, 0, 0) - -#define TreeView_SetScrollTime(hwnd, uTime) \ - (UINT)SNDMSG((hwnd), TVM_SETSCROLLTIME, uTime, 0) - -#define TreeView_GetScrollTime(hwnd) \ - (UINT)SNDMSG((hwnd), TVM_GETSCROLLTIME, 0, 0) - -#define TreeView_SetInsertMark(hwnd, hItem, fAfter) \ - (BOOL)SNDMSG((hwnd), TVM_SETINSERTMARK, (WPARAM)(fAfter), \ - (LPARAM) (hItem)) - -#define TreeView_SetInsertMarkColor(hwnd, clr) \ - (COLORREF)SNDMSG((hwnd), TVM_SETINSERTMARKCOLOR, 0, (LPARAM)clr) - -#define TreeView_GetInsertMarkColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), TVM_GETINSERTMARKCOLOR, 0, 0) - -#define TreeView_SetItemState(hwndTV, hti, data, _mask) \ -{ TVITEM _TVi; \ - _TVi.mask = TVIF_STATE; \ - _TVi.hItem = hti; \ - _TVi.stateMask = _mask; \ - _TVi.state = data; \ - SNDMSG((hwndTV), TVM_SETITEM, 0, (LPARAM)&_TVi); \ -} - -#define TreeView_GetItemState(hwndTV, hti, mask) \ - (UINT)SNDMSG((hwndTV), TVM_GETITEMSTATE, (WPARAM)(hti), (LPARAM)(mask)) -#define TreeView_GetCheckState(hwndTV, hti) \ - ((((UINT)(SNDMSG((hwndTV), TVM_GETITEMSTATE, (WPARAM)(hti), \ - TVIS_STATEIMAGEMASK))) >> 12) -1) - -#define TreeView_SetLineColor(hwnd, clr) \ - (COLORREF)SNDMSG((hwnd), TVM_SETLINECOLOR, 0, (LPARAM)(clr)) - -#define TreeView_GetLineColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), TVM_GETLINECOLOR, 0, 0) - -#define TreeView_MapAccIDToHTREEITEM(hwnd, id) \ - (HTREEITEM)SNDMSG((hwnd), TVM_MAPACCIDTOHTREEITEM, id, 0) - -#define TreeView_MapHTREEITEMToAccID(hwnd, htreeitem) \ - (UINT)SNDMSG((hwnd), TVM_MAPHTREEITEMTOACCID, (WPARAM)htreeitem, 0) - -#define TreeView_SetUnicodeFormat(hwnd, fUnicode) \ - (BOOL)SNDMSG((hwnd), TVM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0) -#define TreeView_GetUnicodeFormat(hwnd) \ - (BOOL)SNDMSG((hwnd), TVM_GETUNICODEFORMAT, 0, 0) - -/* Listview control */ - -#define WC_LISTVIEWA "SysListView32" -#if defined(__GNUC__) -# define WC_LISTVIEWW (const WCHAR []){ 'S','y','s', \ - 'L','i','s','t','V','i','e','w','3','2',0 } -#elif defined(_MSC_VER) -# define WC_LISTVIEWW L"SysListView32" +#ifdef UNICODE +#define CreateStatusWindow CreateStatusWindowW +#define DrawStatusText DrawStatusTextW #else -static const WCHAR WC_LISTVIEWW[] = { 'S','y','s', - 'L','i','s','t','V','i','e','w','3','2',0 }; +#define CreateStatusWindow CreateStatusWindowA +#define DrawStatusText DrawStatusTextA #endif -#define WC_LISTVIEW WINELIB_NAME_AW(WC_LISTVIEW) -#define LVSCW_AUTOSIZE -1 -#define LVSCW_AUTOSIZE_USEHEADER -2 +#define STATUSCLASSNAMEW L"msctls_statusbar32" +#define STATUSCLASSNAMEA "msctls_statusbar32" +#ifdef UNICODE +#define STATUSCLASSNAME STATUSCLASSNAMEW +#else +#define STATUSCLASSNAME STATUSCLASSNAMEA +#endif -#define LVS_ICON 0x0000 -#define LVS_REPORT 0x0001 -#define LVS_SMALLICON 0x0002 -#define LVS_LIST 0x0003 -#define LVS_TYPEMASK 0x0003 -#define LVS_SINGLESEL 0x0004 -#define LVS_SHOWSELALWAYS 0x0008 -#define LVS_SORTASCENDING 0x0010 -#define LVS_SORTDESCENDING 0x0020 -#define LVS_SHAREIMAGELISTS 0x0040 -#define LVS_NOLABELWRAP 0x0080 -#define LVS_AUTOARRANGE 0x0100 -#define LVS_EDITLABELS 0x0200 -#define LVS_OWNERDATA 0x1000 -#define LVS_NOSCROLL 0x2000 -#define LVS_TYPESTYLEMASK 0xfc00 -#define LVS_ALIGNTOP 0x0000 -#define LVS_ALIGNLEFT 0x0800 -#define LVS_ALIGNMASK 0x0c00 -#define LVS_OWNERDRAWFIXED 0x0400 -#define LVS_NOCOLUMNHEADER 0x4000 -#define LVS_NOSORTHEADER 0x8000 +#define SB_SETTEXTA (WM_USER+1) +#define SB_SETTEXTW (WM_USER+11) +#define SB_GETTEXTA (WM_USER+2) +#define SB_GETTEXTW (WM_USER+13) +#define SB_GETTEXTLENGTHA (WM_USER+3) +#define SB_GETTEXTLENGTHW (WM_USER+12) -#define LVS_EX_GRIDLINES 0x0001 -#define LVS_EX_SUBITEMIMAGES 0x0002 -#define LVS_EX_CHECKBOXES 0x0004 -#define LVS_EX_TRACKSELECT 0x0008 -#define LVS_EX_HEADERDRAGDROP 0x0010 -#define LVS_EX_FULLROWSELECT 0x0020 -#define LVS_EX_ONECLICKACTIVATE 0x0040 -#define LVS_EX_TWOCLICKACTIVATE 0x0080 -#define LVS_EX_FLATSB 0x0100 -#define LVS_EX_REGIONAL 0x0200 -#define LVS_EX_INFOTIP 0x0400 -#define LVS_EX_UNDERLINEHOT 0x0800 -#define LVS_EX_UNDERLINECOLD 0x1000 -#define LVS_EX_MULTIWORKAREAS 0x2000 -#define LVS_EX_LABELTIP 0x4000 -#define LVS_EX_BORDERSELECT 0x8000 -#define LVS_EX_DOUBLEBUFFER 0x00010000 -#define LVS_EX_HIDELABELS 0x00020000 -#define LVS_EX_SINGLEROW 0x00040000 -#define LVS_EX_SNAPTOGRID 0x00080000 -#define LVS_EX_SIMPLESELECT 0x00100000 -#define LVS_EX_JUSTIFYCOLUMNS 0x00200000 -#define LVS_EX_TRANSPARENTBKGND 0x00400000 -#define LVS_EX_TRANSPARENTSHADOWTEXT 0x00800000 -#define LVS_EX_AUTOAUTOARRANGE 0x01000000 -#define LVS_EX_HEADERINALLVIEWS 0x02000000 -#define LVS_EX_AUTOCHECKSELECT 0x08000000 -#define LVS_EX_AUTOSIZECOLUMNS 0x10000000 -#define LVS_EX_COLUMNSNAPPOINTS 0x40000000 -#define LVS_EX_COLUMNOVERFLOW 0x80000000 +#ifdef UNICODE +#define SB_GETTEXT SB_GETTEXTW +#define SB_SETTEXT SB_SETTEXTW +#define SB_GETTEXTLENGTH SB_GETTEXTLENGTHW +#define SB_SETTIPTEXT SB_SETTIPTEXTW +#define SB_GETTIPTEXT SB_GETTIPTEXTW +#else +#define SB_GETTEXT SB_GETTEXTA +#define SB_SETTEXT SB_SETTEXTA +#define SB_GETTEXTLENGTH SB_GETTEXTLENGTHA +#define SB_SETTIPTEXT SB_SETTIPTEXTA +#define SB_GETTIPTEXT SB_GETTIPTEXTA +#endif -#define LVCF_FMT 0x0001 -#define LVCF_WIDTH 0x0002 -#define LVCF_TEXT 0x0004 -#define LVCF_SUBITEM 0x0008 -#define LVCF_IMAGE 0x0010 -#define LVCF_ORDER 0x0020 -#define LVCF_MINWIDTH 0x0040 +#define SB_SETPARTS (WM_USER+4) +#define SB_GETPARTS (WM_USER+6) +#define SB_GETBORDERS (WM_USER+7) +#define SB_SETMINHEIGHT (WM_USER+8) +#define SB_SIMPLE (WM_USER+9) +#define SB_GETRECT (WM_USER+10) +#define SB_ISSIMPLE (WM_USER+14) +#define SB_SETICON (WM_USER+15) +#define SB_SETTIPTEXTA (WM_USER+16) +#define SB_SETTIPTEXTW (WM_USER+17) +#define SB_GETTIPTEXTA (WM_USER+18) +#define SB_GETTIPTEXTW (WM_USER+19) +#define SB_GETICON (WM_USER+20) +#define SB_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define SB_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define LVCFMT_LEFT 0x0000 -#define LVCFMT_RIGHT 0x0001 -#define LVCFMT_CENTER 0x0002 -#define LVCFMT_JUSTIFYMASK 0x0003 -#define LVCFMT_FIXED_WIDTH 0x0100 -#define LVCFMT_IMAGE 0x0800 -#define LVCFMT_BITMAP_ON_RIGHT 0x1000 -#define LVCFMT_COL_HAS_IMAGES 0x8000 -#define LVCFMT_NO_DPI_SCALE 0x00040000 -#define LVCFMT_FIXED_RATIO 0x00080000 -#define LVCFMT_LINE_BREAK 0x00100000 -#define LVCFMT_FILL 0x00200000 -#define LVCFMT_WRAP 0x00400000 -#define LVCFMT_NO_TITLE 0x00800000 -#define LVCFMT_SPLIT_BUTTON 0x01000000 -#define LVCFMT_TILE_PLACEMENTMASK (LVCFMT_LINE_BREAK | LVCFMT_FILL) +#define SBT_OWNERDRAW 0x1000 +#define SBT_NOBORDERS 0x100 +#define SBT_POPOUT 0x200 +#define SBT_RTLREADING 0x400 +#define SBT_NOTABPARSING 0x800 -#define LVSIL_NORMAL 0 -#define LVSIL_SMALL 1 -#define LVSIL_STATE 2 -#define LVSIL_GROUPHEADER 3 +#define SB_SETBKCOLOR CCM_SETBKCOLOR -/* following 2 flags only for LVS_OWNERDATA listviews */ -/* and only in report or list mode */ -#define LVSICF_NOINVALIDATEALL 0x0001 -#define LVSICF_NOSCROLL 0x0002 +#define SBN_SIMPLEMODECHANGE (SBN_FIRST - 0) + +#define SB_SIMPLEID 0xff +#endif + +#ifndef NOMENUHELP + + WINCOMMCTRLAPI void WINAPI MenuHelp(UINT uMsg,WPARAM wParam,LPARAM lParam,HMENU hMainMenu,HINSTANCE hInst,HWND hwndStatus,UINT *lpwIDs); + WINCOMMCTRLAPI WINBOOL WINAPI ShowHideMenuCtl(HWND hWnd,UINT_PTR uFlags,LPINT lpInfo); + WINCOMMCTRLAPI void WINAPI GetEffectiveClientRect(HWND hWnd,LPRECT lprc,const INT *lpInfo); + +#define MINSYSCOMMAND SC_SIZE +#endif + +#ifndef NOTRACKBAR + +#define TRACKBAR_CLASSA "msctls_trackbar32" +#define TRACKBAR_CLASSW L"msctls_trackbar32" +#ifdef UNICODE +#define TRACKBAR_CLASS TRACKBAR_CLASSW +#else +#define TRACKBAR_CLASS TRACKBAR_CLASSA +#endif + +#define TBS_AUTOTICKS 0x1 +#define TBS_VERT 0x2 +#define TBS_HORZ 0x0 +#define TBS_TOP 0x4 +#define TBS_BOTTOM 0x0 +#define TBS_LEFT 0x4 +#define TBS_RIGHT 0x0 +#define TBS_BOTH 0x8 +#define TBS_NOTICKS 0x10 +#define TBS_ENABLESELRANGE 0x20 +#define TBS_FIXEDLENGTH 0x40 +#define TBS_NOTHUMB 0x80 +#define TBS_TOOLTIPS 0x100 +#define TBS_REVERSED 0x200 +#define TBS_DOWNISLEFT 0x400 + +#define TBM_GETPOS (WM_USER) +#define TBM_GETRANGEMIN (WM_USER+1) +#define TBM_GETRANGEMAX (WM_USER+2) +#define TBM_GETTIC (WM_USER+3) +#define TBM_SETTIC (WM_USER+4) +#define TBM_SETPOS (WM_USER+5) +#define TBM_SETRANGE (WM_USER+6) +#define TBM_SETRANGEMIN (WM_USER+7) +#define TBM_SETRANGEMAX (WM_USER+8) +#define TBM_CLEARTICS (WM_USER+9) +#define TBM_SETSEL (WM_USER+10) +#define TBM_SETSELSTART (WM_USER+11) +#define TBM_SETSELEND (WM_USER+12) +#define TBM_GETPTICS (WM_USER+14) +#define TBM_GETTICPOS (WM_USER+15) +#define TBM_GETNUMTICS (WM_USER+16) +#define TBM_GETSELSTART (WM_USER+17) +#define TBM_GETSELEND (WM_USER+18) +#define TBM_CLEARSEL (WM_USER+19) +#define TBM_SETTICFREQ (WM_USER+20) +#define TBM_SETPAGESIZE (WM_USER+21) +#define TBM_GETPAGESIZE (WM_USER+22) +#define TBM_SETLINESIZE (WM_USER+23) +#define TBM_GETLINESIZE (WM_USER+24) +#define TBM_GETTHUMBRECT (WM_USER+25) +#define TBM_GETCHANNELRECT (WM_USER+26) +#define TBM_SETTHUMBLENGTH (WM_USER+27) +#define TBM_GETTHUMBLENGTH (WM_USER+28) +#define TBM_SETTOOLTIPS (WM_USER+29) +#define TBM_GETTOOLTIPS (WM_USER+30) +#define TBM_SETTIPSIDE (WM_USER+31) + +#define TBTS_TOP 0 +#define TBTS_LEFT 1 +#define TBTS_BOTTOM 2 +#define TBTS_RIGHT 3 + +#define TBM_SETBUDDY (WM_USER+32) +#define TBM_GETBUDDY (WM_USER+33) +#define TBM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define TBM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT + +#define TB_LINEUP 0 +#define TB_LINEDOWN 1 +#define TB_PAGEUP 2 +#define TB_PAGEDOWN 3 +#define TB_THUMBPOSITION 4 +#define TB_THUMBTRACK 5 +#define TB_TOP 6 +#define TB_BOTTOM 7 +#define TB_ENDTRACK 8 + +#define TBCD_TICS 0x1 +#define TBCD_THUMB 0x2 +#define TBCD_CHANNEL 0x3 +#endif + +#ifndef NODRAGLIST + + typedef struct tagDRAGLISTINFO { + UINT uNotification; + HWND hWnd; + POINT ptCursor; + } DRAGLISTINFO,*LPDRAGLISTINFO; + +#define DL_BEGINDRAG (WM_USER+133) +#define DL_DRAGGING (WM_USER+134) +#define DL_DROPPED (WM_USER+135) +#define DL_CANCELDRAG (WM_USER+136) + +#define DL_CURSORSET 0 +#define DL_STOPCURSOR 1 +#define DL_COPYCURSOR 2 +#define DL_MOVECURSOR 3 + +#define DRAGLISTMSGSTRING TEXT("commctrl_DragListMsg") + + WINCOMMCTRLAPI WINBOOL WINAPI MakeDragList(HWND hLB); + WINCOMMCTRLAPI void WINAPI DrawInsert(HWND handParent,HWND hLB,int nItem); + + WINCOMMCTRLAPI int WINAPI LBItemFromPt(HWND hLB,POINT pt,WINBOOL bAutoScroll); +#endif + +#ifndef NOUPDOWN + +#define UPDOWN_CLASSA "msctls_updown32" +#define UPDOWN_CLASSW L"msctls_updown32" +#ifdef UNICODE +#define UPDOWN_CLASS UPDOWN_CLASSW +#else +#define UPDOWN_CLASS UPDOWN_CLASSA +#endif + + typedef struct _UDACCEL { + UINT nSec; + UINT nInc; + } UDACCEL,*LPUDACCEL; + +#define UD_MAXVAL 0x7fff +#define UD_MINVAL (-UD_MAXVAL) + +#define UDS_WRAP 0x1 +#define UDS_SETBUDDYINT 0x2 +#define UDS_ALIGNRIGHT 0x4 +#define UDS_ALIGNLEFT 0x8 +#define UDS_AUTOBUDDY 0x10 +#define UDS_ARROWKEYS 0x20 +#define UDS_HORZ 0x40 +#define UDS_NOTHOUSANDS 0x80 +#define UDS_HOTTRACK 0x100 + +#define UDM_SETRANGE (WM_USER+101) +#define UDM_GETRANGE (WM_USER+102) +#define UDM_SETPOS (WM_USER+103) +#define UDM_GETPOS (WM_USER+104) +#define UDM_SETBUDDY (WM_USER+105) +#define UDM_GETBUDDY (WM_USER+106) +#define UDM_SETACCEL (WM_USER+107) +#define UDM_GETACCEL (WM_USER+108) +#define UDM_SETBASE (WM_USER+109) +#define UDM_GETBASE (WM_USER+110) +#define UDM_SETRANGE32 (WM_USER+111) +#define UDM_GETRANGE32 (WM_USER+112) +#define UDM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define UDM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define UDM_SETPOS32 (WM_USER+113) +#define UDM_GETPOS32 (WM_USER+114) + + WINCOMMCTRLAPI HWND WINAPI CreateUpDownControl(DWORD dwStyle,int x,int y,int cx,int cy,HWND hParent,int nID,HINSTANCE hInst,HWND hBuddy,int nUpper,int nLower,int nPos); + +#define NM_UPDOWN NMUPDOWN +#define LPNM_UPDOWN LPNMUPDOWN + + typedef struct _NM_UPDOWN { + NMHDR hdr; + int iPos; + int iDelta; + } NMUPDOWN,*LPNMUPDOWN; + +#define UDN_DELTAPOS (UDN_FIRST - 1) +#endif + +#ifndef NOPROGRESS + +#define PROGRESS_CLASSA "msctls_progress32" +#define PROGRESS_CLASSW L"msctls_progress32" +#ifdef UNICODE +#define PROGRESS_CLASS PROGRESS_CLASSW +#else +#define PROGRESS_CLASS PROGRESS_CLASSA +#endif + +#define PBS_SMOOTH 0x1 +#define PBS_VERTICAL 0x4 + +#define PBM_SETRANGE (WM_USER+1) +#define PBM_SETPOS (WM_USER+2) +#define PBM_DELTAPOS (WM_USER+3) +#define PBM_SETSTEP (WM_USER+4) +#define PBM_STEPIT (WM_USER+5) +#define PBM_SETRANGE32 (WM_USER+6) + typedef struct { + int iLow; + int iHigh; + } PBRANGE,*PPBRANGE; +#define PBM_GETRANGE (WM_USER+7) +#define PBM_GETPOS (WM_USER+8) +#define PBM_SETBARCOLOR (WM_USER+9) +#define PBM_SETBKCOLOR CCM_SETBKCOLOR + +#define PBS_MARQUEE 0x8 +#define PBM_SETMARQUEE (WM_USER+10) + +#if (_WIN32_WINNT >= 0x0600) +#define PBM_GETSTEP (WM_USER+13) +#define PBM_GETBKCOLOR (WM_USER+14) +#define PBM_GETBARCOLOR (WM_USER+15) +#define PBM_SETSTATE (WM_USER+16) +#define PBM_GETSTATE (WM_USER+17) +#define PBS_SMOOTHREVERSE 0x10 +#define PBST_NORMAL 1 +#define PBST_ERROR 2 +#define PBST_PAUSED 3 +#endif /* (_WIN32_WINNT >= 0x0600) */ + +#endif /* !NOPROGRESS */ -#define LVFI_PARAM 0x0001 -#define LVFI_STRING 0x0002 -#define LVFI_SUBSTRING 0x0004 -#define LVFI_PARTIAL 0x0008 -#define LVFI_WRAP 0x0020 -#define LVFI_NEARESTXY 0x0040 +#ifndef NOHOTKEY -#define LVIF_TEXT 0x0001 -#define LVIF_IMAGE 0x0002 -#define LVIF_PARAM 0x0004 -#define LVIF_STATE 0x0008 -#define LVIF_INDENT 0x0010 -#define LVIF_GROUPID 0x0100 -#define LVIF_COLUMNS 0x0200 -#define LVIF_NORECOMPUTE 0x0800 -#define LVIF_DI_SETITEM 0x1000 -#define LVIF_COLFMT 0x00010000 +#define HOTKEYF_SHIFT 0x1 +#define HOTKEYF_CONTROL 0x2 +#define HOTKEYF_ALT 0x4 +#define HOTKEYF_EXT 0x8 +#define HKCOMB_NONE 0x1 +#define HKCOMB_S 0x2 +#define HKCOMB_C 0x4 +#define HKCOMB_A 0x8 +#define HKCOMB_SC 0x10 +#define HKCOMB_SA 0x20 +#define HKCOMB_CA 0x40 +#define HKCOMB_SCA 0x80 -#define LVIR_BOUNDS 0x0000 -#define LVIR_ICON 0x0001 -#define LVIR_LABEL 0x0002 -#define LVIR_SELECTBOUNDS 0x0003 +#define HKM_SETHOTKEY (WM_USER+1) +#define HKM_GETHOTKEY (WM_USER+2) +#define HKM_SETRULES (WM_USER+3) -#define LVIS_FOCUSED 0x0001 -#define LVIS_SELECTED 0x0002 -#define LVIS_CUT 0x0004 -#define LVIS_DROPHILITED 0x0008 -#define LVIS_ACTIVATING 0x0020 +#define HOTKEY_CLASSA "msctls_hotkey32" +#define HOTKEY_CLASSW L"msctls_hotkey32" +#ifdef UNICODE +#define HOTKEY_CLASS HOTKEY_CLASSW +#else +#define HOTKEY_CLASS HOTKEY_CLASSA +#endif +#endif -#define LVIS_OVERLAYMASK 0x0F00 -#define LVIS_STATEIMAGEMASK 0xF000 +#define CCS_TOP 0x1L +#define CCS_NOMOVEY 0x2L +#define CCS_BOTTOM 0x3L +#define CCS_NORESIZE 0x4L +#define CCS_NOPARENTALIGN 0x8L +#define CCS_ADJUSTABLE 0x20L +#define CCS_NODIVIDER 0x40L +#define CCS_VERT 0x80L +#define CCS_LEFT (CCS_VERT | CCS_TOP) +#define CCS_RIGHT (CCS_VERT | CCS_BOTTOM) +#define CCS_NOMOVEX (CCS_VERT | CCS_NOMOVEY) -#define LVNI_ALL 0x0000 -#define LVNI_FOCUSED 0x0001 -#define LVNI_SELECTED 0x0002 -#define LVNI_CUT 0x0004 -#define LVNI_DROPHILITED 0x0008 +#ifndef NOLISTVIEW -#define LVNI_ABOVE 0x0100 -#define LVNI_BELOW 0x0200 -#define LVNI_TOLEFT 0x0400 -#define LVNI_TORIGHT 0x0800 +#define WC_LISTVIEWA "SysListView32" +#define WC_LISTVIEWW L"SysListView32" +#ifdef UNICODE +#define WC_LISTVIEW WC_LISTVIEWW +#else +#define WC_LISTVIEW WC_LISTVIEWA +#endif -#define LVHT_NOWHERE 0x0001 -#define LVHT_ONITEMICON 0x0002 -#define LVHT_ONITEMLABEL 0x0004 -#define LVHT_ONITEMSTATEICON 0x0008 -#define LVHT_ONITEM (LVHT_ONITEMICON|LVHT_ONITEMLABEL|LVHT_ONITEMSTATEICON) +#define LVS_ICON 0x0 +#define LVS_REPORT 0x1 +#define LVS_SMALLICON 0x2 +#define LVS_LIST 0x3 +#define LVS_TYPEMASK 0x3 +#define LVS_SINGLESEL 0x4 +#define LVS_SHOWSELALWAYS 0x8 +#define LVS_SORTASCENDING 0x10 +#define LVS_SORTDESCENDING 0x20 +#define LVS_SHAREIMAGELISTS 0x40 +#define LVS_NOLABELWRAP 0x80 +#define LVS_AUTOARRANGE 0x100 +#define LVS_EDITLABELS 0x200 +#define LVS_OWNERDATA 0x1000 +#define LVS_NOSCROLL 0x2000 -#define LVHT_ABOVE 0x0008 -#define LVHT_BELOW 0x0010 -#define LVHT_TORIGHT 0x0020 -#define LVHT_TOLEFT 0x0040 +#define LVS_TYPESTYLEMASK 0xfc00 -#define LV_VIEW_ICON 0x0000 -#define LV_VIEW_DETAILS 0x0001 -#define LV_VIEW_SMALLICON 0x0002 -#define LV_VIEW_LIST 0x0003 -#define LV_VIEW_TILE 0x0004 -#define LV_VIEW_MAX 0x0004 +#define LVS_ALIGNTOP 0x0 +#define LVS_ALIGNLEFT 0x800 +#define LVS_ALIGNMASK 0xc00 -#define LVGF_NONE 0x00000000 -#define LVGF_HEADER 0x00000001 -#define LVGF_FOOTER 0x00000002 -#define LVGF_STATE 0x00000004 -#define LVGF_ALIGN 0x00000008 -#define LVGF_GROUPID 0x00000010 -#define LVGF_SUBTITLE 0x00000100 -#define LVGF_TASK 0x00000200 -#define LVGF_DESCRIPTIONTOP 0x00000400 -#define LVGF_DESCRIPTIONBOTTOM 0x00000800 -#define LVGF_TITLEIMAGE 0x00001000 -#define LVGF_EXTENDEDIMAGE 0x00002000 -#define LVGF_ITEMS 0x00004000 -#define LVGF_SUBSET 0x00008000 -#define LVGF_SUBSETITEMS 0x00010000 +#define LVS_OWNERDRAWFIXED 0x400 +#define LVS_NOCOLUMNHEADER 0x4000 +#define LVS_NOSORTHEADER 0x8000 -#define LVGS_NORMAL 0x00000000 -#define LVGS_COLLAPSED 0x00000001 -#define LVGS_HIDDEN 0x00000002 +#define LVM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define ListView_SetUnicodeFormat(hwnd,fUnicode) (WINBOOL)SNDMSG((hwnd),LVM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) +#define LVM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define ListView_GetUnicodeFormat(hwnd) (WINBOOL)SNDMSG((hwnd),LVM_GETUNICODEFORMAT,0,0) +#define LVM_GETBKCOLOR (LVM_FIRST+0) +#define ListView_GetBkColor(hwnd) (COLORREF)SNDMSG((hwnd),LVM_GETBKCOLOR,0,0L) +#define LVM_SETBKCOLOR (LVM_FIRST+1) +#define ListView_SetBkColor(hwnd,clrBk) (WINBOOL)SNDMSG((hwnd),LVM_SETBKCOLOR,0,(LPARAM)(COLORREF)(clrBk)) +#define LVM_GETIMAGELIST (LVM_FIRST+2) +#define ListView_GetImageList(hwnd,iImageList) (HIMAGELIST)SNDMSG((hwnd),LVM_GETIMAGELIST,(WPARAM)(INT)(iImageList),0L) -#define LVGA_HEADER_LEFT 0x00000001 -#define LVGA_HEADER_CENTER 0x00000002 -#define LVGA_HEADER_RIGHT 0x00000004 -#define LVGA_FOOTER_LEFT 0x00000008 -#define LVGA_FOOTER_CENTER 0x00000010 -#define LVGA_FOOTER_RIGHT 0x00000020 +#define LVSIL_NORMAL 0 +#define LVSIL_SMALL 1 +#define LVSIL_STATE 2 -#define LVGMF_NONE 0x00000000 -#define LVGMF_BORDERSIZE 0x00000001 -#define LVGMF_BORDERCOLOR 0x00000002 -#define LVGMF_TEXTCOLOR 0x00000004 +#define LVM_SETIMAGELIST (LVM_FIRST+3) +#define ListView_SetImageList(hwnd,himl,iImageList) (HIMAGELIST)SNDMSG((hwnd),LVM_SETIMAGELIST,(WPARAM)(iImageList),(LPARAM)(HIMAGELIST)(himl)) -#define LVTVIF_AUTOSIZE 0x00000000 -#define LVTVIF_FIXEDWIDTH 0x00000001 -#define LVTVIF_FIXEDHEIGHT 0x00000002 -#define LVTVIF_FIXEDSIZE 0x00000003 -#define LVTVIF_EXTENDED 0x00000004 +#define LVM_GETITEMCOUNT (LVM_FIRST+4) +#define ListView_GetItemCount(hwnd) (int)SNDMSG((hwnd),LVM_GETITEMCOUNT,0,0L) -#define LVTVIM_TILESIZE 0x00000001 -#define LVTVIM_COLUMNS 0x00000002 -#define LVTVIM_LABELMARGIN 0x00000004 +#define LVIF_TEXT 0x1 +#define LVIF_IMAGE 0x2 +#define LVIF_PARAM 0x4 +#define LVIF_STATE 0x8 +#define LVIF_INDENT 0x10 +#define LVIF_NORECOMPUTE 0x800 +#define LVIF_GROUPID 0x100 +#define LVIF_COLUMNS 0x200 -#define LVIM_AFTER 0x00000001 +#define LVIS_FOCUSED 0x1 +#define LVIS_SELECTED 0x2 +#define LVIS_CUT 0x4 +#define LVIS_DROPHILITED 0x8 +#define LVIS_GLOW 0x10 +#define LVIS_ACTIVATING 0x20 -#define LVM_FIRST 0x1000 -#define LVM_GETBKCOLOR (LVM_FIRST+0) -#define LVM_SETBKCOLOR (LVM_FIRST+1) -#define LVM_GETIMAGELIST (LVM_FIRST+2) -#define LVM_SETIMAGELIST (LVM_FIRST+3) -#define LVM_GETITEMCOUNT (LVM_FIRST+4) -#define LVM_GETITEMA (LVM_FIRST+5) -#define LVM_GETITEMW (LVM_FIRST+75) -#define LVM_GETITEM WINELIB_NAME_AW(LVM_GETITEM) -#define LVM_SETITEMA (LVM_FIRST+6) -#define LVM_SETITEMW (LVM_FIRST+76) -#define LVM_SETITEM WINELIB_NAME_AW(LVM_SETITEM) -#define LVM_INSERTITEMA (LVM_FIRST+7) -#define LVM_INSERTITEMW (LVM_FIRST+77) -#define LVM_INSERTITEM WINELIB_NAME_AW(LVM_INSERTITEM) -#define LVM_DELETEITEM (LVM_FIRST+8) -#define LVM_DELETEALLITEMS (LVM_FIRST+9) -#define LVM_GETCALLBACKMASK (LVM_FIRST+10) -#define LVM_SETCALLBACKMASK (LVM_FIRST+11) -#define LVM_GETNEXTITEM (LVM_FIRST+12) -#define LVM_FINDITEMA (LVM_FIRST+13) -#define LVM_FINDITEMW (LVM_FIRST+83) -#define LVM_FINDITEM WINELIB_NAME_AW(LVM_FINDITEM) -#define LVM_GETITEMRECT (LVM_FIRST+14) -#define LVM_SETITEMPOSITION (LVM_FIRST+15) -#define LVM_GETITEMPOSITION (LVM_FIRST+16) -#define LVM_GETSTRINGWIDTHA (LVM_FIRST+17) -#define LVM_GETSTRINGWIDTHW (LVM_FIRST+87) -#define LVM_GETSTRINGWIDTH WINELIB_NAME_AW(LVM_GETSTRINGWIDTH) -#define LVM_HITTEST (LVM_FIRST+18) -#define LVM_ENSUREVISIBLE (LVM_FIRST+19) -#define LVM_SCROLL (LVM_FIRST+20) -#define LVM_REDRAWITEMS (LVM_FIRST+21) -#define LVM_ARRANGE (LVM_FIRST+22) -#define LVM_EDITLABELA (LVM_FIRST+23) -#define LVM_EDITLABELW (LVM_FIRST+118) -#define LVM_EDITLABEL WINELIB_NAME_AW(LVM_EDITLABEL) -#define LVM_GETEDITCONTROL (LVM_FIRST+24) -#define LVM_GETCOLUMNA (LVM_FIRST+25) -#define LVM_GETCOLUMNW (LVM_FIRST+95) -#define LVM_GETCOLUMN WINELIB_NAME_AW(LVM_GETCOLUMN) -#define LVM_SETCOLUMNA (LVM_FIRST+26) -#define LVM_SETCOLUMNW (LVM_FIRST+96) -#define LVM_SETCOLUMN WINELIB_NAME_AW(LVM_SETCOLUMN) -#define LVM_INSERTCOLUMNA (LVM_FIRST+27) -#define LVM_INSERTCOLUMNW (LVM_FIRST+97) -#define LVM_INSERTCOLUMN WINELIB_NAME_AW(LVM_INSERTCOLUMN) -#define LVM_DELETECOLUMN (LVM_FIRST+28) -#define LVM_GETCOLUMNWIDTH (LVM_FIRST+29) -#define LVM_SETCOLUMNWIDTH (LVM_FIRST+30) -#define LVM_GETHEADER (LVM_FIRST+31) +#define LVIS_OVERLAYMASK 0xf00 +#define LVIS_STATEIMAGEMASK 0xF000 -#define LVM_CREATEDRAGIMAGE (LVM_FIRST+33) -#define LVM_GETVIEWRECT (LVM_FIRST+34) -#define LVM_GETTEXTCOLOR (LVM_FIRST+35) -#define LVM_SETTEXTCOLOR (LVM_FIRST+36) -#define LVM_GETTEXTBKCOLOR (LVM_FIRST+37) -#define LVM_SETTEXTBKCOLOR (LVM_FIRST+38) -#define LVM_GETTOPINDEX (LVM_FIRST+39) -#define LVM_GETCOUNTPERPAGE (LVM_FIRST+40) -#define LVM_GETORIGIN (LVM_FIRST+41) -#define LVM_UPDATE (LVM_FIRST+42) -#define LVM_SETITEMSTATE (LVM_FIRST+43) -#define LVM_GETITEMSTATE (LVM_FIRST+44) -#define LVM_GETITEMTEXTA (LVM_FIRST+45) -#define LVM_GETITEMTEXTW (LVM_FIRST+115) -#define LVM_GETITEMTEXT WINELIB_NAME_AW(LVM_GETITEMTEXT) -#define LVM_SETITEMTEXTA (LVM_FIRST+46) -#define LVM_SETITEMTEXTW (LVM_FIRST+116) -#define LVM_SETITEMTEXT WINELIB_NAME_AW(LVM_SETITEMTEXT) -#define LVM_SETITEMCOUNT (LVM_FIRST+47) -#define LVM_SORTITEMS (LVM_FIRST+48) -#define LVM_SORTITEMSEX (LVM_FIRST+81) -#define LVM_SETITEMPOSITION32 (LVM_FIRST+49) -#define LVM_GETSELECTEDCOUNT (LVM_FIRST+50) -#define LVM_GETITEMSPACING (LVM_FIRST+51) -#define LVM_GETISEARCHSTRINGA (LVM_FIRST+52) -#define LVM_GETISEARCHSTRINGW (LVM_FIRST+117) -#define LVM_GETISEARCHSTRING WINELIB_NAME_AW(LVM_GETISEARCHSTRING) -#define LVM_SETICONSPACING (LVM_FIRST+53) -#define LVM_SETEXTENDEDLISTVIEWSTYLE (LVM_FIRST+54) -#define LVM_GETEXTENDEDLISTVIEWSTYLE (LVM_FIRST+55) -#define LVM_GETSUBITEMRECT (LVM_FIRST+56) -#define LVM_SUBITEMHITTEST (LVM_FIRST+57) -#define LVM_SETCOLUMNORDERARRAY (LVM_FIRST+58) -#define LVM_GETCOLUMNORDERARRAY (LVM_FIRST+59) -#define LVM_SETHOTITEM (LVM_FIRST+60) -#define LVM_GETHOTITEM (LVM_FIRST+61) -#define LVM_SETHOTCURSOR (LVM_FIRST+62) -#define LVM_GETHOTCURSOR (LVM_FIRST+63) -#define LVM_APPROXIMATEVIEWRECT (LVM_FIRST+64) -#define LVM_SETWORKAREAS (LVM_FIRST+65) -#define LVM_GETSELECTIONMARK (LVM_FIRST+66) -#define LVM_SETSELECTIONMARK (LVM_FIRST+67) -#define LVM_SETBKIMAGEA (LVM_FIRST+68) -#define LVM_SETBKIMAGEW (LVM_FIRST+138) -#define LVM_SETBKIMAGE WINELIB_NAME_AW(LVM_SETBKIMAGE) -#define LVM_GETBKIMAGEA (LVM_FIRST+69) -#define LVM_GETBKIMAGEW (LVM_FIRST+139) -#define LVM_GETBKIMAGE WINELIB_NAME_AW(LVM_GETBKIMAGE) -#define LVM_GETWORKAREAS (LVM_FIRST+70) -#define LVM_SETHOVERTIME (LVM_FIRST+71) -#define LVM_GETHOVERTIME (LVM_FIRST+72) -#define LVM_GETNUMBEROFWORKAREAS (LVM_FIRST+73) -#define LVM_SETTOOLTIPS (LVM_FIRST+74) -#define LVM_GETTOOLTIPS (LVM_FIRST+78) -#define LVM_GETUNICODEFORMAT (CCM_GETUNICODEFORMAT) -#define LVM_SETUNICODEFORMAT (CCM_SETUNICODEFORMAT) -#define LVM_SETSELECTEDCOLUMN (LVM_FIRST + 140) -#define LVM_SETTILEWIDTH (LVM_FIRST + 141) -#define LVM_SETVIEW (LVM_FIRST + 142) -#define LVM_GETVIEW (LVM_FIRST + 143) -#define LVM_INSERTGROUP (LVM_FIRST + 145) -#define LVM_SETGROUPINFO (LVM_FIRST + 147) -#define LVM_GETGROUPINFO (LVM_FIRST + 149) -#define LVM_REMOVEGROUP (LVM_FIRST + 150) -#define LVM_MOVEGROUP (LVM_FIRST + 151) -#define LVM_MOVEITEMTOGROUP (LVM_FIRST + 154) -#define LVM_SETGROUPMETRICS (LVM_FIRST + 155) -#define LVM_GETGROUPMETRICS (LVM_FIRST + 156) -#define LVM_ENABLEGROUPVIEW (LVM_FIRST + 157) -#define LVM_SORTGROUPS (LVM_FIRST + 158) -#define LVM_INSERTGROUPSORTED (LVM_FIRST + 159) -#define LVM_REMOVEALLGROUPS (LVM_FIRST + 160) -#define LVM_HASGROUP (LVM_FIRST + 161) -#define LVM_SETTILEVIEWINFO (LVM_FIRST + 162) -#define LVM_GETTILEVIEWINFO (LVM_FIRST + 163) -#define LVM_SETTILEINFO (LVM_FIRST + 164) -#define LVM_GETTILEINFO (LVM_FIRST + 165) -#define LVM_SETINSERTMARK (LVM_FIRST + 166) -#define LVM_GETINSERTMARK (LVM_FIRST + 167) -#define LVM_INSERTMARKHITTEST (LVM_FIRST + 168) -#define LVM_GETINSERTMARKRECT (LVM_FIRST + 169) -#define LVM_SETINSERTMARKCOLOR (LVM_FIRST + 170) -#define LVM_GETINSERTMARKCOLOR (LVM_FIRST + 171) -#define LVM_SETINFOTIP (LVM_FIRST + 173) -#define LVM_GETSELECTEDCOLUMN (LVM_FIRST + 174) -#define LVM_ISGROUPVIEWENABLED (LVM_FIRST + 175) -#define LVM_GETOUTLINECOLOR (LVM_FIRST + 176) -#define LVM_SETOUTLINECOLOR (LVM_FIRST + 177) -#define LVM_CANCELEDITLABEL (LVM_FIRST + 179) -#define LVM_MAPINDEXTOID (LVM_FIRST + 180) -#define LVM_MAPIDTOINDEX (LVM_FIRST + 181) -#define LVM_ISITEMVISIBLE (LVM_FIRST + 182) +#define INDEXTOSTATEIMAGEMASK(i) ((i) << 12) -#define LVN_FIRST (0U-100U) -#define LVN_LAST (0U-199U) -#define LVN_ITEMCHANGING (LVN_FIRST-0) -#define LVN_ITEMCHANGED (LVN_FIRST-1) -#define LVN_INSERTITEM (LVN_FIRST-2) -#define LVN_DELETEITEM (LVN_FIRST-3) -#define LVN_DELETEALLITEMS (LVN_FIRST-4) -#define LVN_BEGINLABELEDITA (LVN_FIRST-5) -#define LVN_BEGINLABELEDITW (LVN_FIRST-75) -#define LVN_BEGINLABELEDIT WINELIB_NAME_AW(LVN_BEGINLABELEDIT) -#define LVN_ENDLABELEDITA (LVN_FIRST-6) -#define LVN_ENDLABELEDITW (LVN_FIRST-76) -#define LVN_ENDLABELEDIT WINELIB_NAME_AW(LVN_ENDLABELEDIT) -#define LVN_COLUMNCLICK (LVN_FIRST-8) -#define LVN_BEGINDRAG (LVN_FIRST-9) -#define LVN_BEGINRDRAG (LVN_FIRST-11) -#define LVN_ODCACHEHINT (LVN_FIRST-13) -#define LVN_ITEMACTIVATE (LVN_FIRST-14) -#define LVN_ODSTATECHANGED (LVN_FIRST-15) -#define LVN_HOTTRACK (LVN_FIRST-21) -#define LVN_ODFINDITEMA (LVN_FIRST-52) -#define LVN_ODFINDITEMW (LVN_FIRST-79) -#define LVN_ODFINDITEM WINELIB_NAME_AW(LVN_ODFINDITEM) -#define LVN_GETDISPINFOA (LVN_FIRST-50) -#define LVN_GETDISPINFOW (LVN_FIRST-77) -#define LVN_GETDISPINFO WINELIB_NAME_AW(LVN_GETDISPINFO) -#define LVN_SETDISPINFOA (LVN_FIRST-51) -#define LVN_SETDISPINFOW (LVN_FIRST-78) -#define LVN_SETDISPINFO WINELIB_NAME_AW(LVN_SETDISPINFO) -#define LVN_KEYDOWN (LVN_FIRST-55) -#define LVN_MARQUEEBEGIN (LVN_FIRST-56) -#define LVN_GETINFOTIPA (LVN_FIRST-57) -#define LVN_GETINFOTIPW (LVN_FIRST-58) -#define LVN_GETINFOTIP WINELIB_NAME_AW(LVN_GETINFOTIP) -#define LVN_INCREMENTALSEARCHA (LVN_FIRST-62) -#define LVN_INCREMENTALSEARCHW (LVN_FIRST-63) -#define LVN_INCREMENTALSEARCH WINELIB_NAME_AW(LVN_INCREMENTALSEARCH) -#define LVN_BEGINSCROLL (LVN_FIRST-80) -#define LVN_ENDSCROLL (LVN_FIRST-81) -#define LVN_LINKCLICK (LVN_FIRST-84) -#define LVN_ASYNCDRAWN (LVN_FIRST-86) -#define LVN_GETEMPTYMARKUP (LVN_FIRST-87) - -/* LVN_INCREMENTALSEARCH return codes */ -#define LVNSCH_DEFAULT -1 -#define LVNSCH_ERROR -2 -#define LVNSCH_IGNORE -3 - -#define LVA_DEFAULT 0x0000 -#define LVA_ALIGNLEFT 0x0001 -#define LVA_ALIGNTOP 0x0002 -#define LVA_SNAPTOGRID 0x0005 - -typedef struct tagLVITEMA -{ - UINT mask; - INT iItem; - INT iSubItem; - UINT state; - UINT stateMask; - LPSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; - /* (_WIN32_IE >= 0x0300) */ - INT iIndent; - /* (_WIN32_IE >= 0x0560) */ - INT iGroupId; - UINT cColumns; - PUINT puColumns; - /* (_WIN32_WINNT >= 0x0600) */ - PINT piColFmt; - INT iGroup; -} LVITEMA, *LPLVITEMA; - -typedef struct tagLVITEMW -{ - UINT mask; - INT iItem; - INT iSubItem; - UINT state; - UINT stateMask; - LPWSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; - /* (_WIN32_IE >= 0x0300) */ - INT iIndent; - /* (_WIN32_IE >= 0x0560) */ - INT iGroupId; - UINT cColumns; - PUINT puColumns; - /* (_WIN32_WINNT >= 0x0600) */ - PINT piColFmt; - INT iGroup; -} LVITEMW, *LPLVITEMW; - -#define LVITEM WINELIB_NAME_AW(LVITEM) -#define LPLVITEM WINELIB_NAME_AW(LPLVITEM) - -#define LVITEM_V1_SIZEA CCSIZEOF_STRUCT(LVITEMA, lParam) -#define LVITEM_V1_SIZEW CCSIZEOF_STRUCT(LVITEMW, lParam) -#define LVITEM_V1_SIZE WINELIB_NAME_AW(LVITEM_V1_SIZE) - -#define LVITEMA_V5_SIZE CCSIZEOF_STRUCT(LVITEMA, puColumns) -#define LVITEMW_V5_SIZE CCSIZEOF_STRUCT(LVITEMW, puColumns) -#define LVITEM_V5_SIZE WINELIB_NAME_AW(LVITEM_V5_SIZE) - -#define LV_ITEM LVITEM +#define I_INDENTCALLBACK (-1) #define LV_ITEMA LVITEMA #define LV_ITEMW LVITEMW -typedef struct LVSETINFOTIP -{ - UINT cbSize; - DWORD dwFlags; - LPWSTR pszText; +#define I_GROUPIDCALLBACK (-1) +#define I_GROUPIDNONE (-2) + +#define LV_ITEM LVITEM + +#define LVITEMA_V1_SIZE CCSIZEOF_STRUCT(LVITEMA,lParam) +#define LVITEMW_V1_SIZE CCSIZEOF_STRUCT(LVITEMW,lParam) + + typedef struct tagLVITEMA { + UINT mask; int iItem; int iSubItem; -} LVSETINFOTIP, *PLVSETINFOTIP; + UINT state; + UINT stateMask; + LPSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + int iIndent; + int iGroupId; + UINT cColumns; + PUINT puColumns; + } LVITEMA,*LPLVITEMA; -/* ListView background image structs and constants - For _WIN32_IE version 0x400 and later. */ + typedef struct tagLVITEMW + { + UINT mask; + int iItem; + int iSubItem; + UINT state; + UINT stateMask; + LPWSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + int iIndent; + int iGroupId; + UINT cColumns; + PUINT puColumns; + } LVITEMW,*LPLVITEMW; -typedef struct tagLVBKIMAGEA -{ +#ifdef UNICODE +#define LVITEM LVITEMW +#define LPLVITEM LPLVITEMW +#define LVITEM_V1_SIZE LVITEMW_V1_SIZE +#else +#define LVITEM LVITEMA +#define LPLVITEM LPLVITEMA +#define LVITEM_V1_SIZE LVITEMA_V1_SIZE +#endif + +#define LPSTR_TEXTCALLBACKW ((LPWSTR)-1L) +#define LPSTR_TEXTCALLBACKA ((LPSTR)-1L) +#ifdef UNICODE +#define LPSTR_TEXTCALLBACK LPSTR_TEXTCALLBACKW +#else +#define LPSTR_TEXTCALLBACK LPSTR_TEXTCALLBACKA +#endif + +#define I_IMAGECALLBACK (-1) +#define I_IMAGENONE (-2) +#define I_COLUMNSCALLBACK ((UINT)-1) + +#define LVM_GETITEMA (LVM_FIRST+5) +#define LVM_GETITEMW (LVM_FIRST+75) +#ifdef UNICODE +#define LVM_GETITEM LVM_GETITEMW +#else +#define LVM_GETITEM LVM_GETITEMA +#endif + +#define ListView_GetItem(hwnd,pitem) (WINBOOL)SNDMSG((hwnd),LVM_GETITEM,0,(LPARAM)(LV_ITEM *)(pitem)) + +#define LVM_SETITEMA (LVM_FIRST+6) +#define LVM_SETITEMW (LVM_FIRST+76) +#ifdef UNICODE +#define LVM_SETITEM LVM_SETITEMW +#else +#define LVM_SETITEM LVM_SETITEMA +#endif + +#define ListView_SetItem(hwnd,pitem) (WINBOOL)SNDMSG((hwnd),LVM_SETITEM,0,(LPARAM)(const LV_ITEM *)(pitem)) + +#define LVM_INSERTITEMA (LVM_FIRST+7) +#define LVM_INSERTITEMW (LVM_FIRST+77) +#ifdef UNICODE +#define LVM_INSERTITEM LVM_INSERTITEMW +#else +#define LVM_INSERTITEM LVM_INSERTITEMA +#endif +#define ListView_InsertItem(hwnd,pitem) (int)SNDMSG((hwnd),LVM_INSERTITEM,0,(LPARAM)(const LV_ITEM *)(pitem)) + +#define LVM_DELETEITEM (LVM_FIRST+8) +#define ListView_DeleteItem(hwnd,i) (WINBOOL)SNDMSG((hwnd),LVM_DELETEITEM,(WPARAM)(int)(i),0L) + +#define LVM_DELETEALLITEMS (LVM_FIRST+9) +#define ListView_DeleteAllItems(hwnd) (WINBOOL)SNDMSG((hwnd),LVM_DELETEALLITEMS,0,0L) + +#define LVM_GETCALLBACKMASK (LVM_FIRST+10) +#define ListView_GetCallbackMask(hwnd) (WINBOOL)SNDMSG((hwnd),LVM_GETCALLBACKMASK,0,0) + +#define LVM_SETCALLBACKMASK (LVM_FIRST+11) +#define ListView_SetCallbackMask(hwnd,mask) (WINBOOL)SNDMSG((hwnd),LVM_SETCALLBACKMASK,(WPARAM)(UINT)(mask),0) + +#define LVNI_ALL 0x0 +#define LVNI_FOCUSED 0x1 +#define LVNI_SELECTED 0x2 +#define LVNI_CUT 0x4 +#define LVNI_DROPHILITED 0x8 + +#define LVNI_ABOVE 0x100 +#define LVNI_BELOW 0x200 +#define LVNI_TOLEFT 0x400 +#define LVNI_TORIGHT 0x800 + +#define LVM_GETNEXTITEM (LVM_FIRST+12) +#define ListView_GetNextItem(hwnd,i,flags) (int)SNDMSG((hwnd),LVM_GETNEXTITEM,(WPARAM)(int)(i),MAKELPARAM((flags),0)) + +#define LVFI_PARAM 0x1 +#define LVFI_STRING 0x2 +#define LVFI_PARTIAL 0x8 +#define LVFI_WRAP 0x20 +#define LVFI_NEARESTXY 0x40 + +#define LV_FINDINFOA LVFINDINFOA +#define LV_FINDINFOW LVFINDINFOW +#define LV_FINDINFO LVFINDINFO + + typedef struct tagLVFINDINFOA { + UINT flags; + LPCSTR psz; + LPARAM lParam; + POINT pt; + UINT vkDirection; + } LVFINDINFOA,*LPFINDINFOA; + + typedef struct tagLVFINDINFOW { + UINT flags; + LPCWSTR psz; + LPARAM lParam; + POINT pt; + UINT vkDirection; + } LVFINDINFOW,*LPFINDINFOW; + +#ifdef UNICODE +#define LVFINDINFO LVFINDINFOW +#else +#define LVFINDINFO LVFINDINFOA +#endif + +#define LVM_FINDITEMA (LVM_FIRST+13) +#define LVM_FINDITEMW (LVM_FIRST+83) +#ifdef UNICODE +#define LVM_FINDITEM LVM_FINDITEMW +#else +#define LVM_FINDITEM LVM_FINDITEMA +#endif + +#define ListView_FindItem(hwnd,iStart,plvfi) (int)SNDMSG((hwnd),LVM_FINDITEM,(WPARAM)(int)(iStart),(LPARAM)(const LV_FINDINFO *)(plvfi)) + +#define LVIR_BOUNDS 0 +#define LVIR_ICON 1 +#define LVIR_LABEL 2 +#define LVIR_SELECTBOUNDS 3 + +#define LVM_GETITEMRECT (LVM_FIRST+14) +#define ListView_GetItemRect(hwnd,i,prc,code) (WINBOOL)SNDMSG((hwnd),LVM_GETITEMRECT,(WPARAM)(int)(i),((prc) ? (((RECT *)(prc))->left = (code),(LPARAM)(RECT *)(prc)) : (LPARAM)(RECT *)NULL)) + +#define LVM_SETITEMPOSITION (LVM_FIRST+15) +#define ListView_SetItemPosition(hwndLV,i,x,y) (WINBOOL)SNDMSG((hwndLV),LVM_SETITEMPOSITION,(WPARAM)(int)(i),MAKELPARAM((x),(y))) + +#define LVM_GETITEMPOSITION (LVM_FIRST+16) +#define ListView_GetItemPosition(hwndLV,i,ppt) (WINBOOL)SNDMSG((hwndLV),LVM_GETITEMPOSITION,(WPARAM)(int)(i),(LPARAM)(POINT *)(ppt)) + +#define LVM_GETSTRINGWIDTHA (LVM_FIRST+17) +#define LVM_GETSTRINGWIDTHW (LVM_FIRST+87) +#ifdef UNICODE +#define LVM_GETSTRINGWIDTH LVM_GETSTRINGWIDTHW +#else +#define LVM_GETSTRINGWIDTH LVM_GETSTRINGWIDTHA +#endif + +#define ListView_GetStringWidth(hwndLV,psz) (int)SNDMSG((hwndLV),LVM_GETSTRINGWIDTH,0,(LPARAM)(LPCTSTR)(psz)) + +#define LVHT_NOWHERE 0x1 +#define LVHT_ONITEMICON 0x2 +#define LVHT_ONITEMLABEL 0x4 +#define LVHT_ONITEMSTATEICON 0x8 +#define LVHT_ONITEM (LVHT_ONITEMICON | LVHT_ONITEMLABEL | LVHT_ONITEMSTATEICON) + +#define LVHT_ABOVE 0x8 +#define LVHT_BELOW 0x10 +#define LVHT_TORIGHT 0x20 +#define LVHT_TOLEFT 0x40 + +#define LV_HITTESTINFO LVHITTESTINFO + +#define LVHITTESTINFO_V1_SIZE CCSIZEOF_STRUCT(LVHITTESTINFO,iItem) + + typedef struct tagLVHITTESTINFO { + POINT pt; + UINT flags; + int iItem; + int iSubItem; + } LVHITTESTINFO,*LPLVHITTESTINFO; + +#define LVM_HITTEST (LVM_FIRST+18) +#define ListView_HitTest(hwndLV,pinfo) (int)SNDMSG((hwndLV),LVM_HITTEST,0,(LPARAM)(LV_HITTESTINFO *)(pinfo)) + +#define LVM_ENSUREVISIBLE (LVM_FIRST+19) +#define ListView_EnsureVisible(hwndLV,i,fPartialOK) (WINBOOL)SNDMSG((hwndLV),LVM_ENSUREVISIBLE,(WPARAM)(int)(i),MAKELPARAM((fPartialOK),0)) + +#define LVM_SCROLL (LVM_FIRST+20) +#define ListView_Scroll(hwndLV,dx,dy) (WINBOOL)SNDMSG((hwndLV),LVM_SCROLL,(WPARAM)(int)(dx),(LPARAM)(int)(dy)) + +#define LVM_REDRAWITEMS (LVM_FIRST+21) +#define ListView_RedrawItems(hwndLV,iFirst,iLast) (WINBOOL)SNDMSG((hwndLV),LVM_REDRAWITEMS,(WPARAM)(int)(iFirst),(LPARAM)(int)(iLast)) + +#define LVA_DEFAULT 0x0 +#define LVA_ALIGNLEFT 0x1 +#define LVA_ALIGNTOP 0x2 +#define LVA_SNAPTOGRID 0x5 + +#define LVM_ARRANGE (LVM_FIRST+22) +#define ListView_Arrange(hwndLV,code) (WINBOOL)SNDMSG((hwndLV),LVM_ARRANGE,(WPARAM)(UINT)(code),0L) + +#define LVM_EDITLABELA (LVM_FIRST+23) +#define LVM_EDITLABELW (LVM_FIRST+118) +#ifdef UNICODE +#define LVM_EDITLABEL LVM_EDITLABELW +#else +#define LVM_EDITLABEL LVM_EDITLABELA +#endif + +#define ListView_EditLabel(hwndLV,i) (HWND)SNDMSG((hwndLV),LVM_EDITLABEL,(WPARAM)(int)(i),0L) + +#define LVM_GETEDITCONTROL (LVM_FIRST+24) +#define ListView_GetEditControl(hwndLV) (HWND)SNDMSG((hwndLV),LVM_GETEDITCONTROL,0,0L) + +#define LV_COLUMNA LVCOLUMNA +#define LV_COLUMNW LVCOLUMNW +#define LV_COLUMN LVCOLUMN + +#define LVCOLUMNA_V1_SIZE CCSIZEOF_STRUCT(LVCOLUMNA,iSubItem) +#define LVCOLUMNW_V1_SIZE CCSIZEOF_STRUCT(LVCOLUMNW,iSubItem) + + typedef struct tagLVCOLUMNA { + UINT mask; + int fmt; + int cx; + LPSTR pszText; + int cchTextMax; + int iSubItem; + int iImage; + int iOrder; + } LVCOLUMNA,*LPLVCOLUMNA; + + typedef struct tagLVCOLUMNW { + UINT mask; + int fmt; + int cx; + LPWSTR pszText; + int cchTextMax; + int iSubItem; + #if (_WIN32_IE >= 0x0300) + int iImage; + int iOrder; + #endif + #if (_WIN32_WINNT >= 0x0600) + int cxMin; + int cxDefault; + int cxIdeal; + #endif + } LVCOLUMNW,*LPLVCOLUMNW; + +#ifdef UNICODE +#define LVCOLUMN LVCOLUMNW +#define LPLVCOLUMN LPLVCOLUMNW +#define LVCOLUMN_V1_SIZE LVCOLUMNW_V1_SIZE +#else +#define LVCOLUMN LVCOLUMNA +#define LPLVCOLUMN LPLVCOLUMNA +#define LVCOLUMN_V1_SIZE LVCOLUMNA_V1_SIZE +#endif + +#define LVCF_FMT 0x1 +#define LVCF_WIDTH 0x2 +#define LVCF_TEXT 0x4 +#define LVCF_SUBITEM 0x8 +#define LVCF_IMAGE 0x10 +#define LVCF_ORDER 0x20 +#if (_WIN32_WINNT >= 0x0600) +#define LVCF_MINWIDTH 0x40 +#define LVCF_DEFAULTWIDTH 0x80 +#define LVCF_IDEALWIDTH 0x100 +#endif /* (_WIN32_WINNT >= 0x0600) */ + +#define LVCFMT_LEFT 0x0 +#define LVCFMT_RIGHT 0x1 +#define LVCFMT_CENTER 0x2 +#define LVCFMT_JUSTIFYMASK 0x3 +#define LVCFMT_IMAGE 0x800 +#define LVCFMT_BITMAP_ON_RIGHT 0x1000 +#define LVCFMT_COL_HAS_IMAGES 0x8000 +#if (_WIN32_WINNT >= 0x0600) +#define LVCFMT_FIXED_WIDTH 0x100 +#define LVCFMT_NO_DPI_SCALE 0x40000 +#define LVCFMT_FIXED_RATIO 0x80000 +#define LVCFMT_LINE_BREAK 0x100000 +#define LVCFMT_FILL 0x200000 +#define LVCFMT_WRAP 0x400000 +#define LVCFMT_NO_TITLE 0x800000 +#define LVCFMT_SPLITBUTTON 0x1000000 +#define LVCFMT_TILE_PLACEMENTMASK (LVCFMT_LINE_BREAK|LVCFMT_FILL) +#endif /* (_WIN32_WINNT >= 0x0600) */ + +#define LVM_GETCOLUMNA (LVM_FIRST+25) +#define LVM_GETCOLUMNW (LVM_FIRST+95) +#ifdef UNICODE +#define LVM_GETCOLUMN LVM_GETCOLUMNW +#else +#define LVM_GETCOLUMN LVM_GETCOLUMNA +#endif + +#define ListView_GetColumn(hwnd,iCol,pcol) (WINBOOL)SNDMSG((hwnd),LVM_GETCOLUMN,(WPARAM)(int)(iCol),(LPARAM)(LV_COLUMN *)(pcol)) + +#define LVM_SETCOLUMNA (LVM_FIRST+26) +#define LVM_SETCOLUMNW (LVM_FIRST+96) +#ifdef UNICODE +#define LVM_SETCOLUMN LVM_SETCOLUMNW +#else +#define LVM_SETCOLUMN LVM_SETCOLUMNA +#endif + +#define ListView_SetColumn(hwnd,iCol,pcol) (WINBOOL)SNDMSG((hwnd),LVM_SETCOLUMN,(WPARAM)(int)(iCol),(LPARAM)(const LV_COLUMN *)(pcol)) + +#define LVM_INSERTCOLUMNA (LVM_FIRST+27) +#define LVM_INSERTCOLUMNW (LVM_FIRST+97) +#ifdef UNICODE +#define LVM_INSERTCOLUMN LVM_INSERTCOLUMNW +#else +#define LVM_INSERTCOLUMN LVM_INSERTCOLUMNA +#endif + +#define ListView_InsertColumn(hwnd,iCol,pcol) (int)SNDMSG((hwnd),LVM_INSERTCOLUMN,(WPARAM)(int)(iCol),(LPARAM)(const LV_COLUMN *)(pcol)) + +#define LVM_DELETECOLUMN (LVM_FIRST+28) +#define ListView_DeleteColumn(hwnd,iCol) (WINBOOL)SNDMSG((hwnd),LVM_DELETECOLUMN,(WPARAM)(int)(iCol),0) + +#define LVM_GETCOLUMNWIDTH (LVM_FIRST+29) +#define ListView_GetColumnWidth(hwnd,iCol) (int)SNDMSG((hwnd),LVM_GETCOLUMNWIDTH,(WPARAM)(int)(iCol),0) + +#define LVSCW_AUTOSIZE -1 +#define LVSCW_AUTOSIZE_USEHEADER -2 +#define LVM_SETCOLUMNWIDTH (LVM_FIRST+30) + +#define ListView_SetColumnWidth(hwnd,iCol,cx) (WINBOOL)SNDMSG((hwnd),LVM_SETCOLUMNWIDTH,(WPARAM)(int)(iCol),MAKELPARAM((cx),0)) + +#define LVM_GETHEADER (LVM_FIRST+31) +#define ListView_GetHeader(hwnd) (HWND)SNDMSG((hwnd),LVM_GETHEADER,0,0L) +#define LVM_CREATEDRAGIMAGE (LVM_FIRST+33) +#define ListView_CreateDragImage(hwnd,i,lpptUpLeft) (HIMAGELIST)SNDMSG((hwnd),LVM_CREATEDRAGIMAGE,(WPARAM)(int)(i),(LPARAM)(LPPOINT)(lpptUpLeft)) +#define LVM_GETVIEWRECT (LVM_FIRST+34) +#define ListView_GetViewRect(hwnd,prc) (WINBOOL)SNDMSG((hwnd),LVM_GETVIEWRECT,0,(LPARAM)(RECT *)(prc)) +#define LVM_GETTEXTCOLOR (LVM_FIRST+35) +#define ListView_GetTextColor(hwnd) (COLORREF)SNDMSG((hwnd),LVM_GETTEXTCOLOR,0,0L) +#define LVM_SETTEXTCOLOR (LVM_FIRST+36) +#define ListView_SetTextColor(hwnd,clrText) (WINBOOL)SNDMSG((hwnd),LVM_SETTEXTCOLOR,0,(LPARAM)(COLORREF)(clrText)) +#define LVM_GETTEXTBKCOLOR (LVM_FIRST+37) +#define ListView_GetTextBkColor(hwnd) (COLORREF)SNDMSG((hwnd),LVM_GETTEXTBKCOLOR,0,0L) +#define LVM_SETTEXTBKCOLOR (LVM_FIRST+38) +#define ListView_SetTextBkColor(hwnd,clrTextBk) (WINBOOL)SNDMSG((hwnd),LVM_SETTEXTBKCOLOR,0,(LPARAM)(COLORREF)(clrTextBk)) +#define LVM_GETTOPINDEX (LVM_FIRST+39) +#define ListView_GetTopIndex(hwndLV) (int)SNDMSG((hwndLV),LVM_GETTOPINDEX,0,0) +#define LVM_GETCOUNTPERPAGE (LVM_FIRST+40) +#define ListView_GetCountPerPage(hwndLV) (int)SNDMSG((hwndLV),LVM_GETCOUNTPERPAGE,0,0) +#define LVM_GETORIGIN (LVM_FIRST+41) +#define ListView_GetOrigin(hwndLV,ppt) (WINBOOL)SNDMSG((hwndLV),LVM_GETORIGIN,(WPARAM)0,(LPARAM)(POINT *)(ppt)) +#define LVM_UPDATE (LVM_FIRST+42) +#define ListView_Update(hwndLV,i) (WINBOOL)SNDMSG((hwndLV),LVM_UPDATE,(WPARAM)(i),0L) +#define LVM_SETITEMSTATE (LVM_FIRST+43) +#define ListView_SetItemState(hwndLV,i,data,mask) { LV_ITEM _ms_lvi; _ms_lvi.stateMask = mask; _ms_lvi.state = data; SNDMSG((hwndLV),LVM_SETITEMSTATE,(WPARAM)(i),(LPARAM)(LV_ITEM *)&_ms_lvi);} +#define ListView_SetCheckState(hwndLV,i,fCheck) ListView_SetItemState(hwndLV,i,INDEXTOSTATEIMAGEMASK((fCheck)?2:1),LVIS_STATEIMAGEMASK) +#define LVM_GETITEMSTATE (LVM_FIRST+44) +#define ListView_GetItemState(hwndLV,i,mask) (UINT)SNDMSG((hwndLV),LVM_GETITEMSTATE,(WPARAM)(i),(LPARAM)(mask)) +#define ListView_GetCheckState(hwndLV,i) ((((UINT)(SNDMSG((hwndLV),LVM_GETITEMSTATE,(WPARAM)(i),LVIS_STATEIMAGEMASK))) >> 12) -1) + +#define LVM_GETITEMTEXTA (LVM_FIRST+45) +#define LVM_GETITEMTEXTW (LVM_FIRST+115) + +#ifdef UNICODE +#define LVM_GETITEMTEXT LVM_GETITEMTEXTW +#else +#define LVM_GETITEMTEXT LVM_GETITEMTEXTA +#endif + +#define ListView_GetItemText(hwndLV,i,iSubItem_,pszText_,cchTextMax_) { LV_ITEM _ms_lvi; _ms_lvi.iSubItem = iSubItem_; _ms_lvi.cchTextMax = cchTextMax_; _ms_lvi.pszText = pszText_; SNDMSG((hwndLV),LVM_GETITEMTEXT,(WPARAM)(i),(LPARAM)(LV_ITEM *)&_ms_lvi);} + +#define LVM_SETITEMTEXTA (LVM_FIRST+46) +#define LVM_SETITEMTEXTW (LVM_FIRST+116) + +#ifdef UNICODE +#define LVM_SETITEMTEXT LVM_SETITEMTEXTW +#else +#define LVM_SETITEMTEXT LVM_SETITEMTEXTA +#endif + +#define ListView_SetItemText(hwndLV,i,iSubItem_,pszText_) { LV_ITEM _ms_lvi; _ms_lvi.iSubItem = iSubItem_; _ms_lvi.pszText = pszText_; SNDMSG((hwndLV),LVM_SETITEMTEXT,(WPARAM)(i),(LPARAM)(LV_ITEM *)&_ms_lvi);} + +#define LVSICF_NOINVALIDATEALL 0x1 +#define LVSICF_NOSCROLL 0x2 + +#define LVM_SETITEMCOUNT (LVM_FIRST+47) +#define ListView_SetItemCount(hwndLV,cItems) SNDMSG((hwndLV),LVM_SETITEMCOUNT,(WPARAM)(cItems),0) +#define ListView_SetItemCountEx(hwndLV,cItems,dwFlags) SNDMSG((hwndLV),LVM_SETITEMCOUNT,(WPARAM)(cItems),(LPARAM)(dwFlags)) + + typedef int (CALLBACK *PFNLVCOMPARE)(LPARAM,LPARAM,LPARAM); + +#define LVM_SORTITEMS (LVM_FIRST+48) +#define ListView_SortItems(hwndLV,_pfnCompare,_lPrm) (WINBOOL)SNDMSG((hwndLV),LVM_SORTITEMS,(WPARAM)(LPARAM)(_lPrm),(LPARAM)(PFNLVCOMPARE)(_pfnCompare)) + +#define LVM_SETITEMPOSITION32 (LVM_FIRST+49) +#define ListView_SetItemPosition32(hwndLV,i,x0,y0) { POINT ptNewPos; ptNewPos.x = x0; ptNewPos.y = y0; SNDMSG((hwndLV),LVM_SETITEMPOSITION32,(WPARAM)(int)(i),(LPARAM)&ptNewPos); } + +#define LVM_GETSELECTEDCOUNT (LVM_FIRST+50) +#define ListView_GetSelectedCount(hwndLV) (UINT)SNDMSG((hwndLV),LVM_GETSELECTEDCOUNT,0,0L) + +#define LVM_GETITEMSPACING (LVM_FIRST+51) +#define ListView_GetItemSpacing(hwndLV,fSmall) (DWORD)SNDMSG((hwndLV),LVM_GETITEMSPACING,fSmall,0L) + +#define LVM_GETISEARCHSTRINGA (LVM_FIRST+52) +#define LVM_GETISEARCHSTRINGW (LVM_FIRST+117) + +#ifdef UNICODE +#define LVM_GETISEARCHSTRING LVM_GETISEARCHSTRINGW +#else +#define LVM_GETISEARCHSTRING LVM_GETISEARCHSTRINGA +#endif + +#define ListView_GetISearchString(hwndLV,lpsz) (WINBOOL)SNDMSG((hwndLV),LVM_GETISEARCHSTRING,0,(LPARAM)(LPTSTR)(lpsz)) + +#define LVM_SETICONSPACING (LVM_FIRST+53) + +#define ListView_SetIconSpacing(hwndLV,cx,cy) (DWORD)SNDMSG((hwndLV),LVM_SETICONSPACING,0,MAKELONG(cx,cy)) +#define LVM_SETEXTENDEDLISTVIEWSTYLE (LVM_FIRST+54) +#define ListView_SetExtendedListViewStyle(hwndLV,dw) (DWORD)SNDMSG((hwndLV),LVM_SETEXTENDEDLISTVIEWSTYLE,0,dw) +#define ListView_SetExtendedListViewStyleEx(hwndLV,dwMask,dw) (DWORD)SNDMSG((hwndLV),LVM_SETEXTENDEDLISTVIEWSTYLE,dwMask,dw) +#define LVM_GETEXTENDEDLISTVIEWSTYLE (LVM_FIRST+55) +#define ListView_GetExtendedListViewStyle(hwndLV) (DWORD)SNDMSG((hwndLV),LVM_GETEXTENDEDLISTVIEWSTYLE,0,0) +#define LVS_EX_GRIDLINES 0x1 +#define LVS_EX_SUBITEMIMAGES 0x2 +#define LVS_EX_CHECKBOXES 0x4 +#define LVS_EX_TRACKSELECT 0x8 +#define LVS_EX_HEADERDRAGDROP 0x10 +#define LVS_EX_FULLROWSELECT 0x20 +#define LVS_EX_ONECLICKACTIVATE 0x40 +#define LVS_EX_TWOCLICKACTIVATE 0x80 +#define LVS_EX_FLATSB 0x100 +#define LVS_EX_REGIONAL 0x200 +#define LVS_EX_INFOTIP 0x400 +#define LVS_EX_UNDERLINEHOT 0x800 +#define LVS_EX_UNDERLINECOLD 0x1000 +#define LVS_EX_MULTIWORKAREAS 0x2000 +#define LVS_EX_LABELTIP 0x4000 +#define LVS_EX_BORDERSELECT 0x8000 +#define LVS_EX_DOUBLEBUFFER 0x10000 +#define LVS_EX_HIDELABELS 0x20000 +#define LVS_EX_SINGLEROW 0x40000 +#define LVS_EX_SNAPTOGRID 0x80000 +#define LVS_EX_SIMPLESELECT 0x100000 +#if _WIN32_WINNT >= 0x0600 +#define LVS_EX_JUSTIFYCOLUMNS 0x200000 +#define LVS_EX_TRANSPARENTBKGND 0x400000 +#define LVS_EX_TRANSPARENTSHADOWTEXT 0x800000 +#define LVS_EX_AUTOAUTOARRANGE 0x1000000 +#define LVS_EX_HEADERINALLVIEWS 0x2000000 +#define LVS_EX_AUTOCHECKSELECT 0x8000000 +#define LVS_EX_AUTOSIZECOLUMNS 0x10000000 +#define LVS_EX_COLUMNSNAPPOINTS 0x40000000 +#define LVS_EX_COLUMNOVERFLOW 0x80000000 +#endif + +#define LVM_GETSUBITEMRECT (LVM_FIRST+56) +#define ListView_GetSubItemRect(hwnd,iItem,iSubItem,code,prc) (WINBOOL)SNDMSG((hwnd),LVM_GETSUBITEMRECT,(WPARAM)(int)(iItem),((prc) ? ((((LPRECT)(prc))->top = iSubItem),(((LPRECT)(prc))->left = code),(LPARAM)(prc)) : (LPARAM)(LPRECT)NULL)) +#define LVM_SUBITEMHITTEST (LVM_FIRST+57) +#define ListView_SubItemHitTest(hwnd,plvhti) (int)SNDMSG((hwnd),LVM_SUBITEMHITTEST,0,(LPARAM)(LPLVHITTESTINFO)(plvhti)) +#define LVM_SETCOLUMNORDERARRAY (LVM_FIRST+58) +#define ListView_SetColumnOrderArray(hwnd,iCount,pi) (WINBOOL)SNDMSG((hwnd),LVM_SETCOLUMNORDERARRAY,(WPARAM)(iCount),(LPARAM)(LPINT)(pi)) +#define LVM_GETCOLUMNORDERARRAY (LVM_FIRST+59) +#define ListView_GetColumnOrderArray(hwnd,iCount,pi) (WINBOOL)SNDMSG((hwnd),LVM_GETCOLUMNORDERARRAY,(WPARAM)(iCount),(LPARAM)(LPINT)(pi)) +#define LVM_SETHOTITEM (LVM_FIRST+60) +#define ListView_SetHotItem(hwnd,i) (int)SNDMSG((hwnd),LVM_SETHOTITEM,(WPARAM)(i),0) +#define LVM_GETHOTITEM (LVM_FIRST+61) +#define ListView_GetHotItem(hwnd) (int)SNDMSG((hwnd),LVM_GETHOTITEM,0,0) +#define LVM_SETHOTCURSOR (LVM_FIRST+62) +#define ListView_SetHotCursor(hwnd,hcur) (HCURSOR)SNDMSG((hwnd),LVM_SETHOTCURSOR,0,(LPARAM)(hcur)) +#define LVM_GETHOTCURSOR (LVM_FIRST+63) +#define ListView_GetHotCursor(hwnd) (HCURSOR)SNDMSG((hwnd),LVM_GETHOTCURSOR,0,0) +#define LVM_APPROXIMATEVIEWRECT (LVM_FIRST+64) +#define ListView_ApproximateViewRect(hwnd,iWidth,iHeight,iCount) (DWORD)SNDMSG((hwnd),LVM_APPROXIMATEVIEWRECT,iCount,MAKELPARAM(iWidth,iHeight)) + +#define LV_MAX_WORKAREAS 16 +#define LVM_SETWORKAREAS (LVM_FIRST+65) +#define ListView_SetWorkAreas(hwnd,nWorkAreas,prc) (WINBOOL)SNDMSG((hwnd),LVM_SETWORKAREAS,(WPARAM)(int)(nWorkAreas),(LPARAM)(RECT *)(prc)) +#define LVM_GETWORKAREAS (LVM_FIRST+70) +#define ListView_GetWorkAreas(hwnd,nWorkAreas,prc) (WINBOOL)SNDMSG((hwnd),LVM_GETWORKAREAS,(WPARAM)(int)(nWorkAreas),(LPARAM)(RECT *)(prc)) +#define LVM_GETNUMBEROFWORKAREAS (LVM_FIRST+73) +#define ListView_GetNumberOfWorkAreas(hwnd,pnWorkAreas) (WINBOOL)SNDMSG((hwnd),LVM_GETNUMBEROFWORKAREAS,0,(LPARAM)(UINT *)(pnWorkAreas)) +#define LVM_GETSELECTIONMARK (LVM_FIRST+66) +#define ListView_GetSelectionMark(hwnd) (int)SNDMSG((hwnd),LVM_GETSELECTIONMARK,0,0) +#define LVM_SETSELECTIONMARK (LVM_FIRST+67) +#define ListView_SetSelectionMark(hwnd,i) (int)SNDMSG((hwnd),LVM_SETSELECTIONMARK,0,(LPARAM)(i)) +#define LVM_SETHOVERTIME (LVM_FIRST+71) +#define ListView_SetHoverTime(hwndLV,dwHoverTimeMs) (DWORD)SNDMSG((hwndLV),LVM_SETHOVERTIME,0,(LPARAM)(dwHoverTimeMs)) +#define LVM_GETHOVERTIME (LVM_FIRST+72) +#define ListView_GetHoverTime(hwndLV) (DWORD)SNDMSG((hwndLV),LVM_GETHOVERTIME,0,0) +#define LVM_SETTOOLTIPS (LVM_FIRST+74) +#define ListView_SetToolTips(hwndLV,hwndNewHwnd) (HWND)SNDMSG((hwndLV),LVM_SETTOOLTIPS,(WPARAM)(hwndNewHwnd),0) +#define LVM_GETTOOLTIPS (LVM_FIRST+78) +#define ListView_GetToolTips(hwndLV) (HWND)SNDMSG((hwndLV),LVM_GETTOOLTIPS,0,0) +#define LVM_SORTITEMSEX (LVM_FIRST+81) +#define ListView_SortItemsEx(hwndLV,_pfnCompare,_lPrm) (WINBOOL)SNDMSG((hwndLV),LVM_SORTITEMSEX,(WPARAM)(LPARAM)(_lPrm),(LPARAM)(PFNLVCOMPARE)(_pfnCompare)) + + typedef struct tagLVBKIMAGEA { ULONG ulFlags; HBITMAP hbm; LPSTR pszImage; UINT cchImageMax; int xOffsetPercent; int yOffsetPercent; -} LVBKIMAGEA, *LPLVBKIMAGEA; + } LVBKIMAGEA,*LPLVBKIMAGEA; -typedef struct tagLVBKIMAGEW -{ + typedef struct tagLVBKIMAGEW { ULONG ulFlags; HBITMAP hbm; LPWSTR pszImage; UINT cchImageMax; int xOffsetPercent; int yOffsetPercent; -} LVBKIMAGEW, *LPLVBKIMAGEW; + } LVBKIMAGEW,*LPLVBKIMAGEW; -#define LVBKIMAGE WINELIB_NAME_AW(LVBKIMAGE) -#define LPLVBKIMAGE WINELIB_NAME_AW(LPLVBKIMAGE) +#define LVBKIF_SOURCE_NONE 0x0 +#define LVBKIF_SOURCE_HBITMAP 0x1 +#define LVBKIF_SOURCE_URL 0x2 +#define LVBKIF_SOURCE_MASK 0x3 +#define LVBKIF_STYLE_NORMAL 0x0 +#define LVBKIF_STYLE_TILE 0x10 +#define LVBKIF_STYLE_MASK 0x10 +#define LVBKIF_FLAG_TILEOFFSET 0x100 +#define LVBKIF_TYPE_WATERMARK 0x10000000 -#define LVBKIF_SOURCE_NONE 0x00000000 -#define LVBKIF_SOURCE_HBITMAP 0x00000001 -#define LVBKIF_SOURCE_URL 0x00000002 -#define LVBKIF_SOURCE_MASK 0x00000003 -#define LVBKIF_STYLE_NORMAL 0x00000000 -#define LVBKIF_STYLE_TILE 0x00000010 -#define LVBKIF_STYLE_MASK 0x00000010 -#define LVBKIF_FLAG_TILEOFFSET 0x00000100 -#define LVBKIF_TYPE_WATERMARK 0x10000000 +#define LVM_SETBKIMAGEA (LVM_FIRST+68) +#define LVM_SETBKIMAGEW (LVM_FIRST+138) +#define LVM_GETBKIMAGEA (LVM_FIRST+69) +#define LVM_GETBKIMAGEW (LVM_FIRST+139) -#define ListView_SetBkImage(hwnd, plvbki) \ - (BOOL)SNDMSG((hwnd), LVM_SETBKIMAGE, 0, (LPARAM)plvbki) +#define LVM_SETSELECTEDCOLUMN (LVM_FIRST+140) +#define ListView_SetSelectedColumn(hwnd,iCol) SNDMSG((hwnd),LVM_SETSELECTEDCOLUMN,(WPARAM)iCol,0) +#define LVM_SETTILEWIDTH (LVM_FIRST+141) +#define ListView_SetTileWidth(hwnd,cpWidth) SNDMSG((hwnd),LVM_SETTILEWIDTH,(WPARAM)cpWidth,0) +#define LV_VIEW_ICON 0x0 +#define LV_VIEW_DETAILS 0x1 +#define LV_VIEW_SMALLICON 0x2 +#define LV_VIEW_LIST 0x3 +#define LV_VIEW_TILE 0x4 +#define LV_VIEW_MAX 0x4 +#define LVM_SETVIEW (LVM_FIRST+142) +#define ListView_SetView(hwnd,iView) (DWORD)SNDMSG((hwnd),LVM_SETVIEW,(WPARAM)(DWORD)iView,0) +#define LVM_GETVIEW (LVM_FIRST+143) +#define ListView_GetView(hwnd) (DWORD)SNDMSG((hwnd),LVM_GETVIEW,0,0) +#define LVGF_NONE 0x0 +#define LVGF_HEADER 0x1 +#define LVGF_FOOTER 0x2 +#define LVGF_STATE 0x4 +#define LVGF_ALIGN 0x8 +#define LVGF_GROUPID 0x10 -#define ListView_GetBkImage(hwnd, plvbki) \ - (BOOL)SNDMSG((hwnd), LVM_GETBKIMAGE, 0, (LPARAM)plvbki) +#define LVGS_NORMAL 0x0 +#define LVGS_COLLAPSED 0x1 +#define LVGS_HIDDEN 0x2 -typedef struct tagLVCOLUMNA -{ +#define LVGA_HEADER_LEFT 0x1 +#define LVGA_HEADER_CENTER 0x2 +#define LVGA_HEADER_RIGHT 0x4 +#define LVGA_FOOTER_LEFT 0x8 +#define LVGA_FOOTER_CENTER 0x10 +#define LVGA_FOOTER_RIGHT 0x20 + + typedef struct tagLVGROUP { + UINT cbSize; UINT mask; - INT fmt; - INT cx; - LPSTR pszText; - INT cchTextMax; - INT iSubItem; - /* (_WIN32_IE >= 0x0300) */ - INT iImage; - INT iOrder; - /* (_WIN32_WINNT >= 0x0600) */ - INT cxMin; - INT cxDefault; - INT cxIdeal; -} LVCOLUMNA, *LPLVCOLUMNA; + LPWSTR pszHeader; + int cchHeader; + LPWSTR pszFooter; + int cchFooter; + int iGroupId; + UINT stateMask; + UINT state; + UINT uAlign; + } LVGROUP,*PLVGROUP; -typedef struct tagLVCOLUMNW -{ +#define LVM_INSERTGROUP (LVM_FIRST+145) +#define ListView_InsertGroup(hwnd,index,pgrp) SNDMSG((hwnd),LVM_INSERTGROUP,(WPARAM)index,(LPARAM)pgrp) +#define LVM_SETGROUPINFO (LVM_FIRST+147) +#define ListView_SetGroupInfo(hwnd,iGroupId,pgrp) SNDMSG((hwnd),LVM_SETGROUPINFO,(WPARAM)iGroupId,(LPARAM)pgrp) +#define LVM_GETGROUPINFO (LVM_FIRST+149) +#define ListView_GetGroupInfo(hwnd,iGroupId,pgrp) SNDMSG((hwnd),LVM_GETGROUPINFO,(WPARAM)iGroupId,(LPARAM)pgrp) +#define LVM_REMOVEGROUP (LVM_FIRST+150) +#define ListView_RemoveGroup(hwnd,iGroupId) SNDMSG((hwnd),LVM_REMOVEGROUP,(WPARAM)iGroupId,0) +#define LVM_MOVEGROUP (LVM_FIRST+151) +#define ListView_MoveGroup(hwnd,iGroupId,toIndex) SNDMSG((hwnd),LVM_MOVEGROUP,(WPARAM)iGroupId,(LPARAM)toIndex) +#define LVM_MOVEITEMTOGROUP (LVM_FIRST+154) +#define ListView_MoveItemToGroup(hwnd,idItemFrom,idGroupTo) SNDMSG((hwnd),LVM_MOVEITEMTOGROUP,(WPARAM)idItemFrom,(LPARAM)idGroupTo) +#define LVGMF_NONE 0x0 +#define LVGMF_BORDERSIZE 0x1 +#define LVGMF_BORDERCOLOR 0x2 +#define LVGMF_TEXTCOLOR 0x4 + + typedef struct tagLVGROUPMETRICS { + UINT cbSize; UINT mask; - INT fmt; - INT cx; + UINT Left; + UINT Top; + UINT Right; + UINT Bottom; + COLORREF crLeft; + COLORREF crTop; + COLORREF crRight; + COLORREF crBottom; + COLORREF crHeader; + COLORREF crFooter; + } LVGROUPMETRICS,*PLVGROUPMETRICS; + +#define LVM_SETGROUPMETRICS (LVM_FIRST+155) +#define ListView_SetGroupMetrics(hwnd,pGroupMetrics) SNDMSG((hwnd),LVM_SETGROUPMETRICS,0,(LPARAM)pGroupMetrics) +#define LVM_GETGROUPMETRICS (LVM_FIRST+156) +#define ListView_GetGroupMetrics(hwnd,pGroupMetrics) SNDMSG((hwnd),LVM_GETGROUPMETRICS,0,(LPARAM)pGroupMetrics) +#define LVM_ENABLEGROUPVIEW (LVM_FIRST+157) +#define ListView_EnableGroupView(hwnd,fEnable) SNDMSG((hwnd),LVM_ENABLEGROUPVIEW,(WPARAM)fEnable,0) + + typedef int (CALLBACK *PFNLVGROUPCOMPARE)(int,int,void *); + +#define LVM_SORTGROUPS (LVM_FIRST+158) +#define ListView_SortGroups(hwnd,_pfnGroupCompate,_plv) SNDMSG((hwnd),LVM_SORTGROUPS,(WPARAM)_pfnGroupCompate,(LPARAM)_plv) + + typedef struct tagLVINSERTGROUPSORTED { + PFNLVGROUPCOMPARE pfnGroupCompare; + void *pvData; + LVGROUP lvGroup; + } LVINSERTGROUPSORTED,*PLVINSERTGROUPSORTED; + +#define LVM_INSERTGROUPSORTED (LVM_FIRST+159) +#define ListView_InsertGroupSorted(hwnd,structInsert) SNDMSG((hwnd),LVM_INSERTGROUPSORTED,(WPARAM)structInsert,0) +#define LVM_REMOVEALLGROUPS (LVM_FIRST+160) +#define ListView_RemoveAllGroups(hwnd) SNDMSG((hwnd),LVM_REMOVEALLGROUPS,0,0) +#define LVM_HASGROUP (LVM_FIRST+161) +#define ListView_HasGroup(hwnd,dwGroupId) SNDMSG((hwnd),LVM_HASGROUP,dwGroupId,0) + +#define LVTVIF_AUTOSIZE 0x0 +#define LVTVIF_FIXEDWIDTH 0x1 +#define LVTVIF_FIXEDHEIGHT 0x2 +#define LVTVIF_FIXEDSIZE 0x3 + +#define LVTVIM_TILESIZE 0x1 +#define LVTVIM_COLUMNS 0x2 +#define LVTVIM_LABELMARGIN 0x4 + + typedef struct tagLVTILEVIEWINFO { + UINT cbSize; + DWORD dwMask; + DWORD dwFlags; + SIZE sizeTile; + int cLines; + RECT rcLabelMargin; + } LVTILEVIEWINFO,*PLVTILEVIEWINFO; + + typedef struct tagLVTILEINFO { + UINT cbSize; + int iItem; + UINT cColumns; + PUINT puColumns; + } LVTILEINFO,*PLVTILEINFO; + +#define LVM_SETTILEVIEWINFO (LVM_FIRST+162) +#define ListView_SetTileViewInfo(hwnd,ptvi) SNDMSG((hwnd),LVM_SETTILEVIEWINFO,0,(LPARAM)ptvi) +#define LVM_GETTILEVIEWINFO (LVM_FIRST+163) +#define ListView_GetTileViewInfo(hwnd,ptvi) SNDMSG((hwnd),LVM_GETTILEVIEWINFO,0,(LPARAM)ptvi) +#define LVM_SETTILEINFO (LVM_FIRST+164) +#define ListView_SetTileInfo(hwnd,pti) SNDMSG((hwnd),LVM_SETTILEINFO,0,(LPARAM)pti) +#define LVM_GETTILEINFO (LVM_FIRST+165) +#define ListView_GetTileInfo(hwnd,pti) SNDMSG((hwnd),LVM_GETTILEINFO,0,(LPARAM)pti) + + typedef struct { + UINT cbSize; + DWORD dwFlags; + int iItem; + DWORD dwReserved; + } LVINSERTMARK,*LPLVINSERTMARK; + +#define LVIM_AFTER 0x1 + +#define LVM_SETINSERTMARK (LVM_FIRST+166) +#define ListView_SetInsertMark(hwnd,lvim) (WINBOOL)SNDMSG((hwnd),LVM_SETINSERTMARK,(WPARAM) 0,(LPARAM) (lvim)) +#define LVM_GETINSERTMARK (LVM_FIRST+167) +#define ListView_GetInsertMark(hwnd,lvim) (WINBOOL)SNDMSG((hwnd),LVM_GETINSERTMARK,(WPARAM) 0,(LPARAM) (lvim)) +#define LVM_INSERTMARKHITTEST (LVM_FIRST+168) +#define ListView_InsertMarkHitTest(hwnd,point,lvim) (int)SNDMSG((hwnd),LVM_INSERTMARKHITTEST,(WPARAM)(LPPOINT)(point),(LPARAM)(LPLVINSERTMARK)(lvim)) +#define LVM_GETINSERTMARKRECT (LVM_FIRST+169) +#define ListView_GetInsertMarkRect(hwnd,rc) (int)SNDMSG((hwnd),LVM_GETINSERTMARKRECT,(WPARAM)0,(LPARAM)(LPRECT)(rc)) +#define LVM_SETINSERTMARKCOLOR (LVM_FIRST+170) +#define ListView_SetInsertMarkColor(hwnd,color) (COLORREF)SNDMSG((hwnd),LVM_SETINSERTMARKCOLOR,(WPARAM)0,(LPARAM)(COLORREF)(color)) +#define LVM_GETINSERTMARKCOLOR (LVM_FIRST+171) +#define ListView_GetInsertMarkColor(hwnd) (COLORREF)SNDMSG((hwnd),LVM_GETINSERTMARKCOLOR,(WPARAM)0,(LPARAM)0) + + typedef struct tagLVSETINFOTIP { + UINT cbSize; + DWORD dwFlags; LPWSTR pszText; - INT cchTextMax; - INT iSubItem; - /* (_WIN32_IE >= 0x0300) */ - INT iImage; - INT iOrder; - /* (_WIN32_WINNT >= 0x0600) */ - INT cxMin; - INT cxDefault; - INT cxIdeal; -} LVCOLUMNW, *LPLVCOLUMNW; + int iItem; + int iSubItem; + } LVSETINFOTIP,*PLVSETINFOTIP; -#define LVCOLUMN WINELIB_NAME_AW(LVCOLUMN) -#define LPLVCOLUMN WINELIB_NAME_AW(LPLVCOLUMN) +#define LVM_SETINFOTIP (LVM_FIRST+173) +#define ListView_SetInfoTip(hwndLV,plvInfoTip) (WINBOOL)SNDMSG((hwndLV),LVM_SETINFOTIP,(WPARAM)0,(LPARAM)plvInfoTip) +#define LVM_GETSELECTEDCOLUMN (LVM_FIRST+174) +#define ListView_GetSelectedColumn(hwnd) (UINT)SNDMSG((hwnd),LVM_GETSELECTEDCOLUMN,0,0) +#define LVM_ISGROUPVIEWENABLED (LVM_FIRST+175) +#define ListView_IsGroupViewEnabled(hwnd) (WINBOOL)SNDMSG((hwnd),LVM_ISGROUPVIEWENABLED,0,0) +#define LVM_GETOUTLINECOLOR (LVM_FIRST+176) +#define ListView_GetOutlineColor(hwnd) (COLORREF)SNDMSG((hwnd),LVM_GETOUTLINECOLOR,0,0) +#define LVM_SETOUTLINECOLOR (LVM_FIRST+177) +#define ListView_SetOutlineColor(hwnd,color) (COLORREF)SNDMSG((hwnd),LVM_SETOUTLINECOLOR,(WPARAM)0,(LPARAM)(COLORREF)(color)) +#define LVM_CANCELEDITLABEL (LVM_FIRST+179) +#define ListView_CancelEditLabel(hwnd) (VOID)SNDMSG((hwnd),LVM_CANCELEDITLABEL,(WPARAM)0,(LPARAM)0) +#define LVM_MAPINDEXTOID (LVM_FIRST+180) +#define ListView_MapIndexToID(hwnd,index) (UINT)SNDMSG((hwnd),LVM_MAPINDEXTOID,(WPARAM)index,(LPARAM)0) +#define LVM_MAPIDTOINDEX (LVM_FIRST+181) +#define ListView_MapIDToIndex(hwnd,id) (UINT)SNDMSG((hwnd),LVM_MAPIDTOINDEX,(WPARAM)id,(LPARAM)0) +#define LVM_ISITEMVISIBLE (LVM_FIRST+182) +#define ListView_IsItemVisible(hwnd,index) (UINT)SNDMSG((hwnd),LVM_ISITEMVISIBLE,(WPARAM)(index),(LPARAM)0) -#define LVCOLUMN_V1_SIZEA CCSIZEOF_STRUCT(LVCOLUMNA, iSubItem) -#define LVCOLUMN_V1_SIZEW CCSIZEOF_STRUCT(LVCOLUMNW, iSubItem) -#define LVCOLUMN_V1_SIZE WINELIB_NAME_AW(LVCOLUMN_V1_SIZE) +#ifdef UNICODE +#define LVBKIMAGE LVBKIMAGEW +#define LPLVBKIMAGE LPLVBKIMAGEW +#define LVM_SETBKIMAGE LVM_SETBKIMAGEW +#define LVM_GETBKIMAGE LVM_GETBKIMAGEW +#else +#define LVBKIMAGE LVBKIMAGEA +#define LPLVBKIMAGE LPLVBKIMAGEA +#define LVM_SETBKIMAGE LVM_SETBKIMAGEA +#define LVM_GETBKIMAGE LVM_GETBKIMAGEA +#endif -#define LV_COLUMN LVCOLUMN +#define ListView_SetBkImage(hwnd,plvbki) (WINBOOL)SNDMSG((hwnd),LVM_SETBKIMAGE,0,(LPARAM)(plvbki)) +#define ListView_GetBkImage(hwnd,plvbki) (WINBOOL)SNDMSG((hwnd),LVM_GETBKIMAGE,0,(LPARAM)(plvbki)) +#define LPNM_LISTVIEW LPNMLISTVIEW +#define NM_LISTVIEW NMLISTVIEW -typedef struct tagNMLISTVIEW -{ + typedef struct tagNMLISTVIEW { NMHDR hdr; - INT iItem; - INT iSubItem; + int iItem; + int iSubItem; UINT uNewState; UINT uOldState; UINT uChanged; POINT ptAction; - LPARAM lParam; -} NMLISTVIEW, *LPNMLISTVIEW; + LPARAM lParam; + } NMLISTVIEW,*LPNMLISTVIEW; -#define NM_LISTVIEW NMLISTVIEW -#define LPNM_LISTVIEW LPNMLISTVIEW - -typedef struct tagNMITEMACTIVATE -{ + typedef struct tagNMITEMACTIVATE { NMHDR hdr; int iItem; int iSubItem; @@ -3484,862 +3052,832 @@ typedef struct tagNMITEMACTIVATE POINT ptAction; LPARAM lParam; UINT uKeyFlags; -} NMITEMACTIVATE, *LPNMITEMACTIVATE; + } NMITEMACTIVATE,*LPNMITEMACTIVATE; -#define LVKF_ALT 0x0001 -#define LVKF_CONTROL 0x0002 -#define LVKF_SHIFT 0x0004 +#define LVKF_ALT 0x1 +#define LVKF_CONTROL 0x2 +#define LVKF_SHIFT 0x4 -typedef struct tagLVDISPINFO -{ - NMHDR hdr; - LVITEMA item; -} NMLVDISPINFOA, *LPNMLVDISPINFOA; +#define NMLVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMLVCUSTOMDRW,clrTextBk) -typedef struct tagLVDISPINFOW -{ - NMHDR hdr; - LVITEMW item; -} NMLVDISPINFOW, *LPNMLVDISPINFOW; - -#define NMLVDISPINFO WINELIB_NAME_AW(NMLVDISPINFO) -#define LPNMLVDISPINFO WINELIB_NAME_AW(LPNMLVDISPINFO) - -#define LV_DISPINFO NMLVDISPINFO -#define LV_DISPINFOA NMLVDISPINFOA -#define LV_DISPINFOW NMLVDISPINFOW - -#include -typedef struct tagLVKEYDOWN -{ - NMHDR hdr; - WORD wVKey; - UINT flags; -} NMLVKEYDOWN, *LPNMLVKEYDOWN; -#include - -#define LV_KEYDOWN NMLVKEYDOWN - -typedef struct tagNMLVGETINFOTIPA -{ - NMHDR hdr; - DWORD dwFlags; - LPSTR pszText; - int cchTextMax; - int iItem; - int iSubItem; - LPARAM lParam; -} NMLVGETINFOTIPA, *LPNMLVGETINFOTIPA; - -typedef struct tagNMLVGETINFOTIPW -{ - NMHDR hdr; - DWORD dwFlags; - LPWSTR pszText; - int cchTextMax; - int iItem; - int iSubItem; - LPARAM lParam; -} NMLVGETINFOTIPW, *LPNMLVGETINFOTIPW; - -#define NMLVGETINFOTIP WINELIB_NAME_AW(NMLVGETINFOTIP) -#define LPNMLVGETINFOTIP WINELIB_NAME_AW(LPNMLVGETINFOTIP) - -typedef struct tagLVHITTESTINFO -{ - POINT pt; - UINT flags; - INT iItem; - INT iSubItem; - /* (_WIN32_WINNT >= 0x0600) */ - INT iGroup; -} LVHITTESTINFO, *LPLVHITTESTINFO; - -#define LV_HITTESTINFO LVHITTESTINFO -#define _LV_HITTESTINFO tagLVHITTESTINFO -#define LVHITTESTINFO_V1_SIZE CCSIZEOF_STRUCT(LVHITTESTINFO,iItem) - -typedef struct tagLVFINDINFOA -{ - UINT flags; - LPCSTR psz; - LPARAM lParam; - POINT pt; - UINT vkDirection; -} LVFINDINFOA, *LPLVFINDINFOA; - -typedef struct tagLVFINDINFOW -{ - UINT flags; - LPCWSTR psz; - LPARAM lParam; - POINT pt; - UINT vkDirection; -} LVFINDINFOW, *LPLVFINDINFOW; - -#define LVFINDINFO WINELIB_NAME_AW(LVFINDINFO) -#define LPLVFINDINFO WINELIB_NAME_AW(LPLVFINDINFO) - -#define LV_FINDINFO LVFINDINFO -#define LV_FINDINFOA LVFINDINFOA -#define LV_FINDINFOW LVFINDINFOW - -/* Groups relates structures */ - -typedef struct LVGROUP -{ - UINT cbSize; - UINT mask; - LPWSTR pszHeader; - INT cchHeader; - LPWSTR pszFooter; - INT cchFooter; - INT iGroupId; - UINT stateMask; - UINT state; - UINT uAlign; - /* (_WIN32_WINNT >= 0x0600) */ - LPWSTR pszSubtitle; - UINT cchSubtitle; - LPWSTR pszTask; - UINT cchTask; - LPWSTR pszDescriptionTop; - UINT cchDescriptionTop; - LPWSTR pszDescriptionBottom; - UINT cchDescriptionBottom; - INT iTitleImage; - INT iExtendedImage; - INT iFirstItem; - UINT cItems; - LPWSTR pszSubsetTitle; - UINT cchSubsetTitle; -} LVGROUP, *PLVGROUP; - -#define LVGROUP_V5_SIZE CCSIZEOF_STRUCT(LVGROUP, uAlign) - -typedef struct LVGROUPMETRICS -{ - UINT cbSize; - UINT mask; - UINT Left; - UINT Top; - UINT Right; - UINT Bottom; - COLORREF crLeft; - COLORREF crTop; - COLORREF crRight; - COLORREF crBottom; - COLORREF crRightHeader; - COLORREF crFooter; -} LVGROUPMETRICS, *PLVGROUPMETRICS; - -typedef INT (*PFNLVGROUPCOMPARE)(INT, INT, VOID*); - -typedef struct LVINSERTGROUPSORTED -{ - PFNLVGROUPCOMPARE pfnGroupCompare; - LPVOID *pvData; - LVGROUP lvGroup; -} LVINSERTGROUPSORTED, *PLVINSERTGROUPSORTED; - -/* Tile related structures */ - -typedef struct LVTILEINFO -{ - UINT cbSize; - int iItem; - UINT cColumns; - PUINT puColumns; - /* (_WIN32_WINNT >= 0x0600) */ - int* piColFmt; -} LVTILEINFO, *PLVTILEINFO; - -typedef struct LVTILEVIEWINFO -{ - UINT cbSize; - DWORD dwMask; - DWORD dwFlags; - SIZE sizeTile; - int cLines; - RECT rcLabelMargin; -} LVTILEVIEWINFO, *PLVTILEVIEWINFO; - -typedef struct LVINSERTMARK -{ - UINT cbSize; - DWORD dwFlags; - int iItem; - DWORD dwReserved; -} LVINSERTMARK, *PLVINSERTMARK; - -typedef struct tagTCHITTESTINFO -{ - POINT pt; - UINT flags; -} TCHITTESTINFO, *LPTCHITTESTINFO; - -#define TC_HITTESTINFO TCHITTESTINFO - -typedef INT (CALLBACK *PFNLVCOMPARE)(LPARAM, LPARAM, LPARAM); - -#define NMLVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMLCUSTOMDRW, clrTextBk) - -typedef struct tagNMLVCUSTOMDRAW -{ + typedef struct tagNMLVCUSTOMDRAW { NMCUSTOMDRAW nmcd; COLORREF clrText; COLORREF clrTextBk; - int iSubItem; /* (_WIN32_IE >= 0x0400) */ - DWORD dwItemType; /* (_WIN32_IE >= 0x560) */ - COLORREF clrFace; /* (_WIN32_IE >= 0x560) */ - int iIconEffect; /* (_WIN32_IE >= 0x560) */ - int iIconPhase; /* (_WIN32_IE >= 0x560) */ - int iPartId; /* (_WIN32_IE >= 0x560) */ - int iStateId; /* (_WIN32_IE >= 0x560) */ - RECT rcText; /* (_WIN32_IE >= 0x560) */ - UINT uAlign; /* (_WIN32_IE >= 0x560) */ -} NMLVCUSTOMDRAW, *LPNMLVCUSTOMDRAW; + int iSubItem; + DWORD dwItemType; + COLORREF clrFace; + int iIconEffect; + int iIconPhase; + int iPartId; + int iStateId; + RECT rcText; + UINT uAlign; + } NMLVCUSTOMDRAW,*LPNMLVCUSTOMDRAW; -typedef struct tagNMLVCACHEHINT -{ - NMHDR hdr; - INT iFrom; - INT iTo; -} NMLVCACHEHINT, *LPNMLVCACHEHINT; +#define LVCDI_ITEM 0x0 +#define LVCDI_GROUP 0x1 + +#define LVCDRF_NOSELECT 0x10000 +#define LVCDRF_NOGROUPFRAME 0x20000 + + typedef struct tagNMLVCACHEHINT { + NMHDR hdr; + int iFrom; + int iTo; + } NMLVCACHEHINT,*LPNMLVCACHEHINT; #define LPNM_CACHEHINT LPNMLVCACHEHINT -#define PNM_CACHEHINT LPNMLVCACHEHINT -#define NM_CACHEHINT NMLVCACHEHINT +#define PNM_CACHEHINT LPNMLVCACHEHINT +#define NM_CACHEHINT NMLVCACHEHINT -typedef struct tagNMLVFINDITEMA -{ + typedef struct tagNMLVFINDITEMA { NMHDR hdr; int iStart; LVFINDINFOA lvfi; -} NMLVFINDITEMA, *LPNMLVFINDITEMA; + } NMLVFINDITEMA,*LPNMLVFINDITEMA; -typedef struct tagNMLVFINDITEMW -{ + typedef struct tagNMLVFINDITEMW { NMHDR hdr; int iStart; LVFINDINFOW lvfi; -} NMLVFINDITEMW, *LPNMLVFINDITEMW; + } NMLVFINDITEMW,*LPNMLVFINDITEMW; -#define NMLVFINDITEM WINELIB_NAME_AW(NMLVFINDITEM) -#define LPNMLVFINDITEM WINELIB_NAME_AW(LPNMLVFINDITEM) -#define NM_FINDITEM NMLVFINDITEM -#define LPNM_FINDITEM LPNMLVFINDITEM -#define PNM_FINDITEM LPNMLVFINDITEM +#define PNM_FINDITEMA LPNMLVFINDITEMA +#define LPNM_FINDITEMA LPNMLVFINDITEMA +#define NM_FINDITEMA NMLVFINDITEMA -typedef struct tagNMLVODSTATECHANGE -{ +#define PNM_FINDITEMW LPNMLVFINDITEMW +#define LPNM_FINDITEMW LPNMLVFINDITEMW +#define NM_FINDITEMW NMLVFINDITEMW + +#ifdef UNICODE +#define PNM_FINDITEM PNM_FINDITEMW +#define LPNM_FINDITEM LPNM_FINDITEMW +#define NM_FINDITEM NM_FINDITEMW +#define NMLVFINDITEM NMLVFINDITEMW +#define LPNMLVFINDITEM LPNMLVFINDITEMW +#else +#define PNM_FINDITEM PNM_FINDITEMA +#define LPNM_FINDITEM LPNM_FINDITEMA +#define NM_FINDITEM NM_FINDITEMA +#define NMLVFINDITEM NMLVFINDITEMA +#define LPNMLVFINDITEM LPNMLVFINDITEMA +#endif + + typedef struct tagNMLVODSTATECHANGE { NMHDR hdr; int iFrom; int iTo; UINT uNewState; UINT uOldState; -} NMLVODSTATECHANGE, *LPNMLVODSTATECHANGE; + } NMLVODSTATECHANGE,*LPNMLVODSTATECHANGE; #define PNM_ODSTATECHANGE LPNMLVODSTATECHANGE #define LPNM_ODSTATECHANGE LPNMLVODSTATECHANGE #define NM_ODSTATECHANGE NMLVODSTATECHANGE -typedef struct NMLVSCROLL -{ - NMHDR hdr; - int dx; - int dy; -} NMLVSCROLL, *LPNMLVSCROLL; +#define LVN_ITEMCHANGING (LVN_FIRST-0) +#define LVN_ITEMCHANGED (LVN_FIRST-1) +#define LVN_INSERTITEM (LVN_FIRST-2) +#define LVN_DELETEITEM (LVN_FIRST-3) +#define LVN_DELETEALLITEMS (LVN_FIRST-4) +#define LVN_BEGINLABELEDITA (LVN_FIRST-5) +#define LVN_BEGINLABELEDITW (LVN_FIRST-75) +#define LVN_ENDLABELEDITA (LVN_FIRST-6) +#define LVN_ENDLABELEDITW (LVN_FIRST-76) +#define LVN_COLUMNCLICK (LVN_FIRST-8) +#define LVN_BEGINDRAG (LVN_FIRST-9) +#define LVN_BEGINRDRAG (LVN_FIRST-11) -#define ListView_SetItemCount(hwnd,count) \ - (BOOL)SNDMSG((hwnd),LVM_SETITEMCOUNT,(WPARAM)(INT)(count),0) -#define ListView_SetTextBkColor(hwnd,clrBk) \ - (BOOL)SNDMSG((hwnd),LVM_SETTEXTBKCOLOR,0,(LPARAM)(COLORREF)(clrBk)) -#define ListView_SetTextColor(hwnd,clrBk) \ - (BOOL)SNDMSG((hwnd),LVM_SETTEXTCOLOR,0,(LPARAM)(COLORREF)(clrBk)) -#define ListView_DeleteColumn(hwnd,col)\ - (LRESULT)SNDMSG((hwnd),LVM_DELETECOLUMN,0,(LPARAM)(INT)(col)) -#define ListView_GetColumnA(hwnd,x,col)\ - (LRESULT)SNDMSGA((hwnd),LVM_GETCOLUMNA,(WPARAM)(INT)(x),(LPARAM)(LPLVCOLUMNA)(col)) -#define ListView_GetColumnW(hwnd,x,col)\ - (LRESULT)SNDMSGW((hwnd),LVM_GETCOLUMNW,(WPARAM)(INT)(x),(LPARAM)(LPLVCOLUMNW)(col)) -#define ListView_GetColumn WINELIB_NAME_AW(ListView_GetColumn) -#define ListView_SetColumnA(hwnd,x,col)\ - (LRESULT)SNDMSGA((hwnd),LVM_SETCOLUMNA,(WPARAM)(INT)(x),(LPARAM)(LPLVCOLUMNA)(col)) -#define ListView_SetColumnW(hwnd,x,col)\ - (LRESULT)SNDMSGW((hwnd),LVM_SETCOLUMNW,(WPARAM)(INT)(x),(LPARAM)(LPLVCOLUMNW)(col)) -#define ListView_SetColumn WINELIB_NAME_AW(ListView_SetColumn) -#define ListView_GetColumnWidth(hwnd,x)\ - (INT)SNDMSG((hwnd),LVM_GETCOLUMNWIDTH,(WPARAM)(INT)(x),0L) -#define ListView_SetColumnWidth(hwnd,x,width)\ - (BOOL)SNDMSG((hwnd),LVM_SETCOLUMNWIDTH,(WPARAM)(INT)(x),(LPARAM)(MAKELPARAM(width,0))) +#define LVN_ODCACHEHINT (LVN_FIRST-13) +#define LVN_ODFINDITEMA (LVN_FIRST-52) +#define LVN_ODFINDITEMW (LVN_FIRST-79) +#define LVN_ITEMACTIVATE (LVN_FIRST-14) +#define LVN_ODSTATECHANGED (LVN_FIRST-15) -#define ListView_GetNextItem(hwnd,nItem,flags) \ - (INT)SNDMSG((hwnd),LVM_GETNEXTITEM,(WPARAM)(INT)(nItem),(LPARAM)(MAKELPARAM(flags,0))) -#define ListView_FindItemA(hwnd,nItem,plvfi) \ - (INT)SNDMSGA((hwnd),LVM_FINDITEMA,(WPARAM)(INT)(nItem),(LPARAM)(LVFINDINFOA*)(plvfi)) -#define ListView_FindItemW(hwnd,nItem,plvfi) \ - (INT)SNDMSGW((hwnd),LVM_FINDITEMW,(WPARAM)(INT)(nItem),(LPARAM)(LVFINDINFOW*)(plvfi)) -#define ListView_FindItem WINELIB_NAME_AW(ListView_FindItem) - -#define ListView_Arrange(hwnd,code) \ - (INT)SNDMSG((hwnd),LVM_ARRANGE,(WPARAM)(INT)(code),0L) -#define ListView_GetItemPosition(hwnd,i,ppt) \ - (INT)SNDMSG((hwnd),LVM_GETITEMPOSITION,(WPARAM)(INT)(i),(LPARAM)(LPPOINT)(ppt)) -#define ListView_GetItemRect(hwnd,i,prc,code) \ - (BOOL)SNDMSG((hwnd), LVM_GETITEMRECT, (WPARAM)(int)(i), \ - ((prc) ? (((RECT*)(prc))->left = (code),(LPARAM)(RECT \ - *)(prc)) : (LPARAM)(RECT*)NULL)) -#define ListView_SetItemA(hwnd,pitem) \ - (INT)SNDMSGA((hwnd),LVM_SETITEMA,0,(LPARAM)(const LVITEMA *)(pitem)) -#define ListView_SetItemW(hwnd,pitem) \ - (INT)SNDMSGW((hwnd),LVM_SETITEMW,0,(LPARAM)(const LVITEMW *)(pitem)) -#define ListView_SetItem WINELIB_NAME_AW(ListView_SetItem) -#define ListView_SetItemState(hwnd,i,data,dataMask) \ -{ LVITEM _LVi; _LVi.state = data; _LVi.stateMask = dataMask;\ - SNDMSG(hwnd, LVM_SETITEMSTATE, (WPARAM)(UINT)i, (LPARAM) (LPLVITEM)&_LVi);} -#define ListView_GetItemState(hwnd,i,mask) \ - (UINT)SNDMSG((hwnd),LVM_GETITEMSTATE,(WPARAM)(UINT)(i),(LPARAM)(UINT)(mask)) -#define ListView_SetCheckState(hwndLV, i, bCheck) \ - { LVITEM _LVi; _LVi.state = INDEXTOSTATEIMAGEMASK((bCheck)?2:1); _LVi.stateMask = LVIS_STATEIMAGEMASK; \ - SNDMSG(hwndLV, LVM_SETITEMSTATE, (WPARAM)(UINT)(i), (LPARAM)(LPLVITEM)&_LVi);} -#define ListView_GetCheckState(hwndLV, i) \ - (((UINT)SNDMSG((hwndLV), LVM_GETITEMSTATE, (i), LVIS_STATEIMAGEMASK) >> 12) - 1) -#define ListView_GetCountPerPage(hwnd) \ - (BOOL)SNDMSG((hwnd),LVM_GETCOUNTPERPAGE,0,0L) -#define ListView_GetImageList(hwnd,iImageList) \ - (HIMAGELIST)SNDMSG((hwnd),LVM_GETIMAGELIST,(WPARAM)(INT)(iImageList),0L) -#define ListView_GetStringWidthA(hwnd,pstr) \ - (INT)SNDMSGA((hwnd),LVM_GETSTRINGWIDTHA,0,(LPARAM)(LPCSTR)(pstr)) -#define ListView_GetStringWidthW(hwnd,pstr) \ - (INT)SNDMSGW((hwnd),LVM_GETSTRINGWIDTHW,0,(LPARAM)(LPCWSTR)(pstr)) -#define ListView_GetStringWidth WINELIB_NAME_AW(ListView_GetStringWidth) -#define ListView_GetTopIndex(hwnd) \ - (BOOL)SNDMSG((hwnd),LVM_GETTOPINDEX,0,0L) -#define ListView_Scroll(hwnd,dx,dy) \ - (BOOL)SNDMSG((hwnd),LVM_SCROLL,(WPARAM)(INT)(dx),(LPARAM)(INT)(dy)) -#define ListView_EnsureVisible(hwnd,i,fPartialOk) \ - (BOOL)SNDMSG((hwnd),LVM_ENSUREVISIBLE,(WPARAM)(INT)i,(LPARAM)(BOOL)fPartialOk) -#define ListView_SetBkColor(hwnd,clrBk) \ - (BOOL)SNDMSG((hwnd),LVM_SETBKCOLOR,0,(LPARAM)(COLORREF)(clrBk)) -#define ListView_SetImageList(hwnd,himl,iImageList) \ - (HIMAGELIST)SNDMSG((hwnd),LVM_SETIMAGELIST,(WPARAM)(iImageList),(LPARAM)(HIMAGELIST)(himl)) -#define ListView_GetItemCount(hwnd) \ - (INT)SNDMSG((hwnd),LVM_GETITEMCOUNT,0,0L) -#define ListView_RedrawItems(hwnd,first,last) \ - (BOOL)SNDMSG((hwnd),LVM_REDRAWITEMS,(WPARAM)(INT)(first),(LPARAM)(INT)(last)) -#define ListView_GetEditControl(hwnd) \ - (HWND)SNDMSG((hwnd), LVM_GETEDITCONTROL, 0, 0) -#define ListView_GetTextColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), LVM_GETTEXTCOLOR, 0, 0) -#define ListView_GetTextBkColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), LVM_GETTEXTBKCOLOR, 0, 0) -#define ListView_GetBkColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), LVM_GETBKCOLOR, 0, 0) -#define ListView_GetItemA(hwnd,pitem) \ - (BOOL)SNDMSGA((hwnd),LVM_GETITEMA,0,(LPARAM)(LVITEMA *)(pitem)) -#define ListView_GetItemW(hwnd,pitem) \ - (BOOL)SNDMSGW((hwnd),LVM_GETITEMW,0,(LPARAM)(LVITEMW *)(pitem)) -#define ListView_GetItem WINELIB_NAME_AW(ListView_GetItem) -#define ListView_GetOrigin(hwnd,ppt) \ - (BOOL)SNDMSG((hwnd),LVM_GETORIGIN,0,(LPARAM)(POINT *)(ppt)) - -#define ListView_HitTest(hwnd,pinfo) \ - (INT)SNDMSG((hwnd),LVM_HITTEST,0,(LPARAM)(LPLVHITTESTINFO)(pinfo)) - -#define ListView_InsertItemA(hwnd,pitem) \ - (INT)SNDMSGA((hwnd),LVM_INSERTITEMA,0,(LPARAM)(const LVITEMA *)(pitem)) -#define ListView_InsertItemW(hwnd,pitem) \ - (INT)SNDMSGW((hwnd),LVM_INSERTITEMW,0,(LPARAM)(const LVITEMW *)(pitem)) -#define ListView_InsertItem WINELIB_NAME_AW(ListView_InsertItem) - -#define ListView_DeleteAllItems(hwnd) \ - (BOOL)SNDMSG((hwnd),LVM_DELETEALLITEMS,0,0L) - -#define ListView_InsertColumnA(hwnd,iCol,pcol) \ - (INT)SNDMSGA((hwnd),LVM_INSERTCOLUMNA,(WPARAM)(INT)(iCol),(LPARAM)(const LVCOLUMNA *)(pcol)) -#define ListView_InsertColumnW(hwnd,iCol,pcol) \ - (INT)SNDMSGW((hwnd),LVM_INSERTCOLUMNW,(WPARAM)(INT)(iCol),(LPARAM)(const LVCOLUMNW *)(pcol)) -#define ListView_InsertColumn WINELIB_NAME_AW(ListView_InsertColumn) - -#define ListView_SortItems(hwndLV,_pfnCompare,_lPrm) \ - (BOOL)SNDMSG((hwndLV),LVM_SORTITEMS,(WPARAM)(LPARAM)_lPrm,(LPARAM)(PFNLVCOMPARE)_pfnCompare) -#define ListView_SortItemsEx(hwndLV, _pfnCompare, _lPrm) \ - (BOOL)SNDMSG((hwndLV), LVM_SORTITEMSEX, (WPARAM)(LPARAM)(_lPrm), (LPARAM)(PFNLVCOMPARE)(_pfnCompare)) - -#define ListView_SetItemPosition(hwndLV, i, x, y) \ - (BOOL)SNDMSG((hwndLV),LVM_SETITEMPOSITION,(WPARAM)(INT)(i),MAKELPARAM((x),(y))) -#define ListView_GetSelectedCount(hwndLV) \ - (UINT)SNDMSG((hwndLV),LVM_GETSELECTEDCOUNT,0,0L) - -#define ListView_EditLabelA(hwndLV, i) \ - (HWND)SNDMSG((hwndLV),LVM_EDITLABELA,(WPARAM)(int)(i), 0L) -#define ListView_EditLabelW(hwndLV, i) \ - (HWND)SNDMSG((hwndLV),LVM_EDITLABELW,(WPARAM)(int)(i), 0L) -#define ListView_EditLabel WINELIB_NAME_AW(ListView_EditLabel) - -#define ListView_GetItemTextA(hwndLV, i, _iSubItem, _pszText, _cchTextMax) \ -{ \ - LVITEMA _LVi;\ - _LVi.iSubItem = _iSubItem;\ - _LVi.cchTextMax = _cchTextMax;\ - _LVi.pszText = _pszText;\ - SNDMSGA(hwndLV, LVM_GETITEMTEXTA, (WPARAM)(i), (LPARAM)&_LVi);\ -} -#define ListView_GetItemTextW(hwndLV, i, _iSubItem, _pszText, _cchTextMax) \ -{ \ - LVITEMW _LVi;\ - _LVi.iSubItem = _iSubItem;\ - _LVi.cchTextMax = _cchTextMax;\ - _LVi.pszText = _pszText;\ - SNDMSGW(hwndLV, LVM_GETITEMTEXTW, (WPARAM)(i), (LPARAM)&_LVi);\ -} -#define ListView_GetItemText WINELIB_NAME_AW(ListView_GetItemText) -#define ListView_SetItemPosition32(hwnd,n,x1,y1) \ -{ POINT ptNewPos; ptNewPos.x = (x1); ptNewPos.y = (y1); SNDMSG((hwnd), LVM_SETITEMPOSITION32, (WPARAM)(int)(n), (LPARAM)&ptNewPos); } -#define ListView_SetItemTextA(hwndLV, i, _iSubItem, _pszText) \ -{ LVITEMA _LVi; _LVi.iSubItem = _iSubItem; _LVi.pszText = _pszText;\ - SNDMSGA(hwndLV, LVM_SETITEMTEXTA, (WPARAM)i, (LPARAM) (LVITEMA*)&_LVi);} -#define ListView_SetItemTextW(hwndLV, i, _iSubItem, _pszText) \ -{ LVITEMW _LVi; _LVi.iSubItem = _iSubItem; _LVi.pszText = _pszText;\ - SNDMSGW(hwndLV, LVM_SETITEMTEXTW, (WPARAM)i, (LPARAM) (LVITEMW*)& _LVi);} -#define ListView_SetItemText WINELIB_NAME_AW(ListView_SetItemText) - -#define ListView_DeleteItem(hwndLV, i) \ - (BOOL)SNDMSG(hwndLV, LVM_DELETEITEM, (WPARAM)(int)(i), 0L) -#define ListView_Update(hwndLV, i) \ - (BOOL)SNDMSG((hwndLV), LVM_UPDATE, (WPARAM)(i), 0L) -#define ListView_GetColumnOrderArray(hwndLV, iCount, pi) \ - (BOOL)SNDMSG((hwndLV), LVM_GETCOLUMNORDERARRAY, (WPARAM)iCount, (LPARAM)(LPINT)pi) -#define ListView_GetExtendedListViewStyle(hwndLV) \ - (DWORD)SNDMSG((hwndLV), LVM_GETEXTENDEDLISTVIEWSTYLE, 0, 0L) -#define ListView_GetHotCursor(hwndLV) \ - (HCURSOR)SNDMSG((hwndLV), LVM_GETHOTCURSOR, 0, 0L) -#define ListView_GetHotItem(hwndLV) \ - (int)SNDMSG((hwndLV), LVM_GETHOTITEM, 0, 0L) -#define ListView_GetItemSpacing(hwndLV, fSmall) \ - (DWORD)SNDMSG((hwndLV), LVM_GETITEMSPACING, (WPARAM)fSmall, 0L) -#define ListView_GetSubItemRect(hwndLV, iItem, iSubItem, code, prc) \ - (BOOL)SNDMSG((hwndLV), LVM_GETSUBITEMRECT, (WPARAM)(int)(iItem), \ - ((prc) ? ((((LPRECT)(prc))->top = iSubItem), (((LPRECT)(prc))->left = code), (LPARAM)(prc)) : 0)) -#define ListView_GetToolTips(hwndLV) \ - (HWND)SNDMSG((hwndLV), LVM_GETTOOLTIPS, 0, 0L) -#define ListView_SetColumnOrderArray(hwndLV, iCount, pi) \ - (BOOL)SNDMSG((hwndLV), LVM_SETCOLUMNORDERARRAY, (WPARAM)iCount, (LPARAM)(LPINT)pi) -#define ListView_SetExtendedListViewStyle(hwndLV, dw) \ - (DWORD)SNDMSG((hwndLV), LVM_SETEXTENDEDLISTVIEWSTYLE, 0, (LPARAM)dw) -#define ListView_SetExtendedListViewStyleEx(hwndLV, dwMask, dw) \ - (DWORD)SNDMSG((hwndLV), LVM_SETEXTENDEDLISTVIEWSTYLE, (WPARAM)dwMask, (LPARAM)dw) -#define ListView_SetHotCursor(hwndLV, hcur) \ - (HCURSOR)SNDMSG((hwndLV), LVM_SETHOTCURSOR, 0, (LPARAM)hcur) -#define ListView_SetHotItem(hwndLV, i) \ - (int)SNDMSG((hwndLV), LVM_SETHOTITEM, (WPARAM)i, 0L) -#define ListView_SetIconSpacing(hwndLV, cx, cy) \ - (DWORD)SNDMSG((hwndLV), LVM_SETICONSPACING, 0, MAKELONG(cx,cy)) -#define ListView_SetToolTips(hwndLV, hwndNewHwnd) \ - (HWND)SNDMSG((hwndLV), LVM_SETTOOLTIPS, (WPARAM)hwndNewHwnd, 0L) -#define ListView_SubItemHitTest(hwndLV, plvhti) \ - (int)SNDMSG((hwndLV), LVM_SUBITEMHITTEST, 0, (LPARAM)(LPLVHITTESTINFO)(plvhti)) -#define ListView_GetSelectionMark(hwndLV) \ - (int)SNDMSG((hwndLV), LVM_GETSELECTIONMARK, 0, 0) -#define ListView_SetSelectionMark(hwndLV, iItem) \ - (int)SNDMSG((hwndLV), LVM_SETSELECTIONMARK, 0, (LPARAM)(iItem)) -#define ListView_GetViewRect(hwndLV, prc) \ - (BOOL)SNDMSG((hwndLV),LVM_GETVIEWRECT,0,(LPARAM)(LPRECT)(prc)) -#define ListView_GetHeader(hwndLV) \ - (HWND)SNDMSG((hwndLV),LVM_GETHEADER,0,0L) -#define ListView_SetSelectedColumn(hwnd, iCol) \ - SNDMSG((hwnd), LVM_SETSELECTEDCOLUMN, (WPARAM)iCol, 0) -#define ListView_SetTileWidth(hwnd, cpWidth) \ - SNDMSG((hwnd), LVM_SETTILEWIDTH, (WPARAM)cpWidth, 0) -#define ListView_SetView(hwnd, iView) \ - (DWORD)SNDMSG((hwnd), LVM_SETVIEW, (WPARAM)(DWORD)iView, 0) -#define ListView_GetView(hwnd) \ - (DWORD)SNDMSG((hwnd), LVM_GETVIEW, 0, 0) -#define ListView_InsertGroup(hwnd, index, pgrp) \ - SNDMSG((hwnd), LVM_INSERTGROUP, (WPARAM)index, (LPARAM)pgrp) -#define ListView_SetGroupHeaderImageList(hwnd, himl) \ - SNDMSG((hwnd), LVM_SETIMAGELIST, (WPARAM)LVSIL_GROUPHEADER, (LPARAM)himl) -#define ListView_GetGroupHeaderImageList(hwnd) \ - SNDMSG((hwnd), LVM_GETIMAGELIST, (WPARAM)LVSIL_GROUPHEADER, 0) -#define ListView_SetGroupInfo(hwnd, iGroupId, pgrp) \ - SNDMSG((hwnd), LVM_SETGROUPINFO, (WPARAM)iGroupId, (LPARAM)pgrp) -#define ListView_GetGroupInfo(hwnd, iGroupId, pgrp) \ - SNDMSG((hwnd), LVM_GETGROUPINFO, (WPARAM)iGroupId, (LPARAM)pgrp) -#define ListView_RemoveGroup(hwnd, iGroupId) \ - SNDMSG((hwnd), LVM_REMOVEGROUP, (WPARAM)iGroupId, 0) -#define ListView_MoveGroup(hwnd, iGroupId, toIndex) \ - SNDMSG((hwnd), LVM_MOVEGROUP, (WPARAM)iGroupId, (LPARAM)toIndex) -#define ListView_MoveItemToGroup(hwnd, idItemFrom, idGroupTo) \ - SNDMSG((hwnd), LVM_MOVEITEMTOGROUP, (WPARAM)idItemFrom, (LPARAM)idGroupTo) -#define ListView_SetGroupMetrics(hwnd, pGroupMetrics) \ - SNDMSG((hwnd), LVM_SETGROUPMETRICS, 0, (LPARAM)pGroupMetrics) -#define ListView_GetGroupMetrics(hwnd, pGroupMetrics) \ - SNDMSG((hwnd), LVM_GETGROUPMETRICS, 0, (LPARAM)pGroupMetrics) -#define ListView_EnableGroupView(hwnd, fEnable) \ - SNDMSG((hwnd), LVM_ENABLEGROUPVIEW, (WPARAM)fEnable, 0) -#define ListView_SortGroups(hwnd, _pfnGroupCompate, _plv) \ - SNDMSG((hwnd), LVM_SORTGROUPS, (WPARAM)_pfnGroupCompate, (LPARAM)_plv) -#define ListView_InsertGroupSorted(hwnd, structInsert) \ - SNDMSG((hwnd), LVM_INSERTGROUPSORTED, (WPARAM)structInsert, 0) -#define ListView_RemoveAllGroups(hwnd) \ - SNDMSG((hwnd), LVM_REMOVEALLGROUPS, 0, 0) -#define ListView_HasGroup(hwnd, dwGroupId) \ - SNDMSG((hwnd), LVM_HASGROUP, dwGroupId, 0) -#define ListView_SetTileViewInfo(hwnd, ptvi) \ - SNDMSG((hwnd), LVM_SETTILEVIEWINFO, 0, (LPARAM)ptvi) -#define ListView_GetTileViewInfo(hwnd, ptvi) \ - SNDMSG((hwnd), LVM_GETTILEVIEWINFO, 0, (LPARAM)ptvi) -#define ListView_SetTileInfo(hwnd, pti) \ - SNDMSG((hwnd), LVM_SETTILEINFO, 0, (LPARAM)pti) -#define ListView_GetTileInfo(hwnd, pti) \ - SNDMSG((hwnd), LVM_GETTILEINFO, 0, (LPARAM)pti) -#define ListView_SetInsertMark(hwnd, lvim) \ - (BOOL)SNDMSG((hwnd), LVM_SETINSERTMARK, (WPARAM) 0, (LPARAM) (lvim)) -#define ListView_GetInsertMark(hwnd, lvim) \ - (BOOL)SNDMSG((hwnd), LVM_GETINSERTMARK, (WPARAM) 0, (LPARAM) (lvim)) -#define ListView_InsertMarkHitTest(hwnd, point, lvim) \ - (int)SNDMSG((hwnd), LVM_INSERTMARKHITTEST, (WPARAM)(LPPOINT)(point), (LPARAM)(LPLVINSERTMARK)(lvim)) -#define ListView_GetInsertMarkRect(hwnd, rc) \ - (int)SNDMSG((hwnd), LVM_GETINSERTMARKRECT, (WPARAM)0, (LPARAM)(LPRECT)(rc)) -#define ListView_SetInsertMarkColor(hwnd, color) \ - (COLORREF)SNDMSG((hwnd), LVM_SETINSERTMARKCOLOR, (WPARAM)0, (LPARAM)(COLORREF)(color)) -#define ListView_GetInsertMarkColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), LVM_GETINSERTMARKCOLOR, (WPARAM)0, (LPARAM)0) -#define ListView_SetInfoTip(hwndLV, plvInfoTip)\ - (BOOL)SNDMSG((hwndLV), LVM_SETINFOTIP, (WPARAM)0, (LPARAM)plvInfoTip) -#define ListView_GetSelectedColumn(hwnd) \ - (UINT)SNDMSG((hwnd), LVM_GETSELECTEDCOLUMN, 0, 0) -#define ListView_IsGroupViewEnabled(hwnd) \ - (BOOL)SNDMSG((hwnd), LVM_ISGROUPVIEWENABLED, 0, 0) -#define ListView_GetOutlineColor(hwnd) \ - (COLORREF)SNDMSG((hwnd), LVM_GETOUTLINECOLOR, 0, 0) -#define ListView_SetOutlineColor(hwnd, color) \ - (COLORREF)SNDMSG((hwnd), LVM_SETOUTLINECOLOR, (WPARAM)0, (LPARAM)(COLORREF)(color)) -#define ListView_CancelEditLabel(hwnd) \ - (VOID)SNDMSG((hwnd), LVM_CANCELEDITLABEL, (WPARAM)0, (LPARAM)0) -#define ListView_MapIndexToID(hwnd, index) \ - (UINT)SNDMSG((hwnd), LVM_MAPINDEXTOID, (WPARAM)index, (LPARAM)0) -#define ListView_MapIDToIndex(hwnd, id) \ - (UINT)SNDMSG((hwnd), LVM_MAPIDTOINDEX, (WPARAM)id, (LPARAM)0) -#define ListView_SetUnicodeFormat(hwnd, fUnicode) \ - (BOOL)SNDMSG((hwnd), LVM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0) -#define ListView_GetUnicodeFormat(hwnd) \ - (BOOL)SNDMSG((hwnd), LVM_GETUNICODEFORMAT, 0, 0) - -/* Tab Control */ - -#define WC_TABCONTROLA "SysTabControl32" -#if defined(__GNUC__) -# define WC_TABCONTROLW (const WCHAR []){ 'S','y','s', \ - 'T','a','b','C','o','n','t','r','o','l','3','2',0 } -#elif defined(_MSC_VER) -# define WC_TABCONTROLW L"SysTabControl32" +#ifdef UNICODE +#define LVN_ODFINDITEM LVN_ODFINDITEMW #else -static const WCHAR WC_TABCONTROLW[] = { 'S','y','s', - 'T','a','b','C','o','n','t','r','o','l','3','2',0 }; +#define LVN_ODFINDITEM LVN_ODFINDITEMA #endif -#define WC_TABCONTROL WINELIB_NAME_AW(WC_TABCONTROL) -/* tab control styles */ -#define TCS_SCROLLOPPOSITE 0x0001 /* assumes multiline tab */ -#define TCS_BOTTOM 0x0002 -#define TCS_RIGHT 0x0002 -#define TCS_MULTISELECT 0x0004 /* allow multi-select in button mode */ -#define TCS_FLATBUTTONS 0x0008 -#define TCS_FORCEICONLEFT 0x0010 -#define TCS_FORCELABELLEFT 0x0020 -#define TCS_HOTTRACK 0x0040 -#define TCS_VERTICAL 0x0080 -#define TCS_TABS 0x0000 -#define TCS_BUTTONS 0x0100 -#define TCS_SINGLELINE 0x0000 -#define TCS_MULTILINE 0x0200 -#define TCS_RIGHTJUSTIFY 0x0000 -#define TCS_FIXEDWIDTH 0x0400 -#define TCS_RAGGEDRIGHT 0x0800 -#define TCS_FOCUSONBUTTONDOWN 0x1000 -#define TCS_OWNERDRAWFIXED 0x2000 -#define TCS_TOOLTIPS 0x4000 -#define TCS_FOCUSNEVER 0x8000 -#define TCS_EX_FLATSEPARATORS 0x00000001 /* to be used with */ -#define TCS_EX_REGISTERDROP 0x00000002 /* TCM_SETEXTENDEDSTYLE */ +#define LVN_HOTTRACK (LVN_FIRST-21) +#define LVN_GETDISPINFOA (LVN_FIRST-50) +#define LVN_GETDISPINFOW (LVN_FIRST-77) +#define LVN_SETDISPINFOA (LVN_FIRST-51) +#define LVN_SETDISPINFOW (LVN_FIRST-78) +#ifdef UNICODE +#define LVN_BEGINLABELEDIT LVN_BEGINLABELEDITW +#define LVN_ENDLABELEDIT LVN_ENDLABELEDITW +#define LVN_GETDISPINFO LVN_GETDISPINFOW +#define LVN_SETDISPINFO LVN_SETDISPINFOW +#else +#define LVN_BEGINLABELEDIT LVN_BEGINLABELEDITA +#define LVN_ENDLABELEDIT LVN_ENDLABELEDITA +#define LVN_GETDISPINFO LVN_GETDISPINFOA +#define LVN_SETDISPINFO LVN_SETDISPINFOA +#endif -#define TCM_FIRST 0x1300 +#define LVIF_DI_SETITEM 0x1000 -#define TCM_GETIMAGELIST (TCM_FIRST + 2) -#define TCM_SETIMAGELIST (TCM_FIRST + 3) -#define TCM_GETITEMCOUNT (TCM_FIRST + 4) -#define TCM_GETITEM WINELIB_NAME_AW(TCM_GETITEM) -#define TCM_GETITEMA (TCM_FIRST + 5) -#define TCM_GETITEMW (TCM_FIRST + 60) -#define TCM_SETITEMA (TCM_FIRST + 6) -#define TCM_SETITEMW (TCM_FIRST + 61) -#define TCM_SETITEM WINELIB_NAME_AW(TCM_SETITEM) -#define TCM_INSERTITEMA (TCM_FIRST + 7) -#define TCM_INSERTITEMW (TCM_FIRST + 62) -#define TCM_INSERTITEM WINELIB_NAME_AW(TCM_INSERTITEM) -#define TCM_DELETEITEM (TCM_FIRST + 8) -#define TCM_DELETEALLITEMS (TCM_FIRST + 9) -#define TCM_GETITEMRECT (TCM_FIRST + 10) -#define TCM_GETCURSEL (TCM_FIRST + 11) -#define TCM_SETCURSEL (TCM_FIRST + 12) -#define TCM_HITTEST (TCM_FIRST + 13) -#define TCM_SETITEMEXTRA (TCM_FIRST + 14) -#define TCM_ADJUSTRECT (TCM_FIRST + 40) -#define TCM_SETITEMSIZE (TCM_FIRST + 41) -#define TCM_REMOVEIMAGE (TCM_FIRST + 42) -#define TCM_SETPADDING (TCM_FIRST + 43) -#define TCM_GETROWCOUNT (TCM_FIRST + 44) -#define TCM_GETTOOLTIPS (TCM_FIRST + 45) -#define TCM_SETTOOLTIPS (TCM_FIRST + 46) -#define TCM_GETCURFOCUS (TCM_FIRST + 47) -#define TCM_SETCURFOCUS (TCM_FIRST + 48) -#define TCM_SETMINTABWIDTH (TCM_FIRST + 49) -#define TCM_DESELECTALL (TCM_FIRST + 50) -#define TCM_HIGHLIGHTITEM (TCM_FIRST + 51) -#define TCM_SETEXTENDEDSTYLE (TCM_FIRST + 52) -#define TCM_GETEXTENDEDSTYLE (TCM_FIRST + 53) -#define TCM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define TCM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define LV_DISPINFOA NMLVDISPINFOA +#define LV_DISPINFOW NMLVDISPINFOW +#define LV_DISPINFO NMLVDISPINFO + typedef struct tagLVDISPINFO { + NMHDR hdr; + LVITEMA item; + } NMLVDISPINFOA,*LPNMLVDISPINFOA; -#define TCIF_TEXT 0x0001 -#define TCIF_IMAGE 0x0002 -#define TCIF_RTLREADING 0x0004 -#define TCIF_PARAM 0x0008 -#define TCIF_STATE 0x0010 + typedef struct tagLVDISPINFOW { + NMHDR hdr; + LVITEMW item; + } NMLVDISPINFOW,*LPNMLVDISPINFOW; -#define TCIS_BUTTONPRESSED 0x0001 -#define TCIS_HIGHLIGHTED 0x0002 +#ifdef UNICODE +#define NMLVDISPINFO NMLVDISPINFOW +#else +#define NMLVDISPINFO NMLVDISPINFOA +#endif -/* TabCtrl Macros */ -#define TabCtrl_GetImageList(hwnd) \ - (HIMAGELIST)SNDMSG((hwnd), TCM_GETIMAGELIST, 0, 0L) -#define TabCtrl_SetImageList(hwnd, himl) \ - (HIMAGELIST)SNDMSG((hwnd), TCM_SETIMAGELIST, 0, (LPARAM)(UINT)(HIMAGELIST)(himl)) -#define TabCtrl_GetItemCount(hwnd) \ - (int)SNDMSG((hwnd), TCM_GETITEMCOUNT, 0, 0L) -#define TabCtrl_GetItemA(hwnd, iItem, pitem) \ - (BOOL)SNDMSGA((hwnd), TCM_GETITEMA, (WPARAM)(int)iItem, (LPARAM)(TCITEMA *)(pitem)) -#define TabCtrl_GetItemW(hwnd, iItem, pitem) \ - (BOOL)SNDMSGW((hwnd), TCM_GETITEMW, (WPARAM)(int)iItem, (LPARAM)(TCITEMW *)(pitem)) -#define TabCtrl_GetItem WINELIB_NAME_AW(TabCtrl_GetItem) -#define TabCtrl_SetItemA(hwnd, iItem, pitem) \ - (BOOL)SNDMSGA((hwnd), TCM_SETITEMA, (WPARAM)(int)iItem, (LPARAM)(TCITEMA *)(pitem)) -#define TabCtrl_SetItemW(hwnd, iItem, pitem) \ - (BOOL)SNDMSGW((hwnd), TCM_SETITEMW, (WPARAM)(int)iItem, (LPARAM)(TCITEMW *)(pitem)) -#define TabCtrl_SetItem WINELIB_NAME_AW(TabCtrl_SetItem) -#define TabCtrl_InsertItemA(hwnd, iItem, pitem) \ - (int)SNDMSGA((hwnd), TCM_INSERTITEMA, (WPARAM)(int)iItem, (LPARAM)(const TCITEMA *)(pitem)) -#define TabCtrl_InsertItemW(hwnd, iItem, pitem) \ - (int)SNDMSGW((hwnd), TCM_INSERTITEMW, (WPARAM)(int)iItem, (LPARAM)(const TCITEMW *)(pitem)) -#define TabCtrl_InsertItem WINELIB_NAME_AW(TabCtrl_InsertItem) -#define TabCtrl_DeleteItem(hwnd, i) \ - (BOOL)SNDMSG((hwnd), TCM_DELETEITEM, (WPARAM)(int)(i), 0L) -#define TabCtrl_DeleteAllItems(hwnd) \ - (BOOL)SNDMSG((hwnd), TCM_DELETEALLITEMS, 0, 0L) -#define TabCtrl_GetItemRect(hwnd, i, prc) \ - (BOOL)SNDMSG((hwnd), TCM_GETITEMRECT, (WPARAM)(int)(i), (LPARAM)(RECT *)(prc)) -#define TabCtrl_GetCurSel(hwnd) \ - (int)SNDMSG((hwnd), TCM_GETCURSEL, 0, 0) -#define TabCtrl_SetCurSel(hwnd, i) \ - (int)SNDMSG((hwnd), TCM_SETCURSEL, (WPARAM)i, 0) -#define TabCtrl_HitTest(hwndTC, pinfo) \ - (int)SNDMSG((hwndTC), TCM_HITTEST, 0, (LPARAM)(TC_HITTESTINFO *)(pinfo)) -#define TabCtrl_SetItemExtra(hwndTC, cb) \ - (BOOL)SNDMSG((hwndTC), TCM_SETITEMEXTRA, (WPARAM)(cb), 0L) -#define TabCtrl_AdjustRect(hwnd, bLarger, prc) \ - (int)SNDMSG(hwnd, TCM_ADJUSTRECT, (WPARAM)(BOOL)bLarger, (LPARAM)(RECT *)prc) -#define TabCtrl_SetItemSize(hwnd, x, y) \ - (DWORD)SNDMSG((hwnd), TCM_SETITEMSIZE, 0, MAKELPARAM(x,y)) -#define TabCtrl_RemoveImage(hwnd, i) \ - (void)SNDMSG((hwnd), TCM_REMOVEIMAGE, i, 0L) -#define TabCtrl_SetPadding(hwnd, cx, cy) \ - (void)SNDMSG((hwnd), TCM_SETPADDING, 0, MAKELPARAM(cx, cy)) -#define TabCtrl_GetRowCount(hwnd) \ - (int)SNDMSG((hwnd), TCM_GETROWCOUNT, 0, 0L) -#define TabCtrl_GetToolTips(hwnd) \ - (HWND)SNDMSG((hwnd), TCM_GETTOOLTIPS, 0, 0L) -#define TabCtrl_SetToolTips(hwnd, hwndTT) \ - (void)SNDMSG((hwnd), TCM_SETTOOLTIPS, (WPARAM)hwndTT, 0L) -#define TabCtrl_GetCurFocus(hwnd) \ - (int)SNDMSG((hwnd), TCM_GETCURFOCUS, 0, 0) -#define TabCtrl_SetCurFocus(hwnd, i) \ - SNDMSG((hwnd),TCM_SETCURFOCUS, i, 0) -#define TabCtrl_SetMinTabWidth(hwnd, x) \ - (int)SNDMSG((hwnd), TCM_SETMINTABWIDTH, 0, x) -#define TabCtrl_DeselectAll(hwnd, fExcludeFocus)\ - (void)SNDMSG((hwnd), TCM_DESELECTALL, fExcludeFocus, 0) -#define TabCtrl_GetUnicodeFormat(hwnd) \ - (BOOL)SNDMSG((hwnd), TCM_GETUNICODEFORMAT, 0, 0) -#define TabCtrl_SetUnicodeFormat(hwnd, fUnicode) \ - (BOOL)SNDMSG((hwnd), TCM_SETUNICODEFORMAT, (WPARAM)fUnicode, 0) -#define TabCtrl_GetExtendedStyle(hwnd) \ - (BOOL)SNDMSG((hwnd), TCM_GETEXTENDEDSTYLE, 0, 0) -#define TabCtrl_SetExtendedStyle(hwnd, dwExStyle) \ - (BOOL)SNDMSG((hwnd), TCM_GETEXTENDEDSTYLE, 0, (LPARAM)dwExStyle) -#define TabCtrl_HighlightItem(hwnd, i, fHighlight) \ - (BOOL)SNDMSG((hwnd), TCM_HIGHLIGHTITEM, (WPARAM)i, (LPARAM)MAKELONG(fHighlight, 0)) +#define LVN_KEYDOWN (LVN_FIRST-55) -/* constants for TCHITTESTINFO */ - -#define TCHT_NOWHERE 0x01 -#define TCHT_ONITEMICON 0x02 -#define TCHT_ONITEMLABEL 0x04 -#define TCHT_ONITEM (TCHT_ONITEMICON | TCHT_ONITEMLABEL) - -typedef struct tagTCITEMHEADERA -{ - UINT mask; - UINT lpReserved1; - UINT lpReserved2; - LPSTR pszText; - int cchTextMax; - int iImage; -} TCITEMHEADERA, *LPTCITEMHEADERA; - -typedef struct tagTCITEMHEADERW -{ - UINT mask; - UINT lpReserved1; - UINT lpReserved2; - LPWSTR pszText; - int cchTextMax; - int iImage; -} TCITEMHEADERW, *LPTCITEMHEADERW; - -#define TCITEMHEADER WINELIB_NAME_AW(TCITEMHEADER) -#define LPTCITEMHEADER WINELIB_NAME_AW(LPTCITEMHEADER) -#define TC_ITEMHEADER WINELIB_NAME_AW(TCITEMHEADER) -#define LPTC_ITEMHEADER WINELIB_NAME_AW(LPTCITEMHEADER) - -typedef struct tagTCITEMA -{ - UINT mask; - UINT dwState; - UINT dwStateMask; - LPSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; -} TCITEMA, *LPTCITEMA; - -typedef struct tagTCITEMW -{ - UINT mask; - DWORD dwState; - DWORD dwStateMask; - LPWSTR pszText; - INT cchTextMax; - INT iImage; - LPARAM lParam; -} TCITEMW, *LPTCITEMW; - -#define TCITEM WINELIB_NAME_AW(TCITEM) -#define LPTCITEM WINELIB_NAME_AW(LPTCITEM) -#define TC_ITEM WINELIB_NAME_AW(TCITEM) -#define LPTC_ITEM WINELIB_NAME_AW(LPTCITEM) - -#define TCN_FIRST (0U-550U) -#define TCN_LAST (0U-580U) -#define TCN_KEYDOWN (TCN_FIRST - 0) -#define TCN_SELCHANGE (TCN_FIRST - 1) -#define TCN_SELCHANGING (TCN_FIRST - 2) -#define TCN_GETOBJECT (TCN_FIRST - 3) -#define TCN_FOCUSCHANGE (TCN_FIRST - 4) +#define LV_KEYDOWN NMLVKEYDOWN #include -typedef struct tagTCKEYDOWN -{ + + typedef struct tagLVKEYDOWN { NMHDR hdr; WORD wVKey; UINT flags; -} NMTCKEYDOWN; + } NMLVKEYDOWN,*LPNMLVKEYDOWN; + #include -#define TC_KEYDOWN NMTCKEYDOWN +#define LVN_MARQUEEBEGIN (LVN_FIRST-56) -/* ComboBoxEx control */ + typedef struct tagNMLVGETINFOTIPA { + NMHDR hdr; + DWORD dwFlags; + LPSTR pszText; + int cchTextMax; + int iItem; + int iSubItem; + LPARAM lParam; + } NMLVGETINFOTIPA,*LPNMLVGETINFOTIPA; -#define WC_COMBOBOXEXA "ComboBoxEx32" -#if defined(__GNUC__) -# define WC_COMBOBOXEXW (const WCHAR []){ 'C','o','m','b','o', \ - 'B','o','x','E','x','3','2',0 } -#elif defined(_MSC_VER) -# define WC_COMBOBOXEXW L"ComboBoxEx32" + typedef struct tagNMLVGETINFOTIPW { + NMHDR hdr; + DWORD dwFlags; + LPWSTR pszText; + int cchTextMax; + int iItem; + int iSubItem; + LPARAM lParam; + } NMLVGETINFOTIPW,*LPNMLVGETINFOTIPW; + +#define LVGIT_UNFOLDED 0x1 + +#define LVN_GETINFOTIPA (LVN_FIRST-57) +#define LVN_GETINFOTIPW (LVN_FIRST-58) + +#ifdef UNICODE +#define LVN_GETINFOTIP LVN_GETINFOTIPW +#define NMLVGETINFOTIP NMLVGETINFOTIPW +#define LPNMLVGETINFOTIP LPNMLVGETINFOTIPW #else -static const WCHAR WC_COMBOBOXEXW[] = { 'C','o','m','b','o', - 'B','o','x','E','x','3','2',0 }; +#define LVN_GETINFOTIP LVN_GETINFOTIPA +#define NMLVGETINFOTIP NMLVGETINFOTIPA +#define LPNMLVGETINFOTIP LPNMLVGETINFOTIPA #endif -#define WC_COMBOBOXEX WINELIB_NAME_AW(WC_COMBOBOXEX) -#define CBEIF_TEXT 0x00000001 -#define CBEIF_IMAGE 0x00000002 -#define CBEIF_SELECTEDIMAGE 0x00000004 -#define CBEIF_OVERLAY 0x00000008 -#define CBEIF_INDENT 0x00000010 -#define CBEIF_LPARAM 0x00000020 -#define CBEIF_DI_SETITEM 0x10000000 + typedef struct tagNMLVSCROLL { + NMHDR hdr; + int dx; + int dy; + } NMLVSCROLL,*LPNMLVSCROLL; -#define CBEM_INSERTITEMA (WM_USER+1) -#define CBEM_INSERTITEMW (WM_USER+11) -#define CBEM_INSERTITEM WINELIB_NAME_AW(CBEM_INSERTITEM) -#define CBEM_SETIMAGELIST (WM_USER+2) -#define CBEM_GETIMAGELIST (WM_USER+3) -#define CBEM_GETITEMA (WM_USER+4) -#define CBEM_GETITEMW (WM_USER+13) -#define CBEM_GETITEM WINELIB_NAME_AW(CBEM_GETITEM) -#define CBEM_SETITEMA (WM_USER+5) -#define CBEM_SETITEMW (WM_USER+12) -#define CBEM_SETITEM WINELIB_NAME_AW(CBEM_SETITEM) -#define CBEM_DELETEITEM CB_DELETESTRING -#define CBEM_GETCOMBOCONTROL (WM_USER+6) -#define CBEM_GETEDITCONTROL (WM_USER+7) -#define CBEM_SETEXSTYLE (WM_USER+8) -#define CBEM_GETEXSTYLE (WM_USER+9) -#define CBEM_GETEXTENDEDSTYLE (WM_USER+9) -#define CBEM_SETEXTENDEDSTYLE (WM_USER+14) -#define CBEM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT -#define CBEM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define CBEM_HASEDITCHANGED (WM_USER+10) -#define CBEM_SETWINDOWTHEME CCM_SETWINDOWTHEME +#define LVN_BEGINSCROLL (LVN_FIRST-80) +#define LVN_ENDSCROLL (LVN_FIRST-81) +#endif -#define CBEIF_TEXT 0x00000001 -#define CBEIF_IMAGE 0x00000002 -#define CBEIF_SELECTEDIMAGE 0x00000004 -#define CBEIF_OVERLAY 0x00000008 -#define CBEIF_INDENT 0x00000010 -#define CBEIF_LPARAM 0x00000020 -#define CBEIF_DI_SETITEM 0x10000000 +#ifndef NOTREEVIEW -#define CBEN_FIRST (0U-800U) -#define CBEN_LAST (0U-830U) +#define WC_TREEVIEWA "SysTreeView32" +#define WC_TREEVIEWW L"SysTreeView32" +#ifdef UNICODE +#define WC_TREEVIEW WC_TREEVIEWW +#else +#define WC_TREEVIEW WC_TREEVIEWA +#endif -#define CBEN_GETDISPINFOA (CBEN_FIRST - 0) -#define CBEN_GETDISPINFOW (CBEN_FIRST - 7) -#define CBEN_GETDISPINFO WINELIB_NAME_AW(CBEN_GETDISPINFO) -#define CBEN_INSERTITEM (CBEN_FIRST - 1) -#define CBEN_DELETEITEM (CBEN_FIRST - 2) -#define CBEN_BEGINEDIT (CBEN_FIRST - 4) -#define CBEN_ENDEDITA (CBEN_FIRST - 5) -#define CBEN_ENDEDITW (CBEN_FIRST - 6) -#define CBEN_ENDEDIT WINELIB_NAME_AW(CBEN_ENDEDIT) -#define CBEN_DRAGBEGINA (CBEN_FIRST - 8) -#define CBEN_DRAGBEGINW (CBEN_FIRST - 9) -#define CBEN_DRAGBEGIN WINELIB_NAME_AW(CBEN_DRAGBEGIN) +#define TVS_HASBUTTONS 0x1 +#define TVS_HASLINES 0x2 +#define TVS_LINESATROOT 0x4 +#define TVS_EDITLABELS 0x8 +#define TVS_DISABLEDRAGDROP 0x10 +#define TVS_SHOWSELALWAYS 0x20 +#define TVS_RTLREADING 0x40 +#define TVS_NOTOOLTIPS 0x80 +#define TVS_CHECKBOXES 0x100 +#define TVS_TRACKSELECT 0x200 +#define TVS_SINGLEEXPAND 0x400 +#define TVS_INFOTIP 0x800 +#define TVS_FULLROWSELECT 0x1000 +#define TVS_NOSCROLL 0x2000 +#define TVS_NONEVENHEIGHT 0x4000 +#define TVS_NOHSCROLL 0x8000 -#define CBES_EX_NOEDITIMAGE 0x00000001 -#define CBES_EX_NOEDITIMAGEINDENT 0x00000002 -#define CBES_EX_PATHWORDBREAKPROC 0x00000004 -#define CBES_EX_NOSIZELIMIT 0x00000008 -#define CBES_EX_CASESENSITIVE 0x00000010 + typedef struct _TREEITEM *HTREEITEM; +#define TVIF_TEXT 0x1 +#define TVIF_IMAGE 0x2 +#define TVIF_PARAM 0x4 +#define TVIF_STATE 0x8 +#define TVIF_HANDLE 0x10 +#define TVIF_SELECTEDIMAGE 0x20 +#define TVIF_CHILDREN 0x40 +#define TVIF_INTEGRAL 0x80 +#define TVIS_SELECTED 0x2 +#define TVIS_CUT 0x4 +#define TVIS_DROPHILITED 0x8 +#define TVIS_BOLD 0x10 +#define TVIS_EXPANDED 0x20 +#define TVIS_EXPANDEDONCE 0x40 +#define TVIS_EXPANDPARTIAL 0x80 +#define TVIS_OVERLAYMASK 0xf00 +#define TVIS_STATEIMAGEMASK 0xF000 +#define TVIS_USERMASK 0xF000 -typedef struct tagCOMBOBOXEXITEMA -{ +#define I_CHILDRENCALLBACK (-1) + +#define LPTV_ITEMW LPTVITEMW +#define LPTV_ITEMA LPTVITEMA +#define TV_ITEMW TVITEMW +#define TV_ITEMA TVITEMA +#define LPTV_ITEM LPTVITEM +#define TV_ITEM TVITEM + + typedef struct tagTVITEMA { + UINT mask; + HTREEITEM hItem; + UINT state; + UINT stateMask; + LPSTR pszText; + int cchTextMax; + int iImage; + int iSelectedImage; + int cChildren; + LPARAM lParam; + } TVITEMA,*LPTVITEMA; + + typedef struct tagTVITEMW { + UINT mask; + HTREEITEM hItem; + UINT state; + UINT stateMask; + LPWSTR pszText; + int cchTextMax; + int iImage; + int iSelectedImage; + int cChildren; + LPARAM lParam; + } TVITEMW,*LPTVITEMW; + + typedef struct tagTVITEMEXA { + UINT mask; + HTREEITEM hItem; + UINT state; + UINT stateMask; + LPSTR pszText; + int cchTextMax; + int iImage; + int iSelectedImage; + int cChildren; + LPARAM lParam; + int iIntegral; + } TVITEMEXA,*LPTVITEMEXA; + + typedef struct tagTVITEMEXW { + UINT mask; + HTREEITEM hItem; + UINT state; + UINT stateMask; + LPWSTR pszText; + int cchTextMax; + int iImage; + int iSelectedImage; + int cChildren; + LPARAM lParam; + int iIntegral; + } TVITEMEXW,*LPTVITEMEXW; +#ifdef UNICODE + typedef TVITEMEXW TVITEMEX; + typedef LPTVITEMEXW LPTVITEMEX; +#else + typedef TVITEMEXA TVITEMEX; + typedef LPTVITEMEXA LPTVITEMEX; +#endif + +#ifdef UNICODE +#define TVITEM TVITEMW +#define LPTVITEM LPTVITEMW +#else +#define TVITEM TVITEMA +#define LPTVITEM LPTVITEMA +#endif + +#define TVI_ROOT ((HTREEITEM)(ULONG_PTR)-0x10000) +#define TVI_FIRST ((HTREEITEM)(ULONG_PTR)-0xffff) +#define TVI_LAST ((HTREEITEM)(ULONG_PTR)-0xfffe) +#define TVI_SORT ((HTREEITEM)(ULONG_PTR)-0xfffd) + +#define LPTV_INSERTSTRUCTA LPTVINSERTSTRUCTA +#define LPTV_INSERTSTRUCTW LPTVINSERTSTRUCTW +#define TV_INSERTSTRUCTA TVINSERTSTRUCTA +#define TV_INSERTSTRUCTW TVINSERTSTRUCTW +#define TV_INSERTSTRUCT TVINSERTSTRUCT +#define LPTV_INSERTSTRUCT LPTVINSERTSTRUCT + +#define TVINSERTSTRUCTA_V1_SIZE CCSIZEOF_STRUCT(TVINSERTSTRUCTA,item) +#define TVINSERTSTRUCTW_V1_SIZE CCSIZEOF_STRUCT(TVINSERTSTRUCTW,item) + + typedef struct tagTVINSERTSTRUCTA { + HTREEITEM hParent; + HTREEITEM hInsertAfter; + __MINGW_EXTENSION union { + TVITEMEXA itemex; + TV_ITEMA item; + } DUMMYUNIONNAME; + } TVINSERTSTRUCTA,*LPTVINSERTSTRUCTA; + + typedef struct tagTVINSERTSTRUCTW { + HTREEITEM hParent; + HTREEITEM hInsertAfter; + __MINGW_EXTENSION union { + TVITEMEXW itemex; + TV_ITEMW item; + } DUMMYUNIONNAME; + } TVINSERTSTRUCTW,*LPTVINSERTSTRUCTW; + +#ifdef UNICODE +#define TVINSERTSTRUCT TVINSERTSTRUCTW +#define LPTVINSERTSTRUCT LPTVINSERTSTRUCTW +#define TVINSERTSTRUCT_V1_SIZE TVINSERTSTRUCTW_V1_SIZE +#else +#define TVINSERTSTRUCT TVINSERTSTRUCTA +#define LPTVINSERTSTRUCT LPTVINSERTSTRUCTA +#define TVINSERTSTRUCT_V1_SIZE TVINSERTSTRUCTA_V1_SIZE +#endif + +#define TVM_INSERTITEMA (TV_FIRST+0) +#define TVM_INSERTITEMW (TV_FIRST+50) +#ifdef UNICODE +#define TVM_INSERTITEM TVM_INSERTITEMW +#else +#define TVM_INSERTITEM TVM_INSERTITEMA +#endif + +#define TreeView_InsertItem(hwnd,lpis) (HTREEITEM)SNDMSG((hwnd),TVM_INSERTITEM,0,(LPARAM)(LPTV_INSERTSTRUCT)(lpis)) + +#define TVM_DELETEITEM (TV_FIRST+1) +#define TreeView_DeleteItem(hwnd,hitem) (WINBOOL)SNDMSG((hwnd),TVM_DELETEITEM,0,(LPARAM)(HTREEITEM)(hitem)) + +#define TreeView_DeleteAllItems(hwnd) (WINBOOL)SNDMSG((hwnd),TVM_DELETEITEM,0,(LPARAM)TVI_ROOT) + +#define TVM_EXPAND (TV_FIRST+2) +#define TreeView_Expand(hwnd,hitem,code) (WINBOOL)SNDMSG((hwnd),TVM_EXPAND,(WPARAM)(code),(LPARAM)(HTREEITEM)(hitem)) + +#define TVE_COLLAPSE 0x1 +#define TVE_EXPAND 0x2 +#define TVE_TOGGLE 0x3 +#define TVE_EXPANDPARTIAL 0x4000 +#define TVE_COLLAPSERESET 0x8000 + +#define TVM_GETITEMRECT (TV_FIRST+4) +#define TreeView_GetItemRect(hwnd,hitem,prc,code) (*(HTREEITEM *)prc = (hitem),(WINBOOL)SNDMSG((hwnd),TVM_GETITEMRECT,(WPARAM)(code),(LPARAM)(RECT *)(prc))) + +#define TVM_GETCOUNT (TV_FIRST+5) +#define TreeView_GetCount(hwnd) (UINT)SNDMSG((hwnd),TVM_GETCOUNT,0,0) + +#define TVM_GETINDENT (TV_FIRST+6) +#define TreeView_GetIndent(hwnd) (UINT)SNDMSG((hwnd),TVM_GETINDENT,0,0) + +#define TVM_SETINDENT (TV_FIRST+7) +#define TreeView_SetIndent(hwnd,indent) (WINBOOL)SNDMSG((hwnd),TVM_SETINDENT,(WPARAM)(indent),0) + +#define TVM_GETIMAGELIST (TV_FIRST+8) +#define TreeView_GetImageList(hwnd,iImage) (HIMAGELIST)SNDMSG((hwnd),TVM_GETIMAGELIST,iImage,0) + +#define TVSIL_NORMAL 0 +#define TVSIL_STATE 2 + +#define TVM_SETIMAGELIST (TV_FIRST+9) +#define TreeView_SetImageList(hwnd,himl,iImage) (HIMAGELIST)SNDMSG((hwnd),TVM_SETIMAGELIST,iImage,(LPARAM)(HIMAGELIST)(himl)) + +#define TVM_GETNEXTITEM (TV_FIRST+10) +#define TreeView_GetNextItem(hwnd,hitem,code) (HTREEITEM)SNDMSG((hwnd),TVM_GETNEXTITEM,(WPARAM)(code),(LPARAM)(HTREEITEM)(hitem)) + +#define TVGN_ROOT 0x0 +#define TVGN_NEXT 0x1 +#define TVGN_PREVIOUS 0x2 +#define TVGN_PARENT 0x3 +#define TVGN_CHILD 0x4 +#define TVGN_FIRSTVISIBLE 0x5 +#define TVGN_NEXTVISIBLE 0x6 +#define TVGN_PREVIOUSVISIBLE 0x7 +#define TVGN_DROPHILITE 0x8 +#define TVGN_CARET 0x9 +#define TVGN_LASTVISIBLE 0xa + +#define TVSI_NOSINGLEEXPAND 0x8000 + +#define TreeView_GetChild(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_CHILD) +#define TreeView_GetNextSibling(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_NEXT) +#define TreeView_GetPrevSibling(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_PREVIOUS) +#define TreeView_GetParent(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_PARENT) +#define TreeView_GetFirstVisible(hwnd) TreeView_GetNextItem(hwnd,NULL,TVGN_FIRSTVISIBLE) +#define TreeView_GetNextVisible(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_NEXTVISIBLE) +#define TreeView_GetPrevVisible(hwnd,hitem) TreeView_GetNextItem(hwnd,hitem,TVGN_PREVIOUSVISIBLE) +#define TreeView_GetSelection(hwnd) TreeView_GetNextItem(hwnd,NULL,TVGN_CARET) +#define TreeView_GetDropHilight(hwnd) TreeView_GetNextItem(hwnd,NULL,TVGN_DROPHILITE) +#define TreeView_GetRoot(hwnd) TreeView_GetNextItem(hwnd,NULL,TVGN_ROOT) +#define TreeView_GetLastVisible(hwnd) TreeView_GetNextItem(hwnd,NULL,TVGN_LASTVISIBLE) + +#define TVM_SELECTITEM (TV_FIRST+11) +#define TreeView_Select(hwnd,hitem,code) (WINBOOL)SNDMSG((hwnd),TVM_SELECTITEM,(WPARAM)(code),(LPARAM)(HTREEITEM)(hitem)) + +#define TreeView_SelectItem(hwnd,hitem) TreeView_Select(hwnd,hitem,TVGN_CARET) +#define TreeView_SelectDropTarget(hwnd,hitem) TreeView_Select(hwnd,hitem,TVGN_DROPHILITE) +#define TreeView_SelectSetFirstVisible(hwnd,hitem) TreeView_Select(hwnd,hitem,TVGN_FIRSTVISIBLE) + +#define TVM_GETITEMA (TV_FIRST+12) +#define TVM_GETITEMW (TV_FIRST+62) + +#ifdef UNICODE +#define TVM_GETITEM TVM_GETITEMW +#else +#define TVM_GETITEM TVM_GETITEMA +#endif + +#define TreeView_GetItem(hwnd,pitem) (WINBOOL)SNDMSG((hwnd),TVM_GETITEM,0,(LPARAM)(TV_ITEM *)(pitem)) + +#define TVM_SETITEMA (TV_FIRST+13) +#define TVM_SETITEMW (TV_FIRST+63) + +#ifdef UNICODE +#define TVM_SETITEM TVM_SETITEMW +#else +#define TVM_SETITEM TVM_SETITEMA +#endif + +#define TreeView_SetItem(hwnd,pitem) (WINBOOL)SNDMSG((hwnd),TVM_SETITEM,0,(LPARAM)(const TV_ITEM *)(pitem)) + +#define TVM_EDITLABELA (TV_FIRST+14) +#define TVM_EDITLABELW (TV_FIRST+65) +#ifdef UNICODE +#define TVM_EDITLABEL TVM_EDITLABELW +#else +#define TVM_EDITLABEL TVM_EDITLABELA +#endif + +#define TreeView_EditLabel(hwnd,hitem) (HWND)SNDMSG((hwnd),TVM_EDITLABEL,0,(LPARAM)(HTREEITEM)(hitem)) + +#define TVM_GETEDITCONTROL (TV_FIRST+15) +#define TreeView_GetEditControl(hwnd) (HWND)SNDMSG((hwnd),TVM_GETEDITCONTROL,0,0) + +#define TVM_GETVISIBLECOUNT (TV_FIRST+16) +#define TreeView_GetVisibleCount(hwnd) (UINT)SNDMSG((hwnd),TVM_GETVISIBLECOUNT,0,0) + +#define TVM_HITTEST (TV_FIRST+17) +#define TreeView_HitTest(hwnd,lpht) (HTREEITEM)SNDMSG((hwnd),TVM_HITTEST,0,(LPARAM)(LPTV_HITTESTINFO)(lpht)) + +#define LPTV_HITTESTINFO LPTVHITTESTINFO +#define TV_HITTESTINFO TVHITTESTINFO + + typedef struct tagTVHITTESTINFO { + POINT pt; + UINT flags; + HTREEITEM hItem; + } TVHITTESTINFO,*LPTVHITTESTINFO; + +#define TVHT_NOWHERE 0x1 +#define TVHT_ONITEMICON 0x2 +#define TVHT_ONITEMLABEL 0x4 +#define TVHT_ONITEM (TVHT_ONITEMICON | TVHT_ONITEMLABEL | TVHT_ONITEMSTATEICON) +#define TVHT_ONITEMINDENT 0x8 +#define TVHT_ONITEMBUTTON 0x10 +#define TVHT_ONITEMRIGHT 0x20 +#define TVHT_ONITEMSTATEICON 0x40 + +#define TVHT_ABOVE 0x100 +#define TVHT_BELOW 0x200 +#define TVHT_TORIGHT 0x400 +#define TVHT_TOLEFT 0x800 + +#define TVM_CREATEDRAGIMAGE (TV_FIRST+18) +#define TreeView_CreateDragImage(hwnd,hitem) (HIMAGELIST)SNDMSG((hwnd),TVM_CREATEDRAGIMAGE,0,(LPARAM)(HTREEITEM)(hitem)) + +#define TVM_SORTCHILDREN (TV_FIRST+19) +#define TreeView_SortChildren(hwnd,hitem,recurse) (WINBOOL)SNDMSG((hwnd),TVM_SORTCHILDREN,(WPARAM)(recurse),(LPARAM)(HTREEITEM)(hitem)) + +#define TVM_ENSUREVISIBLE (TV_FIRST+20) +#define TreeView_EnsureVisible(hwnd,hitem) (WINBOOL)SNDMSG((hwnd),TVM_ENSUREVISIBLE,0,(LPARAM)(HTREEITEM)(hitem)) + +#define TVM_SORTCHILDRENCB (TV_FIRST+21) +#define TreeView_SortChildrenCB(hwnd,psort,recurse) (WINBOOL)SNDMSG((hwnd),TVM_SORTCHILDRENCB,(WPARAM)(recurse),(LPARAM)(LPTV_SORTCB)(psort)) + +#define TVM_ENDEDITLABELNOW (TV_FIRST+22) +#define TreeView_EndEditLabelNow(hwnd,fCancel) (WINBOOL)SNDMSG((hwnd),TVM_ENDEDITLABELNOW,(WPARAM)(fCancel),0) + +#define TVM_GETISEARCHSTRINGA (TV_FIRST+23) +#define TVM_GETISEARCHSTRINGW (TV_FIRST+64) + +#ifdef UNICODE +#define TVM_GETISEARCHSTRING TVM_GETISEARCHSTRINGW +#else +#define TVM_GETISEARCHSTRING TVM_GETISEARCHSTRINGA +#endif + +#define TVM_SETTOOLTIPS (TV_FIRST+24) +#define TreeView_SetToolTips(hwnd,hwndTT) (HWND)SNDMSG((hwnd),TVM_SETTOOLTIPS,(WPARAM)(hwndTT),0) +#define TVM_GETTOOLTIPS (TV_FIRST+25) +#define TreeView_GetToolTips(hwnd) (HWND)SNDMSG((hwnd),TVM_GETTOOLTIPS,0,0) +#define TreeView_GetISearchString(hwndTV,lpsz) (WINBOOL)SNDMSG((hwndTV),TVM_GETISEARCHSTRING,0,(LPARAM)(LPTSTR)(lpsz)) + +#define TVM_SETINSERTMARK (TV_FIRST+26) +#define TreeView_SetInsertMark(hwnd,hItem,fAfter) (WINBOOL)SNDMSG((hwnd),TVM_SETINSERTMARK,(WPARAM) (fAfter),(LPARAM) (hItem)) +#define TVM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define TreeView_SetUnicodeFormat(hwnd,fUnicode) (WINBOOL)SNDMSG((hwnd),TVM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) +#define TVM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define TreeView_GetUnicodeFormat(hwnd) (WINBOOL)SNDMSG((hwnd),TVM_GETUNICODEFORMAT,0,0) + +#define TVM_SETITEMHEIGHT (TV_FIRST+27) +#define TreeView_SetItemHeight(hwnd,iHeight) (int)SNDMSG((hwnd),TVM_SETITEMHEIGHT,(WPARAM)(iHeight),0) +#define TVM_GETITEMHEIGHT (TV_FIRST+28) +#define TreeView_GetItemHeight(hwnd) (int)SNDMSG((hwnd),TVM_GETITEMHEIGHT,0,0) +#define TVM_SETBKCOLOR (TV_FIRST+29) +#define TreeView_SetBkColor(hwnd,clr) (COLORREF)SNDMSG((hwnd),TVM_SETBKCOLOR,0,(LPARAM)(clr)) +#define TVM_SETTEXTCOLOR (TV_FIRST+30) +#define TreeView_SetTextColor(hwnd,clr) (COLORREF)SNDMSG((hwnd),TVM_SETTEXTCOLOR,0,(LPARAM)(clr)) +#define TVM_GETBKCOLOR (TV_FIRST+31) +#define TreeView_GetBkColor(hwnd) (COLORREF)SNDMSG((hwnd),TVM_GETBKCOLOR,0,0) +#define TVM_GETTEXTCOLOR (TV_FIRST+32) +#define TreeView_GetTextColor(hwnd) (COLORREF)SNDMSG((hwnd),TVM_GETTEXTCOLOR,0,0) +#define TVM_SETSCROLLTIME (TV_FIRST+33) +#define TreeView_SetScrollTime(hwnd,uTime) (UINT)SNDMSG((hwnd),TVM_SETSCROLLTIME,uTime,0) +#define TVM_GETSCROLLTIME (TV_FIRST+34) +#define TreeView_GetScrollTime(hwnd) (UINT)SNDMSG((hwnd),TVM_GETSCROLLTIME,0,0) +#define TVM_SETINSERTMARKCOLOR (TV_FIRST+37) +#define TreeView_SetInsertMarkColor(hwnd,clr) (COLORREF)SNDMSG((hwnd),TVM_SETINSERTMARKCOLOR,0,(LPARAM)(clr)) +#define TVM_GETINSERTMARKCOLOR (TV_FIRST+38) +#define TreeView_GetInsertMarkColor(hwnd) (COLORREF)SNDMSG((hwnd),TVM_GETINSERTMARKCOLOR,0,0) + +#define TreeView_SetItemState(hwndTV,hti,data,_mask) { TVITEM _ms_TVi; _ms_TVi.mask = TVIF_STATE; _ms_TVi.hItem = hti; _ms_TVi.stateMask = _mask; _ms_TVi.state = data; SNDMSG((hwndTV),TVM_SETITEM,0,(LPARAM)(TV_ITEM *)&_ms_TVi);} +#define TreeView_SetCheckState(hwndTV,hti,fCheck) TreeView_SetItemState(hwndTV,hti,INDEXTOSTATEIMAGEMASK((fCheck)?2:1),TVIS_STATEIMAGEMASK) +#define TVM_GETITEMSTATE (TV_FIRST+39) +#define TreeView_GetItemState(hwndTV,hti,mask) (UINT)SNDMSG((hwndTV),TVM_GETITEMSTATE,(WPARAM)(hti),(LPARAM)(mask)) +#define TreeView_GetCheckState(hwndTV,hti) ((((UINT)(SNDMSG((hwndTV),TVM_GETITEMSTATE,(WPARAM)(hti),TVIS_STATEIMAGEMASK))) >> 12) -1) +#define TVM_SETLINECOLOR (TV_FIRST+40) +#define TreeView_SetLineColor(hwnd,clr) (COLORREF)SNDMSG((hwnd),TVM_SETLINECOLOR,0,(LPARAM)(clr)) +#define TVM_GETLINECOLOR (TV_FIRST+41) +#define TreeView_GetLineColor(hwnd) (COLORREF)SNDMSG((hwnd),TVM_GETLINECOLOR,0,0) + +#define TVM_MAPACCIDTOHTREEITEM (TV_FIRST+42) +#define TreeView_MapAccIDToHTREEITEM(hwnd,id) (HTREEITEM)SNDMSG((hwnd),TVM_MAPACCIDTOHTREEITEM,id,0) + +#define TVM_MAPHTREEITEMTOACCID (TV_FIRST+43) +#define TreeView_MapHTREEITEMToAccID(hwnd,htreeitem) (UINT)SNDMSG((hwnd),TVM_MAPHTREEITEMTOACCID,(WPARAM)htreeitem,0) + + typedef int (CALLBACK *PFNTVCOMPARE)(LPARAM lParam1,LPARAM lParam2,LPARAM lParamSort); + +#define LPTV_SORTCB LPTVSORTCB +#define TV_SORTCB TVSORTCB + + typedef struct tagTVSORTCB { + HTREEITEM hParent; + PFNTVCOMPARE lpfnCompare; + LPARAM lParam; + } TVSORTCB,*LPTVSORTCB; + +#define LPNM_TREEVIEWA LPNMTREEVIEWA +#define LPNM_TREEVIEWW LPNMTREEVIEWW +#define NM_TREEVIEWW NMTREEVIEWW +#define NM_TREEVIEWA NMTREEVIEWA +#define LPNM_TREEVIEW LPNMTREEVIEW +#define NM_TREEVIEW NMTREEVIEW + + typedef struct tagNMTREEVIEWA { + NMHDR hdr; + UINT action; + TVITEMA itemOld; + TVITEMA itemNew; + POINT ptDrag; + } NMTREEVIEWA,*LPNMTREEVIEWA; + + typedef struct tagNMTREEVIEWW { + NMHDR hdr; + UINT action; + TVITEMW itemOld; + TVITEMW itemNew; + POINT ptDrag; + } NMTREEVIEWW,*LPNMTREEVIEWW; + +#ifdef UNICODE +#define NMTREEVIEW NMTREEVIEWW +#define LPNMTREEVIEW LPNMTREEVIEWW +#else +#define NMTREEVIEW NMTREEVIEWA +#define LPNMTREEVIEW LPNMTREEVIEWA +#endif + +#define TVN_SELCHANGINGA (TVN_FIRST-1) +#define TVN_SELCHANGINGW (TVN_FIRST-50) +#define TVN_SELCHANGEDA (TVN_FIRST-2) +#define TVN_SELCHANGEDW (TVN_FIRST-51) + +#define TVC_UNKNOWN 0x0 +#define TVC_BYMOUSE 0x1 +#define TVC_BYKEYBOARD 0x2 + +#define TVN_GETDISPINFOA (TVN_FIRST-3) +#define TVN_GETDISPINFOW (TVN_FIRST-52) +#define TVN_SETDISPINFOA (TVN_FIRST-4) +#define TVN_SETDISPINFOW (TVN_FIRST-53) + +#define TVIF_DI_SETITEM 0x1000 + +#define TV_DISPINFOA NMTVDISPINFOA +#define TV_DISPINFOW NMTVDISPINFOW +#define TV_DISPINFO NMTVDISPINFO + + typedef struct tagTVDISPINFOA { + NMHDR hdr; + TVITEMA item; + } NMTVDISPINFOA,*LPNMTVDISPINFOA; + + typedef struct tagTVDISPINFOW { + NMHDR hdr; + TVITEMW item; + } NMTVDISPINFOW,*LPNMTVDISPINFOW; + +#ifdef UNICODE +#define NMTVDISPINFO NMTVDISPINFOW +#define LPNMTVDISPINFO LPNMTVDISPINFOW +#else +#define NMTVDISPINFO NMTVDISPINFOA +#define LPNMTVDISPINFO LPNMTVDISPINFOA +#endif + +#if (_WIN32_IE >= 0x0600) + +typedef struct tagTVDISPINFOEXA { + NMHDR hdr; + TVITEMEXA item; +} NMTVDISPINFOEXA, *LPNMTVDISPINFOEXA; + +typedef struct tagTVDISPINFOEXW { + NMHDR hdr; + TVITEMEXW item; +} NMTVDISPINFOEXW, *LPNMTVDISPINFOEXW; + +#ifdef UNICODE +#define NMTVDISPINFOEX NMTVDISPINFOEXW +#define LPNMTVDISPINFOEX LPNMTVDISPINFOEXW +#else +#define NMTVDISPINFOEX NMTVDISPINFOEXA +#define LPNMTVDISPINFOEX LPNMTVDISPINFOEXA +#endif /* UNICODE */ + +#define TV_DISPINFOEXA NMTVDISPINFOEXA +#define TV_DISPINFOEXW NMTVDISPINFOEXW +#define TV_DISPINFOEX NMTVDISPINFOEX + +#endif /* (_WIN32_IE >= 0x0600) */ + +#define TVN_ITEMEXPANDINGA (TVN_FIRST-5) +#define TVN_ITEMEXPANDINGW (TVN_FIRST-54) +#define TVN_ITEMEXPANDEDA (TVN_FIRST-6) +#define TVN_ITEMEXPANDEDW (TVN_FIRST-55) +#define TVN_BEGINDRAGA (TVN_FIRST-7) +#define TVN_BEGINDRAGW (TVN_FIRST-56) +#define TVN_BEGINRDRAGA (TVN_FIRST-8) +#define TVN_BEGINRDRAGW (TVN_FIRST-57) +#define TVN_DELETEITEMA (TVN_FIRST-9) +#define TVN_DELETEITEMW (TVN_FIRST-58) +#define TVN_BEGINLABELEDITA (TVN_FIRST-10) +#define TVN_BEGINLABELEDITW (TVN_FIRST-59) +#define TVN_ENDLABELEDITA (TVN_FIRST-11) +#define TVN_ENDLABELEDITW (TVN_FIRST-60) +#define TVN_KEYDOWN (TVN_FIRST-12) +#define TVN_GETINFOTIPA (TVN_FIRST-13) +#define TVN_GETINFOTIPW (TVN_FIRST-14) +#define TVN_SINGLEEXPAND (TVN_FIRST-15) + +#define TVNRET_DEFAULT 0 +#define TVNRET_SKIPOLD 1 +#define TVNRET_SKIPNEW 2 + +#define TV_KEYDOWN NMTVKEYDOWN + +#include + + typedef struct tagTVKEYDOWN { + NMHDR hdr; + WORD wVKey; + UINT flags; + } NMTVKEYDOWN,*LPNMTVKEYDOWN; + +#include + +#ifdef UNICODE +#define TVN_SELCHANGING TVN_SELCHANGINGW +#define TVN_SELCHANGED TVN_SELCHANGEDW +#define TVN_GETDISPINFO TVN_GETDISPINFOW +#define TVN_SETDISPINFO TVN_SETDISPINFOW +#define TVN_ITEMEXPANDING TVN_ITEMEXPANDINGW +#define TVN_ITEMEXPANDED TVN_ITEMEXPANDEDW +#define TVN_BEGINDRAG TVN_BEGINDRAGW +#define TVN_BEGINRDRAG TVN_BEGINRDRAGW +#define TVN_DELETEITEM TVN_DELETEITEMW +#define TVN_BEGINLABELEDIT TVN_BEGINLABELEDITW +#define TVN_ENDLABELEDIT TVN_ENDLABELEDITW +#else +#define TVN_SELCHANGING TVN_SELCHANGINGA +#define TVN_SELCHANGED TVN_SELCHANGEDA +#define TVN_GETDISPINFO TVN_GETDISPINFOA +#define TVN_SETDISPINFO TVN_SETDISPINFOA +#define TVN_ITEMEXPANDING TVN_ITEMEXPANDINGA +#define TVN_ITEMEXPANDED TVN_ITEMEXPANDEDA +#define TVN_BEGINDRAG TVN_BEGINDRAGA +#define TVN_BEGINRDRAG TVN_BEGINRDRAGA +#define TVN_DELETEITEM TVN_DELETEITEMA +#define TVN_BEGINLABELEDIT TVN_BEGINLABELEDITA +#define TVN_ENDLABELEDIT TVN_ENDLABELEDITA +#endif + +#define NMTVCUSTOMDRAW_V3_SIZE CCSIZEOF_STRUCT(NMTVCUSTOMDRAW,clrTextBk) + + typedef struct tagNMTVCUSTOMDRAW { + NMCUSTOMDRAW nmcd; + COLORREF clrText; + COLORREF clrTextBk; + int iLevel; + } NMTVCUSTOMDRAW,*LPNMTVCUSTOMDRAW; + + typedef struct tagNMTVGETINFOTIPA { + NMHDR hdr; + LPSTR pszText; + int cchTextMax; + HTREEITEM hItem; + LPARAM lParam; + } NMTVGETINFOTIPA,*LPNMTVGETINFOTIPA; + + typedef struct tagNMTVGETINFOTIPW { + NMHDR hdr; + LPWSTR pszText; + int cchTextMax; + HTREEITEM hItem; + LPARAM lParam; + } NMTVGETINFOTIPW,*LPNMTVGETINFOTIPW; + +#ifdef UNICODE +#define TVN_GETINFOTIP TVN_GETINFOTIPW +#define NMTVGETINFOTIP NMTVGETINFOTIPW +#define LPNMTVGETINFOTIP LPNMTVGETINFOTIPW +#else +#define TVN_GETINFOTIP TVN_GETINFOTIPA +#define NMTVGETINFOTIP NMTVGETINFOTIPA +#define LPNMTVGETINFOTIP LPNMTVGETINFOTIPA +#endif + +#define TVCDRF_NOIMAGES 0x10000 +#endif + +#ifndef NOUSEREXCONTROLS + +#define WC_COMBOBOXEXW L"ComboBoxEx32" +#define WC_COMBOBOXEXA "ComboBoxEx32" + +#ifdef UNICODE +#define WC_COMBOBOXEX WC_COMBOBOXEXW +#else +#define WC_COMBOBOXEX WC_COMBOBOXEXA +#endif + +#define CBEIF_TEXT 0x1 +#define CBEIF_IMAGE 0x2 +#define CBEIF_SELECTEDIMAGE 0x4 +#define CBEIF_OVERLAY 0x8 +#define CBEIF_INDENT 0x10 +#define CBEIF_LPARAM 0x20 + +#define CBEIF_DI_SETITEM 0x10000000 + + typedef struct tagCOMBOBOXEXITEMA { UINT mask; INT_PTR iItem; LPSTR pszText; @@ -4349,11 +3887,11 @@ typedef struct tagCOMBOBOXEXITEMA int iOverlay; int iIndent; LPARAM lParam; -} COMBOBOXEXITEMA, *PCOMBOBOXEXITEMA; -typedef COMBOBOXEXITEMA const *PCCOMBOEXITEMA; /* Yes, there's a BOX missing */ + } COMBOBOXEXITEMA,*PCOMBOBOXEXITEMA; + typedef COMBOBOXEXITEMA CONST *PCCOMBOEXITEMA; -typedef struct tagCOMBOBOXEXITEMW -{ + typedef struct tagCOMBOBOXEXITEMW + { UINT mask; INT_PTR iItem; LPWSTR pszText; @@ -4363,809 +3901,1212 @@ typedef struct tagCOMBOBOXEXITEMW int iOverlay; int iIndent; LPARAM lParam; -} COMBOBOXEXITEMW, *PCOMBOBOXEXITEMW; -typedef COMBOBOXEXITEMW const *PCCOMBOEXITEMW; /* Yes, there's a BOX missing */ + } COMBOBOXEXITEMW,*PCOMBOBOXEXITEMW; + typedef COMBOBOXEXITEMW CONST *PCCOMBOEXITEMW; -#define COMBOBOXEXITEM WINELIB_NAME_AW(COMBOBOXEXITEM) -#define PCOMBOBOXEXITEM WINELIB_NAME_AW(PCOMBOBOXEXITEM) -#define PCCOMBOBOXEXITEM WINELIB_NAME_AW(PCCOMBOEXITEM) /* Yes, there's a BOX missing */ +#ifdef UNICODE +#define COMBOBOXEXITEM COMBOBOXEXITEMW +#define PCOMBOBOXEXITEM PCOMBOBOXEXITEMW +#define PCCOMBOBOXEXITEM PCCOMBOBOXEXITEMW +#else +#define COMBOBOXEXITEM COMBOBOXEXITEMA +#define PCOMBOBOXEXITEM PCOMBOBOXEXITEMA +#define PCCOMBOBOXEXITEM PCCOMBOBOXEXITEMA +#endif -#define CBENF_KILLFOCUS 1 -#define CBENF_RETURN 2 -#define CBENF_ESCAPE 3 -#define CBENF_DROPDOWN 4 +#define CBEM_INSERTITEMA (WM_USER+1) +#define CBEM_SETIMAGELIST (WM_USER+2) +#define CBEM_GETIMAGELIST (WM_USER+3) +#define CBEM_GETITEMA (WM_USER+4) +#define CBEM_SETITEMA (WM_USER+5) +#define CBEM_DELETEITEM CB_DELETESTRING +#define CBEM_GETCOMBOCONTROL (WM_USER+6) +#define CBEM_GETEDITCONTROL (WM_USER+7) +#define CBEM_SETEXSTYLE (WM_USER+8) +#define CBEM_SETEXTENDEDSTYLE (WM_USER+14) +#define CBEM_GETEXSTYLE (WM_USER+9) +#define CBEM_GETEXTENDEDSTYLE (WM_USER+9) +#define CBEM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define CBEM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define CBEM_HASEDITCHANGED (WM_USER+10) +#define CBEM_INSERTITEMW (WM_USER+11) +#define CBEM_SETITEMW (WM_USER+12) +#define CBEM_GETITEMW (WM_USER+13) + +#ifdef UNICODE +#define CBEM_INSERTITEM CBEM_INSERTITEMW +#define CBEM_SETITEM CBEM_SETITEMW +#define CBEM_GETITEM CBEM_GETITEMW +#else +#define CBEM_INSERTITEM CBEM_INSERTITEMA +#define CBEM_SETITEM CBEM_SETITEMA +#define CBEM_GETITEM CBEM_GETITEMA +#endif + +#define CBEM_SETWINDOWTHEME CCM_SETWINDOWTHEME + +#define CBES_EX_NOEDITIMAGE 0x1 +#define CBES_EX_NOEDITIMAGEINDENT 0x2 +#define CBES_EX_PATHWORDBREAKPROC 0x4 +#define CBES_EX_NOSIZELIMIT 0x8 +#define CBES_EX_CASESENSITIVE 0x10 + + typedef struct { + NMHDR hdr; + COMBOBOXEXITEMA ceItem; + } NMCOMBOBOXEXA,*PNMCOMBOBOXEXA; + + typedef struct { + NMHDR hdr; + COMBOBOXEXITEMW ceItem; + } NMCOMBOBOXEXW,*PNMCOMBOBOXEXW; + +#ifdef UNICODE +#define NMCOMBOBOXEX NMCOMBOBOXEXW +#define PNMCOMBOBOXEX PNMCOMBOBOXEXW +#define CBEN_GETDISPINFO CBEN_GETDISPINFOW +#else +#define NMCOMBOBOXEX NMCOMBOBOXEXA +#define PNMCOMBOBOXEX PNMCOMBOBOXEXA +#define CBEN_GETDISPINFO CBEN_GETDISPINFOA +#endif + +#define CBEN_GETDISPINFOA (CBEN_FIRST - 0) +#define CBEN_INSERTITEM (CBEN_FIRST - 1) +#define CBEN_DELETEITEM (CBEN_FIRST - 2) +#define CBEN_BEGINEDIT (CBEN_FIRST - 4) +#define CBEN_ENDEDITA (CBEN_FIRST - 5) +#define CBEN_ENDEDITW (CBEN_FIRST - 6) + +#define CBEN_GETDISPINFOW (CBEN_FIRST - 7) + +#define CBEN_DRAGBEGINA (CBEN_FIRST - 8) +#define CBEN_DRAGBEGINW (CBEN_FIRST - 9) + +#ifdef UNICODE +#define CBEN_DRAGBEGIN CBEN_DRAGBEGINW +#else +#define CBEN_DRAGBEGIN CBEN_DRAGBEGINA +#endif + +#ifdef UNICODE +#define CBEN_ENDEDIT CBEN_ENDEDITW +#else +#define CBEN_ENDEDIT CBEN_ENDEDITA +#endif + +#define CBENF_KILLFOCUS 1 +#define CBENF_RETURN 2 +#define CBENF_ESCAPE 3 +#define CBENF_DROPDOWN 4 #define CBEMAXSTRLEN 260 -typedef struct tagNMCBEENDEDITW -{ - NMHDR hdr; - BOOL fChanged; - int iNewSelection; - WCHAR szText[CBEMAXSTRLEN]; - int iWhy; -} NMCBEENDEDITW, *LPNMCBEENDEDITW, *PNMCBEENDEDITW; - -typedef struct tagNMCBEENDEDITA -{ - NMHDR hdr; - BOOL fChanged; - int iNewSelection; - char szText[CBEMAXSTRLEN]; - int iWhy; -} NMCBEENDEDITA, *LPNMCBEENDEDITA, *PNMCBEENDEDITA; - -#define NMCBEENDEDIT WINELIB_NAME_AW(NMCBEENDEDIT) -#define LPNMCBEENDEDIT WINELIB_NAME_AW(LPNMCBEENDEDIT) -#define PNMCBEENDEDIT WINELIB_NAME_AW(PNMCBEENDEDIT) - -typedef struct -{ - NMHDR hdr; - COMBOBOXEXITEMA ceItem; -} NMCOMBOBOXEXA, *PNMCOMBOBOXEXA; - -typedef struct -{ - NMHDR hdr; - COMBOBOXEXITEMW ceItem; -} NMCOMBOBOXEXW, *PNMCOMBOBOXEXW; - -#define NMCOMBOBOXEX WINELIB_NAME_AW(NMCOMBOBOXEX) -#define PNMCOMBOBOXEX WINELIB_NAME_AW(PNMCOMBOBOXEX) - -typedef struct -{ - NMHDR hdr; - int iItemid; - char szText[CBEMAXSTRLEN]; -} NMCBEDRAGBEGINA, *PNMCBEDRAGBEGINA, *LPNMCBEDRAGBEGINA; - -typedef struct -{ + typedef struct { NMHDR hdr; int iItemid; WCHAR szText[CBEMAXSTRLEN]; -} NMCBEDRAGBEGINW, *PNMCBEDRAGBEGINW, *LPNMCBEDRAGBEGINW; + }NMCBEDRAGBEGINW,*LPNMCBEDRAGBEGINW,*PNMCBEDRAGBEGINW; -#define NMCBEDRAGBEGIN WINELIB_NAME_AW(NMCBEDRAGBEGIN) -#define PNMCBEDRAGBEGIN WINELIB_NAME_AW(PNMCBEDRAGBEGIN) -#define LPNMCBEDRAGBEGIN WINELIB_NAME_AW(LPNMCBEDRAGBEGIN) - - -/* Hotkey control */ - -#define HOTKEY_CLASSA "msctls_hotkey32" -#if defined(__GNUC__) -# define HOTKEY_CLASSW (const WCHAR []){ 'm','s','c','t','l','s','_', \ - 'h','o','t','k','e','y','3','2',0 } -#elif defined(_MSC_VER) -# define HOTKEY_CLASSW L"msctls_hotkey32" -#else -static const WCHAR HOTKEY_CLASSW[] = { 'm','s','c','t','l','s','_', - 'h','o','t','k','e','y','3','2',0 }; -#endif -#define HOTKEY_CLASS WINELIB_NAME_AW(HOTKEY_CLASS) - -#define HOTKEYF_SHIFT 0x01 -#define HOTKEYF_CONTROL 0x02 -#define HOTKEYF_ALT 0x04 -#define HOTKEYF_EXT 0x08 - -#define HKCOMB_NONE 0x0001 -#define HKCOMB_S 0x0002 -#define HKCOMB_C 0x0004 -#define HKCOMB_A 0x0008 -#define HKCOMB_SC 0x0010 -#define HKCOMB_SA 0x0020 -#define HKCOMB_CA 0x0040 -#define HKCOMB_SCA 0x0080 - -#define HKM_SETHOTKEY (WM_USER+1) -#define HKM_GETHOTKEY (WM_USER+2) -#define HKM_SETRULES (WM_USER+3) - - -/* animate control */ - -#define ANIMATE_CLASSA "SysAnimate32" -#if defined(__GNUC__) -# define ANIMATE_CLASSW (const WCHAR []){ 'S','y','s', \ - 'A','n','i','m','a','t','e','3','2',0 } -#elif defined(_MSC_VER) -# define ANIMATE_CLASSW L"SysAnimate32" -#else -static const WCHAR ANIMATE_CLASSW[] = { 'S','y','s', - 'A','n','i','m','a','t','e','3','2',0 }; -#endif -#define ANIMATE_CLASS WINELIB_NAME_AW(ANIMATE_CLASS) - -#define ACS_CENTER 0x0001 -#define ACS_TRANSPARENT 0x0002 -#define ACS_AUTOPLAY 0x0004 -#define ACS_TIMER 0x0008 /* no threads, just timers */ - -#define ACM_OPENA (WM_USER+100) -#define ACM_OPENW (WM_USER+103) -#define ACM_OPEN WINELIB_NAME_AW(ACM_OPEN) -#define ACM_PLAY (WM_USER+101) -#define ACM_STOP (WM_USER+102) - -#define ACN_START 1 -#define ACN_STOP 2 - -#define Animate_CreateA(hwndP,id,dwStyle,hInstance) \ - CreateWindowA(ANIMATE_CLASSA,NULL,dwStyle,0,0,0,0,hwndP,(HMENU)(id),hInstance,NULL) -#define Animate_CreateW(hwndP,id,dwStyle,hInstance) \ - CreateWindowW(ANIMATE_CLASSW,NULL,dwStyle,0,0,0,0,hwndP,(HMENU)(id),hInstance,NULL) -#define Animate_Create WINELIB_NAME_AW(Animate_Create) -#define Animate_OpenA(hwnd,szName) \ - (BOOL)SNDMSGA(hwnd,ACM_OPENA,0,(LPARAM)(LPSTR)(szName)) -#define Animate_OpenW(hwnd,szName) \ - (BOOL)SNDMSGW(hwnd,ACM_OPENW,0,(LPARAM)(LPWSTR)(szName)) -#define Animate_Open WINELIB_NAME_AW(Animate_Open) -#define Animate_OpenExA(hwnd,hInst,szName) \ - (BOOL)SNDMSGA(hwnd,ACM_OPENA,(WPARAM)hInst,(LPARAM)(LPSTR)(szName)) -#define Animate_OpenExW(hwnd,hInst,szName) \ - (BOOL)SNDMSGW(hwnd,ACM_OPENW,(WPARAM)hInst,(LPARAM)(LPWSTR)(szName)) -#define Animate_OpenEx WINELIB_NAME_AW(Animate_OpenEx) -#define Animate_Play(hwnd,from,to,rep) \ - (BOOL)SNDMSG(hwnd,ACM_PLAY,(WPARAM)(UINT)(rep),(LPARAM)MAKELONG(from,to)) -#define Animate_Stop(hwnd) \ - (BOOL)SNDMSG(hwnd,ACM_STOP,0,0) -#define Animate_Close(hwnd) \ - (BOOL)SNDMSG(hwnd,ACM_OPENA,0,0) -#define Animate_Seek(hwnd,frame) \ - (BOOL)SNDMSG(hwnd,ACM_PLAY,1,(LPARAM)MAKELONG(frame,frame)) - - -/************************************************************************** - * IP Address control - */ - -#define WC_IPADDRESSA "SysIPAddress32" -#if defined(__GNUC__) -# define WC_IPADDRESSW (const WCHAR []){ 'S','y','s', \ - 'I','P','A','d','d','r','e','s','s','3','2',0 } -#elif defined(_MSC_VER) -# define WC_IPADDRESSW L"SysIPAddress32" -#else -static const WCHAR WC_IPADDRESSW[] = { 'S','y','s', - 'I','P','A','d','d','r','e','s','s','3','2',0 }; -#endif -#define WC_IPADDRESS WINELIB_NAME_AW(WC_IPADDRESS) - -#define IPM_CLEARADDRESS (WM_USER+100) -#define IPM_SETADDRESS (WM_USER+101) -#define IPM_GETADDRESS (WM_USER+102) -#define IPM_SETRANGE (WM_USER+103) -#define IPM_SETFOCUS (WM_USER+104) -#define IPM_ISBLANK (WM_USER+105) - -#define IPN_FIRST (0U-860U) -#define IPN_LAST (0U-879U) -#define IPN_FIELDCHANGED (IPN_FIRST-0) - -typedef struct tagNMIPADDRESS -{ + typedef struct { NMHDR hdr; - INT iField; - INT iValue; -} NMIPADDRESS, *LPNMIPADDRESS; + int iItemid; + char szText[CBEMAXSTRLEN]; + }NMCBEDRAGBEGINA,*LPNMCBEDRAGBEGINA,*PNMCBEDRAGBEGINA; -#define MAKEIPRANGE(low,high) \ - ((LPARAM)(WORD)(((BYTE)(high)<<8)+(BYTE)(low))) -#define MAKEIPADDRESS(b1,b2,b3,b4) \ - ((LPARAM)(((DWORD)(b1)<<24)+((DWORD)(b2)<<16)+((DWORD)(b3)<<8)+((DWORD)(b4)))) - -#define FIRST_IPADDRESS(x) (((x)>>24)&0xff) -#define SECOND_IPADDRESS(x) (((x)>>16)&0xff) -#define THIRD_IPADDRESS(x) (((x)>>8)&0xff) -#define FOURTH_IPADDRESS(x) ((x)&0xff) - - -/************************************************************************** - * Native Font control - */ - -#define WC_NATIVEFONTCTLA "NativeFontCtl" -#if defined(__GNUC__) -# define WC_NATIVEFONTCTLW (const WCHAR []){ 'N','a','t','i','v','e', \ - 'F','o','n','t','C','t','l',0 } -#elif defined(_MSC_VER) -# define WC_NATIVEFONTCTLW L"NativeFontCtl" +#ifdef UNICODE +#define NMCBEDRAGBEGIN NMCBEDRAGBEGINW +#define LPNMCBEDRAGBEGIN LPNMCBEDRAGBEGINW +#define PNMCBEDRAGBEGIN PNMCBEDRAGBEGINW #else -static const WCHAR WC_NATIVEFONTCTLW[] = { 'N','a','t','i','v','e', - 'F','o','n','t','C','t','l',0 }; +#define NMCBEDRAGBEGIN NMCBEDRAGBEGINA +#define LPNMCBEDRAGBEGIN LPNMCBEDRAGBEGINA +#define PNMCBEDRAGBEGIN PNMCBEDRAGBEGINA #endif -#define WC_NATIVEFONTCTL WINELIB_NAME_AW(WC_NATIVEFONTCTL) -#define NFS_EDIT 0x0001 -#define NFS_STATIC 0x0002 -#define NFS_LISTCOMBO 0x0004 -#define NFS_BUTTON 0x0008 -#define NFS_ALL 0x0010 + typedef struct { + NMHDR hdr; + WINBOOL fChanged; + int iNewSelection; + WCHAR szText[CBEMAXSTRLEN]; + int iWhy; + } NMCBEENDEDITW,*LPNMCBEENDEDITW,*PNMCBEENDEDITW; + typedef struct { + NMHDR hdr; + WINBOOL fChanged; + int iNewSelection; + char szText[CBEMAXSTRLEN]; + int iWhy; + } NMCBEENDEDITA,*LPNMCBEENDEDITA,*PNMCBEENDEDITA; -/************************************************************************** - * Month calendar control - * - */ - -#define MONTHCAL_CLASSA "SysMonthCal32" -#if defined(__GNUC__) -# define MONTHCAL_CLASSW (const WCHAR []){ 'S','y','s', \ - 'M','o','n','t','h','C','a','l','3','2',0 } -#elif defined(_MSC_VER) -# define MONTHCAL_CLASSW L"SysMonthCal32" +#ifdef UNICODE +#define NMCBEENDEDIT NMCBEENDEDITW +#define LPNMCBEENDEDIT LPNMCBEENDEDITW +#define PNMCBEENDEDIT PNMCBEENDEDITW #else -static const WCHAR MONTHCAL_CLASSW[] = { 'S','y','s', - 'M','o','n','t','h','C','a','l','3','2',0 }; +#define NMCBEENDEDIT NMCBEENDEDITA +#define LPNMCBEENDEDIT LPNMCBEENDEDITA +#define PNMCBEENDEDIT PNMCBEENDEDITA +#endif #endif -#define MONTHCAL_CLASS WINELIB_NAME_AW(MONTHCAL_CLASS) -#define MCM_FIRST 0x1000 -#define MCN_FIRST (0U-750U) -#define MCN_LAST (0U-759U) +#ifndef NOTABCONTROL +#define WC_TABCONTROLA "SysTabControl32" +#define WC_TABCONTROLW L"SysTabControl32" +#ifdef UNICODE +#define WC_TABCONTROL WC_TABCONTROLW +#else +#define WC_TABCONTROL WC_TABCONTROLA +#endif -#define MCM_GETCURSEL (MCM_FIRST + 1) -#define MCM_SETCURSEL (MCM_FIRST + 2) -#define MCM_GETMAXSELCOUNT (MCM_FIRST + 3) -#define MCM_SETMAXSELCOUNT (MCM_FIRST + 4) -#define MCM_GETSELRANGE (MCM_FIRST + 5) -#define MCM_SETSELRANGE (MCM_FIRST + 6) -#define MCM_GETMONTHRANGE (MCM_FIRST + 7) -#define MCM_SETDAYSTATE (MCM_FIRST + 8) -#define MCM_GETMINREQRECT (MCM_FIRST + 9) -#define MCM_SETCOLOR (MCM_FIRST + 10) -#define MCM_GETCOLOR (MCM_FIRST + 11) -#define MCM_SETTODAY (MCM_FIRST + 12) -#define MCM_GETTODAY (MCM_FIRST + 13) -#define MCM_HITTEST (MCM_FIRST + 14) -#define MCM_SETFIRSTDAYOFWEEK (MCM_FIRST + 15) -#define MCM_GETFIRSTDAYOFWEEK (MCM_FIRST + 16) -#define MCM_GETRANGE (MCM_FIRST + 17) -#define MCM_SETRANGE (MCM_FIRST + 18) -#define MCM_GETMONTHDELTA (MCM_FIRST + 19) -#define MCM_SETMONTHDELTA (MCM_FIRST + 20) -#define MCM_GETMAXTODAYWIDTH (MCM_FIRST + 21) -#define MCM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT -#define MCM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define TCS_SCROLLOPPOSITE 0x1 +#define TCS_BOTTOM 0x2 +#define TCS_RIGHT 0x2 +#define TCS_MULTISELECT 0x4 +#define TCS_FLATBUTTONS 0x8 +#define TCS_FORCEICONLEFT 0x10 +#define TCS_FORCELABELLEFT 0x20 +#define TCS_HOTTRACK 0x40 +#define TCS_VERTICAL 0x80 +#define TCS_TABS 0x0 +#define TCS_BUTTONS 0x100 +#define TCS_SINGLELINE 0x0 +#define TCS_MULTILINE 0x200 +#define TCS_RIGHTJUSTIFY 0x0 +#define TCS_FIXEDWIDTH 0x400 +#define TCS_RAGGEDRIGHT 0x800 +#define TCS_FOCUSONBUTTONDOWN 0x1000 +#define TCS_OWNERDRAWFIXED 0x2000 +#define TCS_TOOLTIPS 0x4000 +#define TCS_FOCUSNEVER 0x8000 +#define TCS_EX_FLATSEPARATORS 0x1 +#define TCS_EX_REGISTERDROP 0x2 -/* Notifications */ +#define TCM_GETIMAGELIST (TCM_FIRST+2) +#define TabCtrl_GetImageList(hwnd) (HIMAGELIST)SNDMSG((hwnd),TCM_GETIMAGELIST,0,0L) -#define MCN_SELCHANGE (MCN_FIRST + 1) -#define MCN_GETDAYSTATE (MCN_FIRST + 3) -#define MCN_SELECT (MCN_FIRST + 4) +#define TCM_SETIMAGELIST (TCM_FIRST+3) +#define TabCtrl_SetImageList(hwnd,himl) (HIMAGELIST)SNDMSG((hwnd),TCM_SETIMAGELIST,0,(LPARAM)(HIMAGELIST)(himl)) -#define MCSC_BACKGROUND 0 -#define MCSC_TEXT 1 -#define MCSC_TITLEBK 2 -#define MCSC_TITLETEXT 3 -#define MCSC_MONTHBK 4 +#define TCM_GETITEMCOUNT (TCM_FIRST+4) +#define TabCtrl_GetItemCount(hwnd) (int)SNDMSG((hwnd),TCM_GETITEMCOUNT,0,0L) + +#define TCIF_TEXT 0x1 +#define TCIF_IMAGE 0x2 +#define TCIF_RTLREADING 0x4 +#define TCIF_PARAM 0x8 +#define TCIF_STATE 0x10 + +#define TCIS_BUTTONPRESSED 0x1 +#define TCIS_HIGHLIGHTED 0x2 + +#define TC_ITEMHEADERA TCITEMHEADERA +#define TC_ITEMHEADERW TCITEMHEADERW +#define TC_ITEMHEADER TCITEMHEADER + + typedef struct tagTCITEMHEADERA { + UINT mask; + UINT lpReserved1; + UINT lpReserved2; + LPSTR pszText; + int cchTextMax; + int iImage; + } TCITEMHEADERA,*LPTCITEMHEADERA; + + typedef struct tagTCITEMHEADERW { + UINT mask; + UINT lpReserved1; + UINT lpReserved2; + LPWSTR pszText; + int cchTextMax; + int iImage; + } TCITEMHEADERW,*LPTCITEMHEADERW; + +#ifdef UNICODE +#define TCITEMHEADER TCITEMHEADERW +#define LPTCITEMHEADER LPTCITEMHEADERW +#else +#define TCITEMHEADER TCITEMHEADERA +#define LPTCITEMHEADER LPTCITEMHEADERA +#endif + +#define TC_ITEMA TCITEMA +#define TC_ITEMW TCITEMW +#define TC_ITEM TCITEM + + typedef struct tagTCITEMA { + UINT mask; + DWORD dwState; + DWORD dwStateMask; + LPSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + } TCITEMA,*LPTCITEMA; + + typedef struct tagTCITEMW { + UINT mask; + DWORD dwState; + DWORD dwStateMask; + LPWSTR pszText; + int cchTextMax; + int iImage; + LPARAM lParam; + } TCITEMW,*LPTCITEMW; + +#ifdef UNICODE +#define TCITEM TCITEMW +#define LPTCITEM LPTCITEMW +#else +#define TCITEM TCITEMA +#define LPTCITEM LPTCITEMA +#endif + +#define TCM_GETITEMA (TCM_FIRST+5) +#define TCM_GETITEMW (TCM_FIRST+60) + +#ifdef UNICODE +#define TCM_GETITEM TCM_GETITEMW +#else +#define TCM_GETITEM TCM_GETITEMA +#endif + +#define TabCtrl_GetItem(hwnd,iItem,pitem) (WINBOOL)SNDMSG((hwnd),TCM_GETITEM,(WPARAM)(int)(iItem),(LPARAM)(TC_ITEM *)(pitem)) + +#define TCM_SETITEMA (TCM_FIRST+6) +#define TCM_SETITEMW (TCM_FIRST+61) + +#ifdef UNICODE +#define TCM_SETITEM TCM_SETITEMW +#else +#define TCM_SETITEM TCM_SETITEMA +#endif + +#define TabCtrl_SetItem(hwnd,iItem,pitem) (WINBOOL)SNDMSG((hwnd),TCM_SETITEM,(WPARAM)(int)(iItem),(LPARAM)(TC_ITEM *)(pitem)) + +#define TCM_INSERTITEMA (TCM_FIRST+7) +#define TCM_INSERTITEMW (TCM_FIRST+62) + +#ifdef UNICODE +#define TCM_INSERTITEM TCM_INSERTITEMW +#else +#define TCM_INSERTITEM TCM_INSERTITEMA +#endif + +#define TabCtrl_InsertItem(hwnd,iItem,pitem) (int)SNDMSG((hwnd),TCM_INSERTITEM,(WPARAM)(int)(iItem),(LPARAM)(const TC_ITEM *)(pitem)) + +#define TCM_DELETEITEM (TCM_FIRST+8) +#define TabCtrl_DeleteItem(hwnd,i) (WINBOOL)SNDMSG((hwnd),TCM_DELETEITEM,(WPARAM)(int)(i),0L) + +#define TCM_DELETEALLITEMS (TCM_FIRST+9) +#define TabCtrl_DeleteAllItems(hwnd) (WINBOOL)SNDMSG((hwnd),TCM_DELETEALLITEMS,0,0L) + +#define TCM_GETITEMRECT (TCM_FIRST+10) +#define TabCtrl_GetItemRect(hwnd,i,prc) (WINBOOL)SNDMSG((hwnd),TCM_GETITEMRECT,(WPARAM)(int)(i),(LPARAM)(RECT *)(prc)) + +#define TCM_GETCURSEL (TCM_FIRST+11) +#define TabCtrl_GetCurSel(hwnd) (int)SNDMSG((hwnd),TCM_GETCURSEL,0,0) + +#define TCM_SETCURSEL (TCM_FIRST+12) +#define TabCtrl_SetCurSel(hwnd,i) (int)SNDMSG((hwnd),TCM_SETCURSEL,(WPARAM)(i),0) + +#define TCHT_NOWHERE 0x1 +#define TCHT_ONITEMICON 0x2 +#define TCHT_ONITEMLABEL 0x4 +#define TCHT_ONITEM (TCHT_ONITEMICON | TCHT_ONITEMLABEL) + +#define LPTC_HITTESTINFO LPTCHITTESTINFO +#define TC_HITTESTINFO TCHITTESTINFO + + typedef struct tagTCHITTESTINFO { + POINT pt; + UINT flags; + } TCHITTESTINFO,*LPTCHITTESTINFO; + +#define TCM_HITTEST (TCM_FIRST+13) +#define TabCtrl_HitTest(hwndTC,pinfo) (int)SNDMSG((hwndTC),TCM_HITTEST,0,(LPARAM)(TC_HITTESTINFO *)(pinfo)) +#define TCM_SETITEMEXTRA (TCM_FIRST+14) +#define TabCtrl_SetItemExtra(hwndTC,cb) (WINBOOL)SNDMSG((hwndTC),TCM_SETITEMEXTRA,(WPARAM)(cb),0L) +#define TCM_ADJUSTRECT (TCM_FIRST+40) +#define TabCtrl_AdjustRect(hwnd,bLarger,prc) (int)SNDMSG(hwnd,TCM_ADJUSTRECT,(WPARAM)(WINBOOL)(bLarger),(LPARAM)(RECT *)prc) +#define TCM_SETITEMSIZE (TCM_FIRST+41) +#define TabCtrl_SetItemSize(hwnd,x,y) (DWORD)SNDMSG((hwnd),TCM_SETITEMSIZE,0,MAKELPARAM(x,y)) +#define TCM_REMOVEIMAGE (TCM_FIRST+42) +#define TabCtrl_RemoveImage(hwnd,i) (void)SNDMSG((hwnd),TCM_REMOVEIMAGE,i,0L) +#define TCM_SETPADDING (TCM_FIRST+43) +#define TabCtrl_SetPadding(hwnd,cx,cy) (void)SNDMSG((hwnd),TCM_SETPADDING,0,MAKELPARAM(cx,cy)) +#define TCM_GETROWCOUNT (TCM_FIRST+44) +#define TabCtrl_GetRowCount(hwnd) (int)SNDMSG((hwnd),TCM_GETROWCOUNT,0,0L) +#define TCM_GETTOOLTIPS (TCM_FIRST+45) +#define TabCtrl_GetToolTips(hwnd) (HWND)SNDMSG((hwnd),TCM_GETTOOLTIPS,0,0L) +#define TCM_SETTOOLTIPS (TCM_FIRST+46) +#define TabCtrl_SetToolTips(hwnd,hwndTT) (void)SNDMSG((hwnd),TCM_SETTOOLTIPS,(WPARAM)(hwndTT),0L) +#define TCM_GETCURFOCUS (TCM_FIRST+47) +#define TabCtrl_GetCurFocus(hwnd) (int)SNDMSG((hwnd),TCM_GETCURFOCUS,0,0) +#define TCM_SETCURFOCUS (TCM_FIRST+48) +#define TabCtrl_SetCurFocus(hwnd,i) SNDMSG((hwnd),TCM_SETCURFOCUS,i,0) +#define TCM_SETMINTABWIDTH (TCM_FIRST+49) +#define TabCtrl_SetMinTabWidth(hwnd,x) (int)SNDMSG((hwnd),TCM_SETMINTABWIDTH,0,x) +#define TCM_DESELECTALL (TCM_FIRST+50) +#define TabCtrl_DeselectAll(hwnd,fExcludeFocus) (void)SNDMSG((hwnd),TCM_DESELECTALL,fExcludeFocus,0) +#define TCM_HIGHLIGHTITEM (TCM_FIRST+51) +#define TabCtrl_HighlightItem(hwnd,i,fHighlight) (WINBOOL)SNDMSG((hwnd),TCM_HIGHLIGHTITEM,(WPARAM)(i),(LPARAM)MAKELONG (fHighlight,0)) +#define TCM_SETEXTENDEDSTYLE (TCM_FIRST+52) +#define TabCtrl_SetExtendedStyle(hwnd,dw) (DWORD)SNDMSG((hwnd),TCM_SETEXTENDEDSTYLE,0,dw) +#define TCM_GETEXTENDEDSTYLE (TCM_FIRST+53) +#define TabCtrl_GetExtendedStyle(hwnd) (DWORD)SNDMSG((hwnd),TCM_GETEXTENDEDSTYLE,0,0) +#define TCM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define TabCtrl_SetUnicodeFormat(hwnd,fUnicode) (WINBOOL)SNDMSG((hwnd),TCM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) +#define TCM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define TabCtrl_GetUnicodeFormat(hwnd) (WINBOOL)SNDMSG((hwnd),TCM_GETUNICODEFORMAT,0,0) + +#define TCN_KEYDOWN (TCN_FIRST - 0) + +#define TC_KEYDOWN NMTCKEYDOWN + +#include + + typedef struct tagTCKEYDOWN { + NMHDR hdr; + WORD wVKey; + UINT flags; + } NMTCKEYDOWN; + +#include + +#define TCN_SELCHANGE (TCN_FIRST - 1) +#define TCN_SELCHANGING (TCN_FIRST - 2) +#define TCN_GETOBJECT (TCN_FIRST - 3) +#define TCN_FOCUSCHANGE (TCN_FIRST - 4) +#endif + +#ifndef NOANIMATE + +#define ANIMATE_CLASSW L"SysAnimate32" +#define ANIMATE_CLASSA "SysAnimate32" +#ifdef UNICODE +#define ANIMATE_CLASS ANIMATE_CLASSW +#else +#define ANIMATE_CLASS ANIMATE_CLASSA +#endif + +#define ACS_CENTER 0x1 +#define ACS_TRANSPARENT 0x2 +#define ACS_AUTOPLAY 0x4 +#define ACS_TIMER 0x8 + +#define ACM_OPENA (WM_USER+100) +#define ACM_OPENW (WM_USER+103) +#ifdef UNICODE +#define ACM_OPEN ACM_OPENW +#else +#define ACM_OPEN ACM_OPENA +#endif + +#define ACM_PLAY (WM_USER+101) +#define ACM_STOP (WM_USER+102) + +#define ACN_START 1 +#define ACN_STOP 2 + +#define Animate_Create(hwndP,id,dwStyle,hInstance) CreateWindow(ANIMATE_CLASS,NULL,dwStyle,0,0,0,0,hwndP,(HMENU)(id),hInstance,NULL) + +#define Animate_Open(hwnd,szName) (WINBOOL)SNDMSG(hwnd,ACM_OPEN,0,(LPARAM)(LPTSTR)(szName)) +#define Animate_OpenEx(hwnd,hInst,szName) (WINBOOL)SNDMSG(hwnd,ACM_OPEN,(WPARAM)(hInst),(LPARAM)(LPTSTR)(szName)) +#define Animate_Play(hwnd,from,to,rep) (WINBOOL)SNDMSG(hwnd,ACM_PLAY,(WPARAM)(rep),(LPARAM)MAKELONG(from,to)) +#define Animate_Stop(hwnd) (WINBOOL)SNDMSG(hwnd,ACM_STOP,0,0) +#define Animate_Close(hwnd) Animate_Open(hwnd,NULL) +#define Animate_Seek(hwnd,frame) Animate_Play(hwnd,frame,frame,1) +#endif + +#ifndef NOMONTHCAL +#define MONTHCAL_CLASSW L"SysMonthCal32" +#define MONTHCAL_CLASSA "SysMonthCal32" +#ifdef UNICODE +#define MONTHCAL_CLASS MONTHCAL_CLASSW +#else +#define MONTHCAL_CLASS MONTHCAL_CLASSA +#endif + + typedef DWORD MONTHDAYSTATE,*LPMONTHDAYSTATE; + +#define MCM_FIRST 0x1000 + +#define MCM_GETCURSEL (MCM_FIRST+1) +#define MonthCal_GetCurSel(hmc,pst) (WINBOOL)SNDMSG(hmc,MCM_GETCURSEL,0,(LPARAM)(pst)) +#define MCM_SETCURSEL (MCM_FIRST+2) +#define MonthCal_SetCurSel(hmc,pst) (WINBOOL)SNDMSG(hmc,MCM_SETCURSEL,0,(LPARAM)(pst)) +#define MCM_GETMAXSELCOUNT (MCM_FIRST+3) +#define MonthCal_GetMaxSelCount(hmc) (DWORD)SNDMSG(hmc,MCM_GETMAXSELCOUNT,0,0L) +#define MCM_SETMAXSELCOUNT (MCM_FIRST+4) +#define MonthCal_SetMaxSelCount(hmc,n) (WINBOOL)SNDMSG(hmc,MCM_SETMAXSELCOUNT,(WPARAM)(n),0L) +#define MCM_GETSELRANGE (MCM_FIRST+5) +#define MonthCal_GetSelRange(hmc,rgst) SNDMSG(hmc,MCM_GETSELRANGE,0,(LPARAM)(rgst)) +#define MCM_SETSELRANGE (MCM_FIRST+6) +#define MonthCal_SetSelRange(hmc,rgst) SNDMSG(hmc,MCM_SETSELRANGE,0,(LPARAM)(rgst)) +#define MCM_GETMONTHRANGE (MCM_FIRST+7) +#define MonthCal_GetMonthRange(hmc,gmr,rgst) (DWORD)SNDMSG(hmc,MCM_GETMONTHRANGE,(WPARAM)(gmr),(LPARAM)(rgst)) +#define MCM_SETDAYSTATE (MCM_FIRST+8) +#define MonthCal_SetDayState(hmc,cbds,rgds) SNDMSG(hmc,MCM_SETDAYSTATE,(WPARAM)(cbds),(LPARAM)(rgds)) +#define MCM_GETMINREQRECT (MCM_FIRST+9) +#define MonthCal_GetMinReqRect(hmc,prc) SNDMSG(hmc,MCM_GETMINREQRECT,0,(LPARAM)(prc)) +#define MCM_SETCOLOR (MCM_FIRST+10) +#define MonthCal_SetColor(hmc,iColor,clr) SNDMSG(hmc,MCM_SETCOLOR,iColor,clr) +#define MCM_GETCOLOR (MCM_FIRST+11) +#define MonthCal_GetColor(hmc,iColor) SNDMSG(hmc,MCM_GETCOLOR,iColor,0) + +#define MCSC_BACKGROUND 0 +#define MCSC_TEXT 1 +#define MCSC_TITLEBK 2 +#define MCSC_TITLETEXT 3 +#define MCSC_MONTHBK 4 #define MCSC_TRAILINGTEXT 5 -#define MCS_DAYSTATE 0x0001 -#define MCS_MULTISELECT 0x0002 -#define MCS_WEEKNUMBERS 0x0004 -#define MCS_NOTODAY 0x0010 -#define MCS_NOTODAYCIRCLE 0x0008 -#define MCS_NOTRAILINGDATES 0x0040 +#define MCM_SETTODAY (MCM_FIRST+12) +#define MonthCal_SetToday(hmc,pst) SNDMSG(hmc,MCM_SETTODAY,0,(LPARAM)(pst)) +#define MCM_GETTODAY (MCM_FIRST+13) +#define MonthCal_GetToday(hmc,pst) (WINBOOL)SNDMSG(hmc,MCM_GETTODAY,0,(LPARAM)(pst)) +#define MCM_HITTEST (MCM_FIRST+14) +#define MonthCal_HitTest(hmc,pinfo) SNDMSG(hmc,MCM_HITTEST,0,(LPARAM)(PMCHITTESTINFO)(pinfo)) -#define MCHT_TITLE 0x00010000 -#define MCHT_CALENDAR 0x00020000 -#define MCHT_TODAYLINK 0x00030000 + typedef struct { + UINT cbSize; + POINT pt; -#define MCHT_NEXT 0x01000000 -#define MCHT_PREV 0x02000000 -#define MCHT_NOWHERE 0x00000000 -#define MCHT_TITLEBK (MCHT_TITLE) -#define MCHT_TITLEMONTH (MCHT_TITLE | 0x0001) -#define MCHT_TITLEYEAR (MCHT_TITLE | 0x0002) -#define MCHT_TITLEBTNNEXT (MCHT_TITLE | MCHT_NEXT | 0x0003) -#define MCHT_TITLEBTNPREV (MCHT_TITLE | MCHT_PREV | 0x0003) - -#define MCHT_CALENDARBK (MCHT_CALENDAR) -#define MCHT_CALENDARDATE (MCHT_CALENDAR | 0x0001) -#define MCHT_CALENDARDATENEXT (MCHT_CALENDARDATE | MCHT_NEXT) -#define MCHT_CALENDARDATEPREV (MCHT_CALENDARDATE | MCHT_PREV) -#define MCHT_CALENDARDAY (MCHT_CALENDAR | 0x0002) -#define MCHT_CALENDARWEEKNUM (MCHT_CALENDAR | 0x0003) - - - -#define GMR_VISIBLE 0 -#define GMR_DAYSTATE 1 - - -/* Month calendar's structures */ - - -typedef struct { - UINT cbSize; - POINT pt; - UINT uHit; - SYSTEMTIME st; - /* Vista */ - RECT rc; - INT iOffset; - INT iRow; - INT iCol; -} MCHITTESTINFO, *PMCHITTESTINFO; - -#define MCHITTESTINFO_V1_SIZE CCSIZEOF_STRUCT(MCHITTESTINFO, st) - -typedef struct tagNMSELCHANGE -{ - NMHDR nmhdr; - SYSTEMTIME stSelStart; - SYSTEMTIME stSelEnd; -} NMSELCHANGE, *LPNMSELCHANGE; - -typedef NMSELCHANGE NMSELECT, *LPNMSELECT; -typedef DWORD MONTHDAYSTATE, *LPMONTHDAYSTATE; - -typedef struct tagNMDAYSTATE -{ - NMHDR nmhdr; - SYSTEMTIME stStart; - int cDayState; - LPMONTHDAYSTATE prgDayState; -} NMDAYSTATE, *LPNMDAYSTATE; - - -/* macros */ - -#define MonthCal_GetCurSel(hmc, pst) \ - (BOOL)SNDMSG(hmc, MCM_GETCURSEL, 0, (LPARAM)(pst)) -#define MonthCal_SetCurSel(hmc, pst) \ - (BOOL)SNDMSG(hmc, MCM_SETCURSEL, 0, (LPARAM)(pst)) -#define MonthCal_GetMaxSelCount(hmc) \ - (DWORD)SNDMSG(hmc, MCM_GETMAXSELCOUNT, 0, 0L) -#define MonthCal_SetMaxSelCount(hmc, n) \ - (BOOL)SNDMSG(hmc, MCM_SETMAXSELCOUNT, (WPARAM)(n), 0L) -#define MonthCal_GetSelRange(hmc, rgst) \ - SNDMSG(hmc, MCM_GETSELRANGE, 0, (LPARAM) (rgst)) -#define MonthCal_SetSelRange(hmc, rgst) \ - SNDMSG(hmc, MCM_SETSELRANGE, 0, (LPARAM) (rgst)) -#define MonthCal_GetMonthRange(hmc, gmr, rgst) \ - (DWORD)SNDMSG(hmc, MCM_GETMONTHRANGE, (WPARAM)(gmr), (LPARAM)(rgst)) -#define MonthCal_SetDayState(hmc, cbds, rgds) \ - SNDMSG(hmc, MCM_SETDAYSTATE, (WPARAM)(cbds), (LPARAM)(rgds)) -#define MonthCal_GetMinReqRect(hmc, prc) \ - SNDMSG(hmc, MCM_GETMINREQRECT, 0, (LPARAM)(prc)) -#define MonthCal_SetColor(hmc, iColor, clr)\ - SNDMSG(hmc, MCM_SETCOLOR, iColor, clr) -#define MonthCal_GetColor(hmc, iColor) \ - SNDMSG(hmc, MCM_SETCOLOR, iColor, 0) -#define MonthCal_GetToday(hmc, pst)\ - (BOOL)SNDMSG(hmc, MCM_GETTODAY, 0, (LPARAM)pst) -#define MonthCal_SetToday(hmc, pst)\ - SNDMSG(hmc, MCM_SETTODAY, 0, (LPARAM)pst) -#define MonthCal_HitTest(hmc, pinfo) \ - SNDMSG(hmc, MCM_HITTEST, 0, (LPARAM)(PMCHITTESTINFO)pinfo) -#define MonthCal_SetFirstDayOfWeek(hmc, iDay) \ - SNDMSG(hmc, MCM_SETFIRSTDAYOFWEEK, 0, iDay) -#define MonthCal_GetFirstDayOfWeek(hmc) \ - (DWORD)SNDMSG(hmc, MCM_GETFIRSTDAYOFWEEK, 0, 0) -#define MonthCal_GetRange(hmc, rgst) \ - (DWORD)SNDMSG(hmc, MCM_GETRANGE, 0, (LPARAM)(rgst)) -#define MonthCal_SetRange(hmc, gd, rgst) \ - (BOOL)SNDMSG(hmc, MCM_SETRANGE, (WPARAM)(gd), (LPARAM)(rgst)) -#define MonthCal_GetMonthDelta(hmc) \ - (int)SNDMSG(hmc, MCM_GETMONTHDELTA, 0, 0) -#define MonthCal_SetMonthDelta(hmc, n) \ - (int)SNDMSG(hmc, MCM_SETMONTHDELTA, n, 0) -#define MonthCal_GetMaxTodayWidth(hmc) \ - (DWORD)SNDMSG(hmc, MCM_GETMAXTODAYWIDTH, 0, 0) -#define MonthCal_SetUnicodeFormat(hwnd, fUnicode) \ - (BOOL)SNDMSG((hwnd), MCM_SETUNICODEFORMAT, (WPARAM)(fUnicode), 0) -#define MonthCal_GetUnicodeFormat(hwnd) \ - (BOOL)SNDMSG((hwnd), MCM_GETUNICODEFORMAT, 0, 0) - - -/************************************************************************** - * Date and time picker control - */ - -#define DATETIMEPICK_CLASSA "SysDateTimePick32" -#if defined(__GNUC__) -# define DATETIMEPICK_CLASSW (const WCHAR []){ 'S','y','s', \ - 'D','a','t','e','T','i','m','e','P','i','c','k','3','2',0 } -#elif defined(_MSC_VER) -# define DATETIMEPICK_CLASSW L"SysDateTimePick32" -#else -static const WCHAR DATETIMEPICK_CLASSW[] = { 'S','y','s', - 'D','a','t','e','T','i','m','e','P','i','c','k','3','2',0 }; -#endif -#define DATETIMEPICK_CLASS WINELIB_NAME_AW(DATETIMEPICK_CLASS) - -#define DTM_FIRST 0x1000 -#define DTN_FIRST (0U-760U) -#define DTN_LAST (0U-799U) - - -#define DTM_GETSYSTEMTIME (DTM_FIRST+1) -#define DTM_SETSYSTEMTIME (DTM_FIRST+2) -#define DTM_GETRANGE (DTM_FIRST+3) -#define DTM_SETRANGE (DTM_FIRST+4) -#define DTM_SETFORMATA (DTM_FIRST+5) -#define DTM_SETFORMATW (DTM_FIRST + 50) -#define DTM_SETFORMAT WINELIB_NAME_AW(DTM_SETFORMAT) -#define DTM_SETMCCOLOR (DTM_FIRST+6) -#define DTM_GETMCCOLOR (DTM_FIRST+7) -#define DTM_GETMONTHCAL (DTM_FIRST+8) -#define DTM_SETMCFONT (DTM_FIRST+9) -#define DTM_GETMCFONT (DTM_FIRST+10) - - -/* Datetime Notifications */ - -#define DTN_DATETIMECHANGE (DTN_FIRST + 1) -#define DTN_USERSTRINGA (DTN_FIRST + 2) -#define DTN_WMKEYDOWNA (DTN_FIRST + 3) -#define DTN_FORMATA (DTN_FIRST + 4) -#define DTN_FORMATQUERYA (DTN_FIRST + 5) -#define DTN_DROPDOWN (DTN_FIRST + 6) -#define DTN_CLOSEUP (DTN_FIRST + 7) -#define DTN_USERSTRINGW (DTN_FIRST + 15) -#define DTN_WMKEYDOWNW (DTN_FIRST + 16) -#define DTN_FORMATW (DTN_FIRST + 17) -#define DTN_FORMATQUERYW (DTN_FIRST + 18) - -#define DTN_USERSTRING WINELIB_NAME_AW(DTN_USERSTRING) -#define DTN_WMKEYDOWN WINELIB_NAME_AW(DTN_WMKEYDOWN) -#define DTN_FORMAT WINELIB_NAME_AW(DTN_FORMAT) -#define DTN_FORMATQUERY WINELIB_NAME_AW(DTN_FORMATQUERY) - -#define DTS_SHORTDATEFORMAT 0x0000 -#define DTS_UPDOWN 0x0001 -#define DTS_SHOWNONE 0x0002 -#define DTS_LONGDATEFORMAT 0x0004 -#define DTS_TIMEFORMAT 0x0009 -#define DTS_APPCANPARSE 0x0010 -#define DTS_RIGHTALIGN 0x0020 - -typedef struct tagNMDATETIMECHANGE -{ - NMHDR nmhdr; - DWORD dwFlags; - SYSTEMTIME st; -} NMDATETIMECHANGE, *LPNMDATETIMECHANGE; - -typedef struct tagNMDATETIMESTRINGA -{ - NMHDR nmhdr; - LPCSTR pszUserString; + UINT uHit; SYSTEMTIME st; - DWORD dwFlags; -} NMDATETIMESTRINGA, *LPNMDATETIMESTRINGA; + } MCHITTESTINFO,*PMCHITTESTINFO; -typedef struct tagNMDATETIMESTRINGW -{ - NMHDR nmhdr; - LPCWSTR pszUserString; - SYSTEMTIME st; - DWORD dwFlags; -} NMDATETIMESTRINGW, *LPNMDATETIMESTRINGW; +#define MCHT_TITLE 0x10000 +#define MCHT_CALENDAR 0x20000 +#define MCHT_TODAYLINK 0x30000 -DECL_WINELIB_TYPE_AW(NMDATETIMESTRING) -DECL_WINELIB_TYPE_AW(LPNMDATETIMESTRING) +#define MCHT_NEXT 0x1000000 +#define MCHT_PREV 0x2000000 -typedef struct tagNMDATETIMEWMKEYDOWNA -{ - NMHDR nmhdr; - int nVirtKey; - LPCSTR pszFormat; - SYSTEMTIME st; -} NMDATETIMEWMKEYDOWNA, *LPNMDATETIMEWMKEYDOWNA; +#define MCHT_NOWHERE 0x0 -typedef struct tagNMDATETIMEWMKEYDOWNW -{ - NMHDR nmhdr; - int nVirtKey; - LPCWSTR pszFormat; - SYSTEMTIME st; -} NMDATETIMEWMKEYDOWNW, *LPNMDATETIMEWMKEYDOWNW; +#define MCHT_TITLEBK (MCHT_TITLE) +#define MCHT_TITLEMONTH (MCHT_TITLE | 0x1) +#define MCHT_TITLEYEAR (MCHT_TITLE | 0x2) +#define MCHT_TITLEBTNNEXT (MCHT_TITLE | MCHT_NEXT | 0x3) +#define MCHT_TITLEBTNPREV (MCHT_TITLE | MCHT_PREV | 0x3) -DECL_WINELIB_TYPE_AW(NMDATETIMEWMKEYDOWN) -DECL_WINELIB_TYPE_AW(LPNMDATETIMEWMKEYDOWN) +#define MCHT_CALENDARBK (MCHT_CALENDAR) +#define MCHT_CALENDARDATE (MCHT_CALENDAR | 0x1) +#define MCHT_CALENDARDATENEXT (MCHT_CALENDARDATE | MCHT_NEXT) +#define MCHT_CALENDARDATEPREV (MCHT_CALENDARDATE | MCHT_PREV) +#define MCHT_CALENDARDAY (MCHT_CALENDAR | 0x2) +#define MCHT_CALENDARWEEKNUM (MCHT_CALENDAR | 0x3) -typedef struct tagNMDATETIMEFORMATA -{ +#define MCM_SETFIRSTDAYOFWEEK (MCM_FIRST+15) +#define MonthCal_SetFirstDayOfWeek(hmc,iDay) SNDMSG(hmc,MCM_SETFIRSTDAYOFWEEK,0,iDay) +#define MCM_GETFIRSTDAYOFWEEK (MCM_FIRST+16) +#define MonthCal_GetFirstDayOfWeek(hmc) (DWORD)SNDMSG(hmc,MCM_GETFIRSTDAYOFWEEK,0,0) +#define MCM_GETRANGE (MCM_FIRST+17) +#define MonthCal_GetRange(hmc,rgst) (DWORD)SNDMSG(hmc,MCM_GETRANGE,0,(LPARAM)(rgst)) +#define MCM_SETRANGE (MCM_FIRST+18) +#define MonthCal_SetRange(hmc,gd,rgst) (WINBOOL)SNDMSG(hmc,MCM_SETRANGE,(WPARAM)(gd),(LPARAM)(rgst)) +#define MCM_GETMONTHDELTA (MCM_FIRST+19) +#define MonthCal_GetMonthDelta(hmc) (int)SNDMSG(hmc,MCM_GETMONTHDELTA,0,0) +#define MCM_SETMONTHDELTA (MCM_FIRST+20) +#define MonthCal_SetMonthDelta(hmc,n) (int)SNDMSG(hmc,MCM_SETMONTHDELTA,n,0) +#define MCM_GETMAXTODAYWIDTH (MCM_FIRST+21) +#define MonthCal_GetMaxTodayWidth(hmc) (DWORD)SNDMSG(hmc,MCM_GETMAXTODAYWIDTH,0,0) +#define MCM_SETUNICODEFORMAT CCM_SETUNICODEFORMAT +#define MonthCal_SetUnicodeFormat(hwnd,fUnicode) (WINBOOL)SNDMSG((hwnd),MCM_SETUNICODEFORMAT,(WPARAM)(fUnicode),0) +#define MCM_GETUNICODEFORMAT CCM_GETUNICODEFORMAT +#define MonthCal_GetUnicodeFormat(hwnd) (WINBOOL)SNDMSG((hwnd),MCM_GETUNICODEFORMAT,0,0) + + typedef struct tagNMSELCHANGE { NMHDR nmhdr; - LPCSTR pszFormat; + SYSTEMTIME stSelStart; + SYSTEMTIME stSelEnd; + } NMSELCHANGE,*LPNMSELCHANGE; + +#define MCN_SELCHANGE (MCN_FIRST+1) + + typedef struct tagNMDAYSTATE { + NMHDR nmhdr; + SYSTEMTIME stStart; + int cDayState; + + LPMONTHDAYSTATE prgDayState; + } NMDAYSTATE,*LPNMDAYSTATE; + +#define MCN_GETDAYSTATE (MCN_FIRST+3) + + typedef NMSELCHANGE NMSELECT,*LPNMSELECT; + +#define MCN_SELECT (MCN_FIRST+4) + +#define MCS_DAYSTATE 0x1 +#define MCS_MULTISELECT 0x2 +#define MCS_WEEKNUMBERS 0x4 +#define MCS_NOTODAYCIRCLE 0x8 +#define MCS_NOTODAY 0x10 + +#define GMR_VISIBLE 0 +#define GMR_DAYSTATE 1 +#endif + +#ifndef NODATETIMEPICK +#define DATETIMEPICK_CLASSW L"SysDateTimePick32" +#define DATETIMEPICK_CLASSA "SysDateTimePick32" +#ifdef UNICODE +#define DATETIMEPICK_CLASS DATETIMEPICK_CLASSW +#else +#define DATETIMEPICK_CLASS DATETIMEPICK_CLASSA +#endif +#define DTM_FIRST 0x1000 + +#define DTM_GETSYSTEMTIME (DTM_FIRST+1) +#define DateTime_GetSystemtime(hdp,pst) (DWORD)SNDMSG(hdp,DTM_GETSYSTEMTIME,0,(LPARAM)(pst)) +#define DTM_SETSYSTEMTIME (DTM_FIRST+2) +#define DateTime_SetSystemtime(hdp,gd,pst) (WINBOOL)SNDMSG(hdp,DTM_SETSYSTEMTIME,(WPARAM)(gd),(LPARAM)(pst)) +#define DTM_GETRANGE (DTM_FIRST+3) +#define DateTime_GetRange(hdp,rgst) (DWORD)SNDMSG(hdp,DTM_GETRANGE,0,(LPARAM)(rgst)) +#define DTM_SETRANGE (DTM_FIRST+4) +#define DateTime_SetRange(hdp,gd,rgst) (WINBOOL)SNDMSG(hdp,DTM_SETRANGE,(WPARAM)(gd),(LPARAM)(rgst)) +#define DTM_SETFORMATA (DTM_FIRST+5) +#define DTM_SETFORMATW (DTM_FIRST+50) + +#ifdef UNICODE +#define DTM_SETFORMAT DTM_SETFORMATW +#else +#define DTM_SETFORMAT DTM_SETFORMATA +#endif + +#define DateTime_SetFormat(hdp,sz) (WINBOOL)SNDMSG(hdp,DTM_SETFORMAT,0,(LPARAM)(sz)) + +#define DTM_SETMCCOLOR (DTM_FIRST+6) +#define DateTime_SetMonthCalColor(hdp,iColor,clr) SNDMSG(hdp,DTM_SETMCCOLOR,iColor,clr) +#define DTM_GETMCCOLOR (DTM_FIRST+7) +#define DateTime_GetMonthCalColor(hdp,iColor) SNDMSG(hdp,DTM_GETMCCOLOR,iColor,0) +#define DTM_GETMONTHCAL (DTM_FIRST+8) +#define DateTime_GetMonthCal(hdp) (HWND)SNDMSG(hdp,DTM_GETMONTHCAL,0,0) +#define DTM_SETMCFONT (DTM_FIRST+9) +#define DateTime_SetMonthCalFont(hdp,hfont,fRedraw) SNDMSG(hdp,DTM_SETMCFONT,(WPARAM)(hfont),(LPARAM)(fRedraw)) +#define DTM_GETMCFONT (DTM_FIRST+10) +#define DateTime_GetMonthCalFont(hdp) SNDMSG(hdp,DTM_GETMCFONT,0,0) + +#define DTS_UPDOWN 0x1 +#define DTS_SHOWNONE 0x2 +#define DTS_SHORTDATEFORMAT 0x0 +#define DTS_LONGDATEFORMAT 0x4 +#define DTS_SHORTDATECENTURYFORMAT 0xc +#define DTS_TIMEFORMAT 0x9 +#define DTS_APPCANPARSE 0x10 +#define DTS_RIGHTALIGN 0x20 + +#define DTN_DATETIMECHANGE (DTN_FIRST+1) + typedef struct tagNMDATETIMECHANGE { + NMHDR nmhdr; + DWORD dwFlags; + SYSTEMTIME st; + } NMDATETIMECHANGE,*LPNMDATETIMECHANGE; + +#define DTN_USERSTRINGA (DTN_FIRST+2) +#define DTN_USERSTRINGW (DTN_FIRST+15) + typedef struct tagNMDATETIMESTRINGA { + NMHDR nmhdr; + LPCSTR pszUserString; + SYSTEMTIME st; + DWORD dwFlags; + } NMDATETIMESTRINGA,*LPNMDATETIMESTRINGA; + + typedef struct tagNMDATETIMESTRINGW { + NMHDR nmhdr; + LPCWSTR pszUserString; + SYSTEMTIME st; + DWORD dwFlags; + } NMDATETIMESTRINGW,*LPNMDATETIMESTRINGW; + +#ifdef UNICODE +#define DTN_USERSTRING DTN_USERSTRINGW +#define NMDATETIMESTRING NMDATETIMESTRINGW +#define LPNMDATETIMESTRING LPNMDATETIMESTRINGW +#else +#define DTN_USERSTRING DTN_USERSTRINGA +#define NMDATETIMESTRING NMDATETIMESTRINGA +#define LPNMDATETIMESTRING LPNMDATETIMESTRINGA +#endif + +#define DTN_WMKEYDOWNA (DTN_FIRST+3) +#define DTN_WMKEYDOWNW (DTN_FIRST+16) + typedef struct tagNMDATETIMEWMKEYDOWNA { + NMHDR nmhdr; + int nVirtKey; + LPCSTR pszFormat; + SYSTEMTIME st; + } NMDATETIMEWMKEYDOWNA,*LPNMDATETIMEWMKEYDOWNA; + + typedef struct tagNMDATETIMEWMKEYDOWNW { + NMHDR nmhdr; + int nVirtKey; + LPCWSTR pszFormat; + SYSTEMTIME st; + } NMDATETIMEWMKEYDOWNW,*LPNMDATETIMEWMKEYDOWNW; + +#ifdef UNICODE +#define DTN_WMKEYDOWN DTN_WMKEYDOWNW +#define NMDATETIMEWMKEYDOWN NMDATETIMEWMKEYDOWNW +#define LPNMDATETIMEWMKEYDOWN LPNMDATETIMEWMKEYDOWNW +#else +#define DTN_WMKEYDOWN DTN_WMKEYDOWNA +#define NMDATETIMEWMKEYDOWN NMDATETIMEWMKEYDOWNA +#define LPNMDATETIMEWMKEYDOWN LPNMDATETIMEWMKEYDOWNA +#endif + +#define DTN_FORMATA (DTN_FIRST+4) +#define DTN_FORMATW (DTN_FIRST+17) + typedef struct tagNMDATETIMEFORMATA { + NMHDR nmhdr; + LPCSTR pszFormat; SYSTEMTIME st; LPCSTR pszDisplay; CHAR szDisplay[64]; -} NMDATETIMEFORMATA, *LPNMDATETIMEFORMATA; + } NMDATETIMEFORMATA,*LPNMDATETIMEFORMATA; - -typedef struct tagNMDATETIMEFORMATW -{ + typedef struct tagNMDATETIMEFORMATW { NMHDR nmhdr; LPCWSTR pszFormat; SYSTEMTIME st; LPCWSTR pszDisplay; WCHAR szDisplay[64]; -} NMDATETIMEFORMATW, *LPNMDATETIMEFORMATW; + } NMDATETIMEFORMATW,*LPNMDATETIMEFORMATW; -DECL_WINELIB_TYPE_AW(NMDATETIMEFORMAT) -DECL_WINELIB_TYPE_AW(LPNMDATETIMEFORMAT) +#ifdef UNICODE +#define DTN_FORMAT DTN_FORMATW +#define NMDATETIMEFORMAT NMDATETIMEFORMATW +#define LPNMDATETIMEFORMAT LPNMDATETIMEFORMATW +#else +#define DTN_FORMAT DTN_FORMATA +#define NMDATETIMEFORMAT NMDATETIMEFORMATA +#define LPNMDATETIMEFORMAT LPNMDATETIMEFORMATA +#endif -typedef struct tagNMDATETIMEFORMATQUERYA -{ +#define DTN_FORMATQUERYA (DTN_FIRST+5) +#define DTN_FORMATQUERYW (DTN_FIRST+18) + typedef struct tagNMDATETIMEFORMATQUERYA { NMHDR nmhdr; LPCSTR pszFormat; SIZE szMax; -} NMDATETIMEFORMATQUERYA, *LPNMDATETIMEFORMATQUERYA; + } NMDATETIMEFORMATQUERYA,*LPNMDATETIMEFORMATQUERYA; -typedef struct tagNMDATETIMEFORMATQUERYW -{ + typedef struct tagNMDATETIMEFORMATQUERYW { NMHDR nmhdr; LPCWSTR pszFormat; SIZE szMax; -} NMDATETIMEFORMATQUERYW, *LPNMDATETIMEFORMATQUERYW; + } NMDATETIMEFORMATQUERYW,*LPNMDATETIMEFORMATQUERYW; -DECL_WINELIB_TYPE_AW(NMDATETIMEFORMATQUERY) -DECL_WINELIB_TYPE_AW(LPNMDATETIMEFORMATQUERY) +#ifdef UNICODE +#define DTN_FORMATQUERY DTN_FORMATQUERYW +#define NMDATETIMEFORMATQUERY NMDATETIMEFORMATQUERYW +#define LPNMDATETIMEFORMATQUERY LPNMDATETIMEFORMATQUERYW +#else +#define DTN_FORMATQUERY DTN_FORMATQUERYA +#define NMDATETIMEFORMATQUERY NMDATETIMEFORMATQUERYA +#define LPNMDATETIMEFORMATQUERY LPNMDATETIMEFORMATQUERYA +#endif +#define DTN_DROPDOWN (DTN_FIRST+6) +#define DTN_CLOSEUP (DTN_FIRST+7) +#define GDTR_MIN 0x1 +#define GDTR_MAX 0x2 -#define GDT_ERROR -1 -#define GDT_VALID 0 -#define GDT_NONE 1 +#define GDT_ERROR -1 +#define GDT_VALID 0 +#define GDT_NONE 1 -#define GDTR_MIN 0x0001 -#define GDTR_MAX 0x0002 +#ifndef NOIPADDRESS +#define IPM_CLEARADDRESS (WM_USER+100) +#define IPM_SETADDRESS (WM_USER+101) +#define IPM_GETADDRESS (WM_USER+102) +#define IPM_SETRANGE (WM_USER+103) +#define IPM_SETFOCUS (WM_USER+104) +#define IPM_ISBLANK (WM_USER+105) +#define WC_IPADDRESSW L"SysIPAddress32" +#define WC_IPADDRESSA "SysIPAddress32" -#define DateTime_GetSystemtime(hdp, pst) \ - (DWORD)SNDMSG (hdp, DTM_GETSYSTEMTIME , 0, (LPARAM)(pst)) -#define DateTime_SetSystemtime(hdp, gd, pst) \ - (BOOL)SNDMSG (hdp, DTM_SETSYSTEMTIME, (LPARAM)(gd), (LPARAM)(pst)) -#define DateTime_GetRange(hdp, rgst) \ - (DWORD)SNDMSG (hdp, DTM_GETRANGE, 0, (LPARAM)(rgst)) -#define DateTime_SetRange(hdp, gd, rgst) \ - (BOOL)SNDMSG (hdp, DTM_SETRANGE, (WPARAM)(gd), (LPARAM)(rgst)) -#define DateTime_SetFormatA(hdp, sz) \ - (BOOL)SNDMSGA (hdp, DTM_SETFORMATA, 0, (LPARAM)(sz)) -#define DateTime_SetFormatW(hdp, sz) \ - (BOOL)SNDMSGW (hdp, DTM_SETFORMATW, 0, (LPARAM)(sz)) -#define DateTime_SetFormat WINELIB_NAME_AW(DateTime_SetFormat) -#define DateTime_GetMonthCalColor(hdp, iColor) \ - SNDMSG (hdp, DTM_GETMCCOLOR, iColor, 0) -#define DateTime_SetMonthCalColor(hdp, iColor, clr) \ - SNDMSG (hdp, DTM_SETMCCOLOR, iColor, clr) -#define DateTime_GetMonthCal(hdp) \ - (HWND) SNDMSG (hdp, DTM_GETMONTHCAL, 0, 0) -#define DateTime_SetMonthCalFont(hdp, hfont, fRedraw) \ - SNDMSG (hdp, DTM_SETMCFONT, (WPARAM)hfont, (LPARAM)fRedraw) -#define DateTime_GetMonthCalFont(hdp) \ - SNDMSG (hdp, DTM_GETMCFONT, 0, 0) +#ifdef UNICODE +#define WC_IPADDRESS WC_IPADDRESSW +#else +#define WC_IPADDRESS WC_IPADDRESSA +#endif -#define DA_LAST (0x7fffffff) -#define DPA_APPEND (0x7fffffff) -#define DPA_ERR (-1) +#define IPN_FIELDCHANGED (IPN_FIRST - 0) + typedef struct tagNMIPADDRESS { + NMHDR hdr; + int iField; + int iValue; + } NMIPADDRESS,*LPNMIPADDRESS; -#define DSA_APPEND (0x7fffffff) -#define DSA_ERR (-1) +#define MAKEIPRANGE(low,high) ((LPARAM)(WORD)(((BYTE)(high) << 8)+(BYTE)(low))) -struct _DSA; -typedef struct _DSA *HDSA; +#define MAKEIPADDRESS(b1,b2,b3,b4) ((LPARAM)(((DWORD)(b1)<<24)+((DWORD)(b2)<<16)+((DWORD)(b3)<<8)+((DWORD)(b4)))) -typedef INT (CALLBACK *PFNDSAENUMCALLBACK)(LPVOID, LPVOID); +#define FIRST_IPADDRESS(x) ((x>>24) & 0xff) +#define SECOND_IPADDRESS(x) ((x>>16) & 0xff) +#define THIRD_IPADDRESS(x) ((x>>8) & 0xff) +#define FOURTH_IPADDRESS(x) (x & 0xff) +#endif -HDSA WINAPI DSA_Create(INT, INT); -BOOL WINAPI DSA_Destroy(HDSA); -void WINAPI DSA_DestroyCallback(HDSA, PFNDSAENUMCALLBACK, LPVOID); -LPVOID WINAPI DSA_GetItemPtr(HDSA, INT); -INT WINAPI DSA_InsertItem(HDSA, INT, LPVOID); +#ifndef NOPAGESCROLLER +#define WC_PAGESCROLLERW L"SysPager" +#define WC_PAGESCROLLERA "SysPager" -#define DPAS_SORTED 0x0001 -#define DPAS_INSERTBEFORE 0x0002 -#define DPAS_INSERTAFTER 0x0004 +#ifdef UNICODE +#define WC_PAGESCROLLER WC_PAGESCROLLERW +#else +#define WC_PAGESCROLLER WC_PAGESCROLLERA +#endif +#define PGS_VERT 0x0 +#define PGS_HORZ 0x1 +#define PGS_AUTOSCROLL 0x2 +#define PGS_DRAGNDROP 0x4 -struct _DPA; -typedef struct _DPA *HDPA; +#define PGF_INVISIBLE 0 +#define PGF_NORMAL 1 +#define PGF_GRAYED 2 +#define PGF_DEPRESSED 4 +#define PGF_HOT 8 -#define DPA_GetPtrCount(hdpa) (*(INT*)(hdpa)) +#define PGB_TOPORLEFT 0 +#define PGB_BOTTOMORRIGHT 1 -typedef INT (CALLBACK *PFNDPAENUMCALLBACK)(LPVOID, LPVOID); -typedef INT (CALLBACK *PFNDPACOMPARE)(LPVOID, LPVOID, LPARAM); -typedef PVOID (CALLBACK *PFNDPAMERGE)(UINT,PVOID,PVOID,LPARAM); +#define PGM_SETCHILD (PGM_FIRST+1) +#define Pager_SetChild(hwnd,hwndChild) (void)SNDMSG((hwnd),PGM_SETCHILD,0,(LPARAM)(hwndChild)) -/* merge callback codes */ -#define DPAMM_MERGE 1 -#define DPAMM_DELETE 2 -#define DPAMM_INSERT 3 +#define PGM_RECALCSIZE (PGM_FIRST+2) +#define Pager_RecalcSize(hwnd) (void)SNDMSG((hwnd),PGM_RECALCSIZE,0,0) -/* merge options */ -#define DPAM_SORTED 0x00000001 -#define DPAM_NORMAL 0x00000002 -#define DPAM_UNION 0x00000004 -#define DPAM_INTERSECT 0x00000008 +#define PGM_FORWARDMOUSE (PGM_FIRST+3) +#define Pager_ForwardMouse(hwnd,bForward) (void)SNDMSG((hwnd),PGM_FORWARDMOUSE,(WPARAM)(bForward),0) -HDPA WINAPI DPA_Create(INT); -BOOL WINAPI DPA_Destroy(HDPA); -LPVOID WINAPI DPA_DeletePtr(HDPA, INT); -BOOL WINAPI DPA_DeleteAllPtrs(HDPA); -BOOL WINAPI DPA_SetPtr(HDPA, INT, LPVOID); -LPVOID WINAPI DPA_GetPtr(HDPA, INT); -INT WINAPI DPA_GetPtrIndex(HDPA, LPCVOID); -ULONGLONG WINAPI DPA_GetSize(HDPA); -BOOL WINAPI DPA_Grow(HDPA, INT); -INT WINAPI DPA_InsertPtr(HDPA, INT, LPVOID); -BOOL WINAPI DPA_Sort(HDPA, PFNDPACOMPARE, LPARAM); -void WINAPI DPA_EnumCallback(HDPA, PFNDPAENUMCALLBACK, LPVOID); -void WINAPI DPA_DestroyCallback(HDPA, PFNDPAENUMCALLBACK, LPVOID); -INT WINAPI DPA_Search(HDPA, LPVOID, INT, PFNDPACOMPARE, LPARAM, UINT); -BOOL WINAPI DPA_Merge(HDPA, HDPA, DWORD, PFNDPACOMPARE, PFNDPAMERGE, LPARAM); +#define PGM_SETBKCOLOR (PGM_FIRST+4) +#define Pager_SetBkColor(hwnd,clr) (COLORREF)SNDMSG((hwnd),PGM_SETBKCOLOR,0,(LPARAM)(clr)) -/* save/load from stream */ -typedef struct _DPASTREAMINFO -{ - INT iPos; /* item index */ - LPVOID pvItem; +#define PGM_GETBKCOLOR (PGM_FIRST+5) +#define Pager_GetBkColor(hwnd) (COLORREF)SNDMSG((hwnd),PGM_GETBKCOLOR,0,0) + +#define PGM_SETBORDER (PGM_FIRST+6) +#define Pager_SetBorder(hwnd,iBorder) (int)SNDMSG((hwnd),PGM_SETBORDER,0,(LPARAM)(iBorder)) + +#define PGM_GETBORDER (PGM_FIRST+7) +#define Pager_GetBorder(hwnd) (int)SNDMSG((hwnd),PGM_GETBORDER,0,0) + +#define PGM_SETPOS (PGM_FIRST+8) +#define Pager_SetPos(hwnd,iPos) (int)SNDMSG((hwnd),PGM_SETPOS,0,(LPARAM)(iPos)) + +#define PGM_GETPOS (PGM_FIRST+9) +#define Pager_GetPos(hwnd) (int)SNDMSG((hwnd),PGM_GETPOS,0,0) + +#define PGM_SETBUTTONSIZE (PGM_FIRST+10) +#define Pager_SetButtonSize(hwnd,iSize) (int)SNDMSG((hwnd),PGM_SETBUTTONSIZE,0,(LPARAM)(iSize)) + +#define PGM_GETBUTTONSIZE (PGM_FIRST+11) +#define Pager_GetButtonSize(hwnd) (int)SNDMSG((hwnd),PGM_GETBUTTONSIZE,0,0) + +#define PGM_GETBUTTONSTATE (PGM_FIRST+12) +#define Pager_GetButtonState(hwnd,iButton) (DWORD)SNDMSG((hwnd),PGM_GETBUTTONSTATE,0,(LPARAM)(iButton)) + +#define PGM_GETDROPTARGET CCM_GETDROPTARGET +#define Pager_GetDropTarget(hwnd,ppdt) (void)SNDMSG((hwnd),PGM_GETDROPTARGET,0,(LPARAM)(ppdt)) + +#define PGN_SCROLL (PGN_FIRST-1) + +#define PGF_SCROLLUP 1 +#define PGF_SCROLLDOWN 2 +#define PGF_SCROLLLEFT 4 +#define PGF_SCROLLRIGHT 8 + +#define PGK_SHIFT 1 +#define PGK_CONTROL 2 +#define PGK_MENU 4 + +#include + + typedef struct { + NMHDR hdr; + WORD fwKeys; + RECT rcParent; + int iDir; + int iXpos; + int iYpos; + int iScroll; + }NMPGSCROLL,*LPNMPGSCROLL; + +#include + +#define PGN_CALCSIZE (PGN_FIRST-2) + +#define PGF_CALCWIDTH 1 +#define PGF_CALCHEIGHT 2 + + typedef struct { + NMHDR hdr; + DWORD dwFlag; + int iWidth; + int iHeight; + }NMPGCALCSIZE,*LPNMPGCALCSIZE; + +#define PGN_HOTITEMCHANGE (PGN_FIRST-3) + + typedef struct tagNMPGHOTITEM + { + NMHDR hdr; + int idOld; + int idNew; + DWORD dwFlags; + } NMPGHOTITEM,*LPNMPGHOTITEM; +#endif + +#ifndef NONATIVEFONTCTL + +#define WC_NATIVEFONTCTLW L"NativeFontCtl" +#define WC_NATIVEFONTCTLA "NativeFontCtl" + +#ifdef UNICODE +#define WC_NATIVEFONTCTL WC_NATIVEFONTCTLW +#else +#define WC_NATIVEFONTCTL WC_NATIVEFONTCTLA +#endif + +#define NFS_EDIT 0x1 +#define NFS_STATIC 0x2 +#define NFS_LISTCOMBO 0x4 +#define NFS_BUTTON 0x8 +#define NFS_ALL 0x10 +#define NFS_USEFONTASSOC 0x20 +#endif + +#ifndef NOBUTTON +#define WC_BUTTONA "Button" +#define WC_BUTTONW L"Button" +#ifdef UNICODE +#define WC_BUTTON WC_BUTTONW +#else +#define WC_BUTTON WC_BUTTONA +#endif + +#define BUTTON_IMAGELIST_ALIGN_LEFT 0 +#define BUTTON_IMAGELIST_ALIGN_RIGHT 1 +#define BUTTON_IMAGELIST_ALIGN_TOP 2 +#define BUTTON_IMAGELIST_ALIGN_BOTTOM 3 +#define BUTTON_IMAGELIST_ALIGN_CENTER 4 + + typedef struct { + HIMAGELIST himl; + RECT margin; + UINT uAlign; + } BUTTON_IMAGELIST,*PBUTTON_IMAGELIST; + +#define BCM_GETIDEALSIZE (BCM_FIRST+0x1) +#define Button_GetIdealSize(hwnd,psize) (WINBOOL)SNDMSG((hwnd),BCM_GETIDEALSIZE,0,(LPARAM)(psize)) + +#define BCM_SETIMAGELIST (BCM_FIRST+0x2) +#define Button_SetImageList(hwnd,pbuttonImagelist) (WINBOOL)SNDMSG((hwnd),BCM_SETIMAGELIST,0,(LPARAM)(pbuttonImagelist)) + +#define BCM_GETIMAGELIST (BCM_FIRST+0x3) +#define Button_GetImageList(hwnd,pbuttonImagelist) (WINBOOL)SNDMSG((hwnd),BCM_GETIMAGELIST,0,(LPARAM)(pbuttonImagelist)) + +#define BCM_SETTEXTMARGIN (BCM_FIRST+0x4) +#define Button_SetTextMargin(hwnd,pmargin) (WINBOOL)SNDMSG((hwnd),BCM_SETTEXTMARGIN,0,(LPARAM)(pmargin)) +#define BCM_GETTEXTMARGIN (BCM_FIRST+0x5) +#define Button_GetTextMargin(hwnd,pmargin) (WINBOOL)SNDMSG((hwnd),BCM_GETTEXTMARGIN,0,(LPARAM)(pmargin)) + + typedef struct tagNMBCHOTITEM { + NMHDR hdr; + DWORD dwFlags; + } NMBCHOTITEM,*LPNMBCHOTITEM; + +#define BCN_HOTITEMCHANGE (BCN_FIRST+0x1) + +#define BST_HOT 0x200 + +#endif + +#ifndef NOSTATIC +#define WC_STATICA "Static" +#define WC_STATICW L"Static" +#ifdef UNICODE +#define WC_STATIC WC_STATICW +#else +#define WC_STATIC WC_STATICA +#endif + +#ifndef NOEDIT +#define WC_EDITA "Edit" +#define WC_EDITW L"Edit" +#ifdef UNICODE +#define WC_EDIT WC_EDITW +#else +#define WC_EDIT WC_EDITA +#endif + +#define EM_SETCUEBANNER (ECM_FIRST+1) +#define Edit_SetCueBannerText(hwnd,lpcwText) (WINBOOL)SNDMSG((hwnd),EM_SETCUEBANNER,0,(LPARAM)(lpcwText)) +#define EM_GETCUEBANNER (ECM_FIRST+2) +#define Edit_GetCueBannerText(hwnd,lpwText,cchText) (WINBOOL)SNDMSG((hwnd),EM_GETCUEBANNER,(WPARAM)(lpwText),(LPARAM)(cchText)) + + typedef struct _tagEDITBALLOONTIP { + DWORD cbStruct; + LPCWSTR pszTitle; + LPCWSTR pszText; + INT ttiIcon; + } EDITBALLOONTIP,*PEDITBALLOONTIP; +#define EM_SHOWBALLOONTIP (ECM_FIRST+3) +#define Edit_ShowBalloonTip(hwnd,peditballoontip) (WINBOOL)SNDMSG((hwnd),EM_SHOWBALLOONTIP,0,(LPARAM)(peditballoontip)) +#define EM_HIDEBALLOONTIP (ECM_FIRST+4) +#define Edit_HideBalloonTip(hwnd) (WINBOOL)SNDMSG((hwnd),EM_HIDEBALLOONTIP,0,0) +#endif + +#ifndef NOLISTBOX +#define WC_LISTBOXA "ListBox" +#define WC_LISTBOXW L"ListBox" +#ifdef UNICODE +#define WC_LISTBOX WC_LISTBOXW +#else +#define WC_LISTBOX WC_LISTBOXA +#endif +#endif + +#ifndef NOCOMBOBOX +#define WC_COMBOBOXA "ComboBox" +#define WC_COMBOBOXW L"ComboBox" +#ifdef UNICODE +#define WC_COMBOBOX WC_COMBOBOXW +#else +#define WC_COMBOBOX WC_COMBOBOXA +#endif +#endif + +#define CB_SETMINVISIBLE (CBM_FIRST+1) +#define CB_GETMINVISIBLE (CBM_FIRST+2) + +#define ComboBox_SetMinVisible(hwnd,iMinVisible) (WINBOOL)SNDMSG((hwnd),CB_SETMINVISIBLE,(WPARAM)iMinVisible,0) +#define ComboBox_GetMinVisible(hwnd) (int)SNDMSG((hwnd),CB_GETMINVISIBLE,0,0) + +#ifndef NOSCROLLBAR +#define WC_SCROLLBARA "ScrollBar" +#define WC_SCROLLBARW L"ScrollBar" +#ifdef UNICODE +#define WC_SCROLLBAR WC_SCROLLBARW +#else +#define WC_SCROLLBAR WC_SCROLLBARA +#endif +#endif + +#define INVALID_LINK_INDEX (-1) +#define MAX_LINKID_TEXT 48 +#define L_MAX_URL_LENGTH (2048+32+sizeof("://")) + +#define WC_LINK L"SysLink" + +#define LWS_TRANSPARENT 0x1 +#define LWS_IGNORERETURN 0x2 + +#define LIF_ITEMINDEX 0x1 +#define LIF_STATE 0x2 +#define LIF_ITEMID 0x4 +#define LIF_URL 0x8 + +#define LIS_FOCUSED 0x1 +#define LIS_ENABLED 0x2 +#define LIS_VISITED 0x4 + + typedef struct tagLITEM { + UINT mask; + int iLink; + UINT state; + UINT stateMask; + WCHAR szID[MAX_LINKID_TEXT]; + WCHAR szUrl[L_MAX_URL_LENGTH]; + } LITEM,*PLITEM; + + typedef struct tagLHITTESTINFO { + POINT pt; + LITEM item; + } LHITTESTINFO,*PLHITTESTINFO; + + typedef struct tagNMLINK { + NMHDR hdr; + LITEM item; + } NMLINK,*PNMLINK; + +#define LM_HITTEST (WM_USER+0x300) +#define LM_GETIDEALHEIGHT (WM_USER+0x301) +#define LM_SETITEM (WM_USER+0x302) +#define LM_GETITEM (WM_USER+0x303) + +#ifndef NOMUI + void WINAPI InitMUILanguage(LANGID uiLang); + LANGID WINAPI GetMUILanguage(void); +#endif +#endif + +#define DA_LAST (0x7fffffff) +#define DPA_APPEND (0x7fffffff) +#define DPA_ERR (-1) + +#define DSA_APPEND (0x7fffffff) +#define DSA_ERR (-1) + + typedef struct _DSA *HDSA; + + typedef int (CALLBACK *PFNDPAENUMCALLBACK)(void *p,void *pData); + typedef int (CALLBACK *PFNDSAENUMCALLBACK)(void *p,void *pData); + + WINCOMMCTRLAPI HDSA WINAPI DSA_Create(int cbItem,int cItemGrow); + WINCOMMCTRLAPI WINBOOL WINAPI DSA_Destroy(HDSA hdsa); + WINCOMMCTRLAPI void WINAPI DSA_DestroyCallback(HDSA hdsa,PFNDSAENUMCALLBACK pfnCB,void *pData); + WINCOMMCTRLAPI PVOID WINAPI DSA_GetItemPtr(HDSA hdsa,int i); + WINCOMMCTRLAPI int WINAPI DSA_InsertItem(HDSA hdsa,int i,void *pitem); + + typedef struct _DPA *HDPA; + + WINCOMMCTRLAPI HDPA WINAPI DPA_Create(int cItemGrow); + WINCOMMCTRLAPI WINBOOL WINAPI DPA_Destroy(HDPA hdpa); + WINCOMMCTRLAPI PVOID WINAPI DPA_DeletePtr(HDPA hdpa,int i); + WINCOMMCTRLAPI WINBOOL WINAPI DPA_DeleteAllPtrs(HDPA hdpa); + WINCOMMCTRLAPI void WINAPI DPA_EnumCallback(HDPA hdpa,PFNDPAENUMCALLBACK pfnCB,void *pData); + WINCOMMCTRLAPI void WINAPI DPA_DestroyCallback(HDPA hdpa,PFNDPAENUMCALLBACK pfnCB,void *pData); + WINCOMMCTRLAPI WINBOOL WINAPI DPA_SetPtr(HDPA hdpa,int i,void *p); + WINCOMMCTRLAPI int WINAPI DPA_InsertPtr(HDPA hdpa,int i,void *p); + WINCOMMCTRLAPI PVOID WINAPI DPA_GetPtr(HDPA hdpa,INT_PTR i); + + typedef int (CALLBACK *PFNDPACOMPARE)(void *p1,void *p2,LPARAM lParam); + + WINCOMMCTRLAPI WINBOOL WINAPI DPA_Sort(HDPA hdpa,PFNDPACOMPARE pfnCompare,LPARAM lParam); + +#define DPAS_SORTED 0x1 +#define DPAS_INSERTBEFORE 0x2 +#define DPAS_INSERTAFTER 0x4 + + WINCOMMCTRLAPI int WINAPI DPA_Search(HDPA hdpa,void *pFind,int iStart,PFNDPACOMPARE pfnCompare,LPARAM lParam,UINT options); + WINCOMMCTRLAPI WINBOOL WINAPI Str_SetPtrW(LPWSTR *ppsz,LPCWSTR psz); + +#ifndef NOTRACKMOUSEEVENT + +#ifndef WM_MOUSEHOVER +#define WM_MOUSEHOVER 0x2a1 +#define WM_MOUSELEAVE 0x2a3 +#endif + +#ifndef TME_HOVER + +#define TME_HOVER 0x1 +#define TME_LEAVE 0x2 +#define TME_NONCLIENT 0x10 +#define TME_QUERY 0x40000000 +#define TME_CANCEL 0x80000000 + +#define HOVER_DEFAULT 0xffffffff + + typedef struct tagTRACKMOUSEEVENT { + DWORD cbSize; + DWORD dwFlags; + HWND hwndTrack; + DWORD dwHoverTime; + } TRACKMOUSEEVENT,*LPTRACKMOUSEEVENT; +#endif + + WINCOMMCTRLAPI WINBOOL WINAPI _TrackMouseEvent(LPTRACKMOUSEEVENT lpEventTrack); +#endif + +#ifndef NOFLATSBAPIS + +#define WSB_PROP_CYVSCROLL 0x1L +#define WSB_PROP_CXHSCROLL 0x2L +#define WSB_PROP_CYHSCROLL 0x4L +#define WSB_PROP_CXVSCROLL 0x8L +#define WSB_PROP_CXHTHUMB 0x10L +#define WSB_PROP_CYVTHUMB 0x20L +#define WSB_PROP_VBKGCOLOR 0x40L +#define WSB_PROP_HBKGCOLOR 0x80L +#define WSB_PROP_VSTYLE 0x100L +#define WSB_PROP_HSTYLE 0x200L +#define WSB_PROP_WINSTYLE 0x400L +#define WSB_PROP_PALETTE 0x800L +#define WSB_PROP_MASK 0xfffL + +#define FSB_FLAT_MODE 2 +#define FSB_ENCARTA_MODE 1 +#define FSB_REGULAR_MODE 0 + + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_EnableScrollBar(HWND,int,UINT); + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_ShowScrollBar(HWND,int code,WINBOOL); + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_GetScrollRange(HWND,int code,LPINT,LPINT); + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_GetScrollInfo(HWND,int code,LPSCROLLINFO); + WINCOMMCTRLAPI int WINAPI FlatSB_GetScrollPos(HWND,int code); + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_GetScrollProp(HWND,int propIndex,LPINT); +#ifdef _WIN64 + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_GetScrollPropPtr(HWND,int propIndex,PINT_PTR); +#else +#define FlatSB_GetScrollPropPtr FlatSB_GetScrollProp +#endif + + WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollPos(HWND,int code,int pos,WINBOOL fRedraw); + WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollInfo(HWND,int code,LPSCROLLINFO,WINBOOL fRedraw); + WINCOMMCTRLAPI int WINAPI FlatSB_SetScrollRange(HWND,int code,int min,int max,WINBOOL fRedraw); + WINCOMMCTRLAPI WINBOOL WINAPI FlatSB_SetScrollProp(HWND,UINT index,INT_PTR newValue,WINBOOL); +#define FlatSB_SetScrollPropPtr FlatSB_SetScrollProp + WINCOMMCTRLAPI WINBOOL WINAPI InitializeFlatSB(HWND); + WINCOMMCTRLAPI HRESULT WINAPI UninitializeFlatSB(HWND); +#endif +#endif + + typedef LRESULT (CALLBACK *SUBCLASSPROC)(HWND hWnd,UINT uMsg,WPARAM wParam,LPARAM lParam,UINT_PTR uIdSubclass,DWORD_PTR dwRefData); + + WINBOOL WINAPI SetWindowSubclass(HWND hWnd,SUBCLASSPROC pfnSubclass,UINT_PTR uIdSubclass,DWORD_PTR dwRefData); + WINBOOL WINAPI GetWindowSubclass(HWND hWnd,SUBCLASSPROC pfnSubclass,UINT_PTR uIdSubclass,DWORD_PTR *pdwRefData); + WINBOOL WINAPI RemoveWindowSubclass(HWND hWnd,SUBCLASSPROC pfnSubclass,UINT_PTR uIdSubclass); + LRESULT WINAPI DefSubclassProc(HWND hWnd,UINT uMsg,WPARAM wParam,LPARAM lParam); + int WINAPI DrawShadowText(HDC hdc,LPCWSTR pszText,UINT cch,RECT *prc,DWORD dwFlags,COLORREF crText,COLORREF crShadow,int ixOffset,int iyOffset); + +typedef struct _DPASTREAMINFO { + int iPos; + void *pvItem; } DPASTREAMINFO; struct IStream; -typedef HRESULT (CALLBACK *PFNDPASTREAM)(DPASTREAMINFO*, struct IStream*, LPVOID); +typedef HRESULT (CALLBACK *PFNDPASTREAM)(DPASTREAMINFO*, struct IStream*, void*); +typedef void* (CALLBACK *PFNDPAMERGE)(UINT, void*, void*, LPARAM); +typedef const void* (CALLBACK *PFNDPAMERGECONST)(UINT, const void*, const void*, LPARAM); -HRESULT WINAPI DPA_LoadStream(HDPA*, PFNDPASTREAM, struct IStream*, LPVOID); -HRESULT WINAPI DPA_SaveStream(HDPA, PFNDPASTREAM, struct IStream*, LPVOID); + WINCOMMCTRLAPI HRESULT WINAPI DPA_LoadStream(HDPA * phdpa, PFNDPASTREAM pfn, struct IStream * pstream, void *pvInstData); + WINCOMMCTRLAPI HRESULT WINAPI DPA_SaveStream(HDPA hdpa, PFNDPASTREAM pfn, struct IStream * pstream, void *pvInstData); + WINCOMMCTRLAPI BOOL WINAPI DPA_Grow(HDPA pdpa, IN int cp); + WINCOMMCTRLAPI int WINAPI DPA_InsertPtr(HDPA hdpa, IN int i, void *p); + WINCOMMCTRLAPI PVOID WINAPI DPA_GetPtr(HDPA hdpa, INT_PTR i); + WINCOMMCTRLAPI BOOL WINAPI DPA_SetPtr(HDPA hdpa, IN int i, void *p); + WINCOMMCTRLAPI int WINAPI DPA_GetPtrIndex(HDPA hdpa, const void *p); -BOOL WINAPI Str_SetPtrW (LPWSTR *, LPCWSTR); +#define DPA_GetPtrCount(hdpa) (*(int *)(hdpa)) +#define DPA_SetPtrCount(hdpa, cItems) (*(int *)(hdpa) = (cItems)) +#define DPA_GetPtrPtr(hdpa) (*((void * **)((BYTE *)(hdpa) + sizeof(void *)))) +#define DPA_AppendPtr(hdpa, pitem) DPA_InsertPtr(hdpa, DA_LAST, pitem) +#define DPA_FastDeleteLastPtr(hdpa) (--*(int *)(hdpa)) +#define DPA_FastGetPtr(hdpa, i) (DPA_GetPtrPtr(hdpa)[i]) -/************************************************************************** - * SysLink control - */ +#define DPAM_SORTED 1 +#define DPAM_NORMAL 2 +#define DPAM_UNION 4 +#define DPAM_INTERSECT 8 -#if defined(__GNUC__) -# define WC_LINK (const WCHAR []){ 'S','y','s','L','i','n','k',0 } -#elif defined(_MSC_VER) -# define WC_LINK L"SysLink" -#else -static const WCHAR WC_LINK[] = { 'S','y','s','L','i','n','k',0 }; -#endif - -/* SysLink styles */ -#define LWS_TRANSPARENT 0x0001 -#define LWS_IGNORERETURN 0x0002 - -/* SysLink messages */ -#define LM_HITTEST (WM_USER + 768) -#define LM_GETIDEALHEIGHT (WM_USER + 769) -#define LM_GETIDEALSIZE (LM_GETIDEALHEIGHT) -#define LM_SETITEM (WM_USER + 770) -#define LM_GETITEM (WM_USER + 771) - -/* SysLink links flags */ - -#define LIF_ITEMINDEX 1 -#define LIF_STATE 2 -#define LIF_ITEMID 4 -#define LIF_URL 8 - -/* SysLink links states */ - -#define LIS_FOCUSED 1 -#define LIS_ENABLED 2 -#define LIS_VISITED 4 - -/* SysLink misc. */ - -#define INVALID_LINK_INDEX (-1) -#define MAX_LINKID_TEXT 48 -#define L_MAX_URL_LENGTH 2084 - -/* SysLink structures */ - -typedef struct tagLITEM -{ - UINT mask; - int iLink; - UINT state; - UINT stateMask; - WCHAR szID[MAX_LINKID_TEXT]; - WCHAR szUrl[L_MAX_URL_LENGTH]; -} LITEM, *PLITEM; - -typedef struct tagLHITTESTINFO -{ - POINT pt; - LITEM item; -} LHITTESTINFO, *PLHITTESTINFO; - -typedef struct tagNMLINK -{ - NMHDR hdr; - LITEM item; -} NMLINK, *PNMLINK; - -typedef struct tagNMLVLINK -{ - NMHDR hdr; - LITEM link; - int iItem; - int iSubItem; -} NMLVLINK, *PNMLVLINK; - -/************************************************************************** - * Static control - */ - -#define WC_STATICA "Static" -#if defined(__GNUC__) -# define WC_STATICW (const WCHAR []){ 'S','t','a','t','i','c',0 } -#elif defined(_MSC_VER) -# define WC_STATICW L"Static" -#else -static const WCHAR WC_STATICW[] = { 'S','t','a','t','i','c',0 }; -#endif -#define WC_STATIC WINELIB_NAME_AW(WC_STATIC) - -/************************************************************************** - * Combobox control - */ - -#define WC_COMBOBOXA "ComboBox" -#if defined(__GNUC__) -# define WC_COMBOBOXW (const WCHAR []){ 'C','o','m','b','o','B','o','x',0 } -#elif defined(_MSC_VER) -# define WC_COMBOBOXW L"ComboBox" -#else -static const WCHAR WC_COMBOBOXW[] = { 'C','o','m','b','o','B','o','x',0 }; -#endif -#define WC_COMBOBOX WINELIB_NAME_AW(WC_COMBOBOX) - -/************************************************************************** - * Edit control - */ - -#define WC_EDITA "Edit" -#if defined(__GNUC__) -# define WC_EDITW (const WCHAR []){ 'E','d','i','t',0 } -#elif defined(_MSC_VER) -# define WC_EDITW L"Edit" -#else -static const WCHAR WC_EDITW[] = { 'E','d','i','t',0 }; -#endif -#define WC_EDIT WINELIB_NAME_AW(WC_EDIT) - -/************************************************************************** - * Listbox control - */ - -#define WC_LISTBOXA "ListBox" -#if defined(__GNUC__) -# define WC_LISTBOXW (const WCHAR []){ 'L','i','s','t','B','o','x',0 } -#elif defined(_MSC_VER) -# define WC_LISTBOXW L"ListBox" -#else -static const WCHAR WC_LISTBOXW[] = { 'L','i','s','t','B','o','x',0 }; -#endif -#define WC_LISTBOX WINELIB_NAME_AW(WC_LISTBOX) - -/************************************************************************** - * Scrollbar control - */ - -#define WC_SCROLLBARA "ScrollBar" -#if defined(__GNUC__) -# define WC_SCROLLBARW (const WCHAR []){ 'S','c','r','o','l','l','B','a','r',0 } -#elif defined(_MSC_VER) -# define WC_SCROLLBARW L"ScrollBar" -#else -static const WCHAR WC_SCROLLBARW[] = { 'S','c','r','o','l','l','B','a','r',0 }; -#endif -#define WC_SCROLLBAR WINELIB_NAME_AW(WC_SCROLLBAR) +#define DPAMM_MERGE 1 +#define DPAMM_DELETE 2 +#define DPAMM_INSERT 3 #ifdef __cplusplus } #endif - -#endif /* __WINE_COMMCTRL_H */ +#endif +#endif diff --git a/reactos/include/reactos/wine/commctrl.h b/reactos/include/reactos/wine/commctrl.h new file mode 100644 index 00000000000..47c3a806d11 --- /dev/null +++ b/reactos/include/reactos/wine/commctrl.h @@ -0,0 +1,72 @@ + +#ifndef _INC_COMMCTRL_WINE +#define _INC_COMMCTRL_WINE + +#define DPA_GetPtr DPA_GetPtr_wine_hack +#define FlatSB_SetScrollProp FlatSB_SetScrollProp_wine_hack + +#if (_WIN32_IE < 0x501) +#undef _WIN32_IE +#define _WIN32_IE 0x0501 +#endif + +#include_next + +#undef DPA_GetPtr +LPVOID WINAPI DPA_GetPtr(HDPA, INT); + +#undef FlatSB_SetScrollProp +BOOL WINAPI FlatSB_SetScrollProp(HWND, UINT, INT, BOOL); + +#define DRAGLISTMSGSTRINGA "commctrl_DragListMsg" +#if defined(__GNUC__) +# define DRAGLISTMSGSTRINGW (const WCHAR []){ 'c','o','m','m','c','t','r','l', \ + '_','D','r','a','g','L','i','s','t','M','s','g',0 } +#elif defined(_MSC_VER) +# define DRAGLISTMSGSTRINGW L"commctrl_DragListMsg" +#else +static const WCHAR DRAGLISTMSGSTRINGW[] = { 'c','o','m','m','c','t','r','l', + '_','D','r','a','g','L','i','s','t','M','s','g',0 }; +#endif + +#define FLATSB_CLASSA "flatsb_class32" +#if defined(__GNUC__) +# define FLATSB_CLASSW (const WCHAR []){ 'f','l','a','t','s','b','_', \ + 'c','l','a','s','s','3','2',0 } +#elif defined(_MSC_VER) +# define FLATSB_CLASSW L"flatsb_class32" +#else +static const WCHAR FLATSB_CLASSW[] = { 'f','l','a','t','s','b','_', + 'c','l','a','s','s','3','2',0 }; +#endif + +typedef TBSAVEPARAMSW *LPTBSAVEPARAMSW; + +typedef LVFINDINFOA *LPLVFINDINFOA; +typedef LVFINDINFOW *LPLVFINDINFOW; + +#define SB_SETBORDERS (WM_USER+5) +#define TBSTYLE_EX_UNDOC1 0x00000004 /* similar to TBSTYLE_WRAPABLE */ + +/* these are undocumented and the names are guesses */ +typedef struct +{ + NMHDR hdr; + HWND hwndDialog; +} NMTBINITCUSTOMIZE; + +typedef struct +{ + NMHDR hdr; + INT idNew; + INT iDirection; /* left is -1, right is 1 */ + DWORD dwReason; /* HICF_* */ +} NMTBWRAPHOTITEM; + +#define LPNMLVDISPINFO WINELIB_NAME_AW(LPNMLVDISPINFO) + +/* undocumented messages in Toolbar */ +#define TB_UNKWN45D (WM_USER+93) +#define TB_UNKWN464 (WM_USER+100) + +#endif /* _INC_COMMCTRL_WINE */ From f820fe7a43420431af07c5aa14d96202367ee5bb Mon Sep 17 00:00:00 2001 From: Timo Kreuzer Date: Sat, 8 May 2010 15:30:59 +0000 Subject: [PATCH 05/12] [WIN32K] Fix broken parameter passing from EngMaskBitBlt to (Alpha)BltMask. It was passing the wrong surface and the wrong point. Rename some parameters to reflect what their usage is. Add ASSERTs to make sure noone passes useless parameters. Fixes crippled text in startmenu. The whole code is broken by design, anyway it will go away, once the new text rendering code is done. See issue #4379 for more details. svn path=/trunk/; revision=47124 --- reactos/subsystems/win32/win32k/eng/bitblt.c | 38 +++++++++++--------- 1 file changed, 22 insertions(+), 16 deletions(-) diff --git a/reactos/subsystems/win32/win32k/eng/bitblt.c b/reactos/subsystems/win32/win32k/eng/bitblt.c index afac0e8a7d3..8806aa75fc5 100644 --- a/reactos/subsystems/win32/win32k/eng/bitblt.c +++ b/reactos/subsystems/win32/win32k/eng/bitblt.c @@ -51,6 +51,9 @@ BltMask(SURFOBJ* psoDest, ULONG Pattern = 0; HBITMAP hbmPattern; + ASSERT(psoSource == NULL); + ASSERT(pptlSource == NULL); + if (psoMask == NULL) { return FALSE; @@ -662,8 +665,8 @@ static BOOLEAN APIENTRY AlphaBltMask(SURFOBJ* psoDest, SURFOBJ* psoSource, // unused SURFOBJ* psoMask, - XLATEOBJ* ColorTranslation, - XLATEOBJ* SrcColorTranslation, + XLATEOBJ* pxloRGB2Dest, + XLATEOBJ* pxloBrush, RECTL* prclDest, POINTL* pptlSource, // unused POINTL* pptlMask, @@ -675,12 +678,15 @@ AlphaBltMask(SURFOBJ* psoDest, ULONG Background, BrushColor, NewColor; BYTE *tMask, *lMask; + ASSERT(psoSource == NULL); + ASSERT(pptlSource == NULL); + dx = prclDest->right - prclDest->left; dy = prclDest->bottom - prclDest->top; if (psoMask != NULL) { - BrushColor = XLATEOBJ_iXlate(SrcColorTranslation, pbo ? pbo->iSolidColor : 0); + BrushColor = XLATEOBJ_iXlate(pxloBrush, pbo ? pbo->iSolidColor : 0); r = (int)GetRValue(BrushColor); g = (int)GetGValue(BrushColor); b = (int)GetBValue(BrushColor); @@ -701,14 +707,14 @@ AlphaBltMask(SURFOBJ* psoDest, else { Background = DIB_GetSource(psoDest, prclDest->left + i, prclDest->top + j, - SrcColorTranslation); + pxloBrush); NewColor = RGB((*lMask * (r - GetRValue(Background)) >> 8) + GetRValue(Background), (*lMask * (g - GetGValue(Background)) >> 8) + GetGValue(Background), (*lMask * (b - GetBValue(Background)) >> 8) + GetBValue(Background)); - Background = XLATEOBJ_iXlate(ColorTranslation, NewColor); + Background = XLATEOBJ_iXlate(pxloRGB2Dest, NewColor); DibFunctionsForBitmapFormat[psoDest->iBitmapFormat].DIB_PutPixel( psoDest, prclDest->left + i, prclDest->top + j, Background); } @@ -846,10 +852,10 @@ EngMaskBitBlt(SURFOBJ *psoDest, case DC_TRIVIAL: if (psoMask->iBitmapFormat == BMF_8BPP) Ret = AlphaBltMask(psoOutput, NULL , psoInput, DestColorTranslation, SourceColorTranslation, - &OutputRect, &InputPoint, pptlMask, pbo, &AdjustedBrushOrigin); + &OutputRect, NULL, &InputPoint, pbo, &AdjustedBrushOrigin); else Ret = BltMask(psoOutput, NULL, psoInput, DestColorTranslation, - &OutputRect, &InputPoint, pptlMask, pbo, &AdjustedBrushOrigin, + &OutputRect, NULL, &InputPoint, pbo, &AdjustedBrushOrigin, R4_MASK); break; case DC_RECT: @@ -864,13 +870,13 @@ EngMaskBitBlt(SURFOBJ *psoDest, Pt.y = InputPoint.y + CombinedRect.top - OutputRect.top; if (psoMask->iBitmapFormat == BMF_8BPP) { - Ret = AlphaBltMask(psoOutput, psoInput, psoMask, DestColorTranslation, SourceColorTranslation, - &CombinedRect, &Pt, pptlMask, pbo, &AdjustedBrushOrigin); + Ret = AlphaBltMask(psoOutput, NULL, psoInput, DestColorTranslation, SourceColorTranslation, + &CombinedRect, NULL, &Pt, pbo, &AdjustedBrushOrigin); } else { - Ret = BltMask(psoOutput, psoInput, psoMask, DestColorTranslation, - &CombinedRect, &Pt, pptlMask, pbo, &AdjustedBrushOrigin, R4_MASK); + Ret = BltMask(psoOutput, NULL, psoInput, DestColorTranslation, + &CombinedRect, NULL, &Pt, pbo, &AdjustedBrushOrigin, R4_MASK); } } break; @@ -908,17 +914,17 @@ EngMaskBitBlt(SURFOBJ *psoDest, Pt.y = InputPoint.y + CombinedRect.top - OutputRect.top; if (psoMask->iBitmapFormat == BMF_8BPP) { - Ret = AlphaBltMask(psoOutput, psoInput, psoMask, + Ret = AlphaBltMask(psoOutput, NULL, psoInput, DestColorTranslation, SourceColorTranslation, - &CombinedRect, &Pt, pptlMask, pbo, + &CombinedRect, NULL, &Pt, pbo, &AdjustedBrushOrigin) && Ret; } else { - Ret = BltMask(psoOutput, psoInput, psoMask, - DestColorTranslation, &CombinedRect, &Pt, - pptlMask, pbo, &AdjustedBrushOrigin, + Ret = BltMask(psoOutput, NULL, psoInput, + DestColorTranslation, &CombinedRect, NULL, + &Pt, pbo, &AdjustedBrushOrigin, R4_MASK) && Ret; } } From 4b9b7d580f842c505fe71b616089dcfb182b2caf Mon Sep 17 00:00:00 2001 From: Gregor Schneider Date: Sat, 8 May 2010 15:33:40 +0000 Subject: [PATCH 06/12] [EXPLORER] - Use proper buffer size, font type and an arbitrary high system time to create the size of the systray clock window - Fixes clock clipping See issue #2320 for more details. svn path=/trunk/; revision=47125 --- reactos/base/shell/explorer/taskbar/traynotify.cpp | 9 ++++++--- 1 file changed, 6 insertions(+), 3 deletions(-) diff --git a/reactos/base/shell/explorer/taskbar/traynotify.cpp b/reactos/base/shell/explorer/taskbar/traynotify.cpp index 5bb76af043e..ea0e85a4204 100644 --- a/reactos/base/shell/explorer/taskbar/traynotify.cpp +++ b/reactos/base/shell/explorer/taskbar/traynotify.cpp @@ -1282,14 +1282,17 @@ HWND ClockWindow::Create(HWND hwndParent) ClientRect clnt(hwndParent); WindowCanvas canvas(hwndParent); - FontSelection font(canvas, GetStockFont(DEFAULT_GUI_FONT)); + FontSelection font(canvas, GetStockFont(ANSI_VAR_FONT)); RECT rect = {0, 0, 0, 0}; - TCHAR buffer[8]; + TCHAR buffer[16]; + // Arbitrary high time so that the created clock window is big enough + SYSTEMTIME st = { 1601, 1, 0, 1, 23, 59, 59, 999 }; - if (!GetTimeFormat(LOCALE_USER_DEFAULT, TIME_NOSECONDS, NULL, NULL, buffer, sizeof(buffer)/sizeof(TCHAR))) + if (!GetTimeFormat(LOCALE_USER_DEFAULT, TIME_NOSECONDS, &st, NULL, buffer, sizeof(buffer)/sizeof(TCHAR))) _tcscpy(buffer, TEXT("00:00")); + // Calculate the rectangle needed to draw the time (without actually drawing it) DrawText(canvas, buffer, -1, &rect, DT_SINGLELINE|DT_NOPREFIX|DT_CALCRECT); int clockwindowWidth = rect.right-rect.left + 4; From 5678dca446e6a65e5f238933e81aac8a37e9f1ef Mon Sep 17 00:00:00 2001 From: Michael Martin Date: Sat, 8 May 2010 15:49:02 +0000 Subject: [PATCH 07/12] [win32k] - Modify how non-queued messages are send that originate from the Win23k subsystem. Non-queued messages must go directly to the windows WNDPROC and not through the message pump (previews ROS behavior). More importantly sending these messages must not cause the sending thread to block waiting for a reply. - Add a messaging handling function that always sends message from Win32k to the windows thread without waiting. This will also allow the implementation of message call back later. - Modify PackParam and UnpackParam to accept a BOOL value to determine whether LParam needs to be allocated from NonPagedPool. Use with new message handling as if message sent to another thread have any pointers they must be allocated from NonPagedPool. - Fixed broken logic in can_active_window function and co_WinPosShowWindow. - Fixed broken logic in co_IntSendActivateMessages. The WM_ACTIVATEAPP message was being sent to every window belonging to the desktop twice. Once with flag saying window was activated and again with deactivated. - These changes should fix bugs #969, #3171, #4501, #4676, #4677, #4948. svn path=/trunk/; revision=47126 --- .../win32/win32k/include/msgqueue.h | 16 ++ .../subsystems/win32/win32k/ntuser/focus.c | 44 +--- .../subsystems/win32/win32k/ntuser/message.c | 222 ++++++++++++++++-- .../subsystems/win32/win32k/ntuser/msgqueue.c | 18 +- .../subsystems/win32/win32k/ntuser/winpos.c | 30 +-- 5 files changed, 261 insertions(+), 69 deletions(-) diff --git a/reactos/subsystems/win32/win32k/include/msgqueue.h b/reactos/subsystems/win32/win32k/include/msgqueue.h index c751f3a911d..a8cc896df03 100644 --- a/reactos/subsystems/win32/win32k/include/msgqueue.h +++ b/reactos/subsystems/win32/win32k/include/msgqueue.h @@ -6,6 +6,7 @@ #define MSQ_NORMAL 0 #define MSQ_ISHOOK 1 #define MSQ_ISEVENT 2 +#define MSQ_SENTNOWAIT 0x80000000 typedef struct _USER_MESSAGE { @@ -28,6 +29,7 @@ typedef struct _USER_SENT_MESSAGE /* entry in the dispatching list of the sender's message queue */ LIST_ENTRY DispatchingListEntry; INT HookMessage; + BOOL HasPackedLParam; } USER_SENT_MESSAGE, *PUSER_SENT_MESSAGE; typedef struct _USER_SENT_MESSAGE_NOTIFY @@ -184,6 +186,20 @@ co_IntSendMessageTimeout(HWND hWnd, UINT uFlags, UINT uTimeout, ULONG_PTR *uResult); + +LRESULT FASTCALL co_IntSendMessageNoWait(HWND hWnd, + UINT Msg, + WPARAM wParam, + LPARAM lParam); +LRESULT FASTCALL +co_IntSendMessageWithCallBack(HWND hWnd, + UINT Msg, + WPARAM wParam, + LPARAM lParam, + SENDASYNCPROC CompletionCallback, + ULONG_PTR CompletionCallbackContext, + ULONG_PTR *uResult); + LRESULT FASTCALL IntDispatchMessage(MSG* Msg); BOOL FASTCALL diff --git a/reactos/subsystems/win32/win32k/ntuser/focus.c b/reactos/subsystems/win32/win32k/ntuser/focus.c index 9e309ac7dcd..7a8eeeb32d6 100644 --- a/reactos/subsystems/win32/win32k/ntuser/focus.c +++ b/reactos/subsystems/win32/win32k/ntuser/focus.c @@ -53,8 +53,8 @@ co_IntSendDeactivateMessages(HWND hWndPrev, HWND hWnd) { if (hWndPrev) { - co_IntPostOrSendMessage(hWndPrev, WM_NCACTIVATE, FALSE, 0); - co_IntPostOrSendMessage(hWndPrev, WM_ACTIVATE, + co_IntSendMessageNoWait(hWndPrev, WM_NCACTIVATE, FALSE, 0); + co_IntSendMessageNoWait(hWndPrev, WM_ACTIVATE, MAKEWPARAM(WA_INACTIVE, UserGetWindowLong(hWndPrev, GWL_STYLE, FALSE) & WS_MINIMIZE), (LPARAM)hWnd); } @@ -105,38 +105,19 @@ co_IntSendActivateMessages(HWND hWndPrev, HWND hWnd, BOOL MouseActivate) if (Window && WindowPrev) { - PWINDOW_OBJECT cWindow; - HWND *List, *phWnd; HANDLE OldTID = IntGetWndThreadId(WindowPrev); HANDLE NewTID = IntGetWndThreadId(Window); - DPRINT("SendActiveMessage Old -> %x, New -> %x\n", OldTID, NewTID); + DPRINT1("SendActiveMessage Old -> %x, New -> %x\n", OldTID, NewTID); + if (Window->Wnd->style & WS_MINIMIZE) + { + DPRINT1("Widow was nminimized\n"); + } if (OldTID != NewTID) { - List = IntWinListChildren(UserGetWindowObject(IntGetDesktopWindow())); - if (List) - { - for (phWnd = List; *phWnd; ++phWnd) - { - cWindow = UserGetWindowObject(*phWnd); - if (cWindow && (IntGetWndThreadId(cWindow) == OldTID)) - { // FALSE if the window is being deactivated, - // ThreadId that owns the window being activated. - co_IntPostOrSendMessage(*phWnd, WM_ACTIVATEAPP, FALSE, (LPARAM)NewTID); - } - } - for (phWnd = List; *phWnd; ++phWnd) - { - cWindow = UserGetWindowObject(*phWnd); - if (cWindow && (IntGetWndThreadId(cWindow) == NewTID)) - { // TRUE if the window is being activated, - // ThreadId that owns the window being deactivated. - co_IntPostOrSendMessage(*phWnd, WM_ACTIVATEAPP, TRUE, (LPARAM)OldTID); - } - } - ExFreePool(List); - } + co_IntSendMessageNoWait(hWndPrev, WM_ACTIVATEAPP, FALSE, (LPARAM)NewTID); + co_IntSendMessageNoWait(hWnd, WM_ACTIVATEAPP, TRUE, (LPARAM)OldTID); } UserDerefObjectCo(WindowPrev); // Now allow the previous window to die. } @@ -144,10 +125,9 @@ co_IntSendActivateMessages(HWND hWndPrev, HWND hWnd, BOOL MouseActivate) UserDerefObjectCo(Window); /* FIXME: IntIsWindow */ - - co_IntPostOrSendMessage(hWnd, WM_NCACTIVATE, (WPARAM)(hWnd == UserGetForegroundWindow()), 0); + co_IntSendMessageNoWait(hWnd, WM_NCACTIVATE, (WPARAM)(hWnd == UserGetForegroundWindow()), 0); /* FIXME: WA_CLICKACTIVE */ - co_IntPostOrSendMessage(hWnd, WM_ACTIVATE, + co_IntSendMessageNoWait(hWnd, WM_ACTIVATE, MAKEWPARAM(MouseActivate ? WA_CLICKACTIVE : WA_ACTIVE, UserGetWindowLong(hWnd, GWL_STYLE, FALSE) & WS_MINIMIZE), (LPARAM)hWndPrev); @@ -241,7 +221,9 @@ co_IntSetForegroundAndFocusWindow(PWINDOW_OBJECT Window, PWINDOW_OBJECT FocusWin co_IntSendDeactivateMessages(hWndPrev, hWnd); co_IntSendKillFocusMessages(hWndFocusPrev, hWndFocus); + IntSetFocusMessageQueue(Window->pti->MessageQueue); + if (Window->pti->MessageQueue) { Window->pti->MessageQueue->ActiveWindow = hWnd; diff --git a/reactos/subsystems/win32/win32k/ntuser/message.c b/reactos/subsystems/win32/win32k/ntuser/message.c index 3bd92011346..39b0470c795 100644 --- a/reactos/subsystems/win32/win32k/ntuser/message.c +++ b/reactos/subsystems/win32/win32k/ntuser/message.c @@ -165,7 +165,7 @@ MsgMemorySize(PMSGMEMORY MsgMemoryEntry, WPARAM wParam, LPARAM lParam) } static NTSTATUS -PackParam(LPARAM *lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) +PackParam(LPARAM *lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam, BOOL NonPagedPoolNeeded) { NCCALCSIZE_PARAMS *UnpackedNcCalcsize; NCCALCSIZE_PARAMS *PackedNcCalcsize; @@ -173,28 +173,34 @@ PackParam(LPARAM *lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) CREATESTRUCTW *PackedCs; PUNICODE_STRING WindowName; PUNICODE_STRING ClassName; + POOL_TYPE PoolType; UINT Size; PCHAR CsData; *lParamPacked = lParam; + + if (NonPagedPoolNeeded) + PoolType = NonPagedPool; + else + PoolType = PagedPool; + if (WM_NCCALCSIZE == Msg && wParam) { + UnpackedNcCalcsize = (NCCALCSIZE_PARAMS *) lParam; - if (UnpackedNcCalcsize->lppos != (PWINDOWPOS) (UnpackedNcCalcsize + 1)) + PackedNcCalcsize = ExAllocatePoolWithTag(PoolType, + sizeof(NCCALCSIZE_PARAMS) + sizeof(WINDOWPOS), + TAG_MSG); + + if (NULL == PackedNcCalcsize) { - PackedNcCalcsize = ExAllocatePoolWithTag(PagedPool, - sizeof(NCCALCSIZE_PARAMS) + sizeof(WINDOWPOS), - TAG_MSG); - if (NULL == PackedNcCalcsize) - { - DPRINT1("Not enough memory to pack lParam\n"); - return STATUS_NO_MEMORY; - } - RtlCopyMemory(PackedNcCalcsize, UnpackedNcCalcsize, sizeof(NCCALCSIZE_PARAMS)); - PackedNcCalcsize->lppos = (PWINDOWPOS) (PackedNcCalcsize + 1); - RtlCopyMemory(PackedNcCalcsize->lppos, UnpackedNcCalcsize->lppos, sizeof(WINDOWPOS)); - *lParamPacked = (LPARAM) PackedNcCalcsize; + DPRINT1("Not enough memory to pack lParam\n"); + return STATUS_NO_MEMORY; } + RtlCopyMemory(PackedNcCalcsize, UnpackedNcCalcsize, sizeof(NCCALCSIZE_PARAMS)); + PackedNcCalcsize->lppos = (PWINDOWPOS) (PackedNcCalcsize + 1); + RtlCopyMemory(PackedNcCalcsize->lppos, UnpackedNcCalcsize->lppos, sizeof(WINDOWPOS)); + *lParamPacked = (LPARAM) PackedNcCalcsize; } else if (WM_CREATE == Msg || WM_NCCREATE == Msg) { @@ -210,7 +216,7 @@ PackParam(LPARAM *lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) { Size += sizeof(WCHAR) + ClassName->Length + sizeof(WCHAR); } - PackedCs = ExAllocatePoolWithTag(PagedPool, Size, TAG_MSG); + PackedCs = ExAllocatePoolWithTag(PoolType, Size, TAG_MSG); if (NULL == PackedCs) { DPRINT1("Not enough memory to pack lParam\n"); @@ -244,11 +250,28 @@ PackParam(LPARAM *lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) *lParamPacked = (LPARAM) PackedCs; } + else if (PoolType == NonPagedPool) + { + PMSGMEMORY MsgMemoryEntry; + PVOID PackedData; + + MsgMemoryEntry = FindMsgMemory(Msg); + + if ((!MsgMemoryEntry) || (MsgMemoryEntry->Size < 0)) + { + /* Keep previous behavior */ + return STATUS_SUCCESS; + } + PackedData = ExAllocatePoolWithTag(NonPagedPool, MsgMemorySize(MsgMemoryEntry, wParam, lParam), TAG_MSG); + RtlCopyMemory(PackedData, (PVOID)lParam, MsgMemorySize(MsgMemoryEntry, wParam, lParam)); + *lParamPacked = (LPARAM)PackedData; + } + return STATUS_SUCCESS; } static NTSTATUS -UnpackParam(LPARAM lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) +UnpackParam(LPARAM lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam, BOOL NonPagedPoolUsed) { NCCALCSIZE_PARAMS *UnpackedParams; NCCALCSIZE_PARAMS *PackedParams; @@ -277,6 +300,23 @@ UnpackParam(LPARAM lParamPacked, UINT Msg, WPARAM wParam, LPARAM lParam) return STATUS_SUCCESS; } + else if (NonPagedPoolUsed) + { + PMSGMEMORY MsgMemoryEntry; + MsgMemoryEntry = FindMsgMemory(Msg); + if (MsgMemoryEntry->Size < 0) + { + /* Keep previous behavior */ + return STATUS_INVALID_PARAMETER; + } + + if (MsgMemory->Flags == MMS_FLAG_READWRITE) + { + //RtlCopyMemory((PVOID)lParam, (PVOID)lParamPacked, MsgMemory->Size); + } + ExFreePool((PVOID) lParamPacked); + return STATUS_SUCCESS; + } ASSERT(FALSE); @@ -394,7 +434,7 @@ IntDispatchMessage(PMSG pMsg) lParamBufferSize = MsgMemorySize(MsgMemoryEntry, pMsg->wParam, pMsg->lParam); } - if (! NT_SUCCESS(PackParam(&lParamPacked, pMsg->message, pMsg->wParam, pMsg->lParam))) + if (! NT_SUCCESS(PackParam(&lParamPacked, pMsg->message, pMsg->wParam, pMsg->lParam, FALSE))) { DPRINT1("Failed to pack message parameters\n"); return 0; @@ -408,7 +448,7 @@ IntDispatchMessage(PMSG pMsg) lParamPacked, lParamBufferSize); - if (! NT_SUCCESS(UnpackParam(lParamPacked, pMsg->message, pMsg->wParam, pMsg->lParam))) + if (! NT_SUCCESS(UnpackParam(lParamPacked, pMsg->message, pMsg->wParam, pMsg->lParam, FALSE))) { DPRINT1("Failed to unpack message parameters\n"); } @@ -1372,7 +1412,7 @@ co_IntSendMessageTimeoutSingle( HWND hWnd, lParamBufferSize = MsgMemorySize(MsgMemoryEntry, wParam, lParam); } - if (! NT_SUCCESS(PackParam(&lParamPacked, Msg, wParam, lParam))) + if (! NT_SUCCESS(PackParam(&lParamPacked, Msg, wParam, lParam, FALSE))) { DPRINT1("Failed to pack message parameters\n"); RETURN( FALSE); @@ -1392,7 +1432,7 @@ co_IntSendMessageTimeoutSingle( HWND hWnd, IntCallWndProcRet( Window, hWnd, Msg, wParam, lParam, (LRESULT *)uResult); - if (! NT_SUCCESS(UnpackParam(lParamPacked, Msg, wParam, lParam))) + if (! NT_SUCCESS(UnpackParam(lParamPacked, Msg, wParam, lParam, FALSE))) { DPRINT1("Failed to unpack message parameters\n"); RETURN( TRUE); @@ -1499,6 +1539,148 @@ co_IntSendMessageTimeout( HWND hWnd, return (LRESULT) TRUE; } +LRESULT FASTCALL co_IntSendMessageNoWait(HWND hWnd, + UINT Msg, + WPARAM wParam, + LPARAM lParam) +{ + ULONG_PTR Result = 0; + co_IntSendMessageWithCallBack(hWnd, + Msg, + wParam, + lParam, + NULL, + 0, + &Result); + return Result; +} + +LRESULT FASTCALL +co_IntSendMessageWithCallBack( HWND hWnd, + UINT Msg, + WPARAM wParam, + LPARAM lParam, + SENDASYNCPROC CompletionCallback, + ULONG_PTR CompletionCallbackContext, + ULONG_PTR *uResult) +{ + ULONG_PTR Result; + PWINDOW_OBJECT Window = NULL; + PMSGMEMORY MsgMemoryEntry; + INT lParamBufferSize; + LPARAM lParamPacked; + PTHREADINFO Win32Thread; + DECLARE_RETURN(LRESULT); + USER_REFERENCE_ENTRY Ref; + PUSER_SENT_MESSAGE Message; + + if (!(Window = UserGetWindowObject(hWnd))) + { + RETURN(FALSE); + } + + UserRefObjectCo(Window, &Ref); + + if (Window->state & WINDOWSTATUS_DESTROYING) + { + /* FIXME - last error? */ + DPRINT1("Attempted to send message to window 0x%x that is being destroyed!\n", hWnd); + RETURN(FALSE); + } + + Win32Thread = PsGetCurrentThreadWin32Thread(); + + IntCallWndProc( Window, hWnd, Msg, wParam, lParam); + + if (Win32Thread == NULL) + { + ASSERT(FALSE); + RETURN(FALSE); + } + + if (Win32Thread->TIF_flags & TIF_INCLEANUP) + { + /* Never send messages to exiting threads */ + RETURN(FALSE); + } + + /* See if this message type is present in the table */ + MsgMemoryEntry = FindMsgMemory(Msg); + if (NULL == MsgMemoryEntry) + { + lParamBufferSize = -1; + } + else + { + lParamBufferSize = MsgMemorySize(MsgMemoryEntry, wParam, lParam); + } + + if (! NT_SUCCESS(PackParam(&lParamPacked, Msg, wParam, lParam, Window->pti->MessageQueue != Win32Thread->MessageQueue))) + { + DPRINT1("Failed to pack message parameters\n"); + RETURN( FALSE); + } + + /* If this is not a callback and it can be sent now, then send it. */ + if ((Window->pti->MessageQueue == Win32Thread->MessageQueue) && (CompletionCallback == NULL)) + { + + Result = (ULONG_PTR)co_IntCallWindowProc( Window->Wnd->lpfnWndProc, + !Window->Wnd->Unicode, + hWnd, + Msg, + wParam, + lParamPacked, + lParamBufferSize ); + if(uResult) + { + *uResult = Result; + } + } + + IntCallWndProcRet( Window, hWnd, Msg, wParam, lParam, (LRESULT *)uResult); + + if (Window->pti->MessageQueue == Win32Thread->MessageQueue) + { + if (! NT_SUCCESS(UnpackParam(lParamPacked, Msg, wParam, lParam, FALSE))) + { + DPRINT1("Failed to unpack message parameters\n"); + RETURN(TRUE); + } + RETURN(TRUE); + } + + if(!(Message = ExAllocatePoolWithTag(NonPagedPool, sizeof(USER_SENT_MESSAGE), TAG_USRMSG))) + { + DPRINT1("MsqSendMessage(): Not enough memory to allocate a message"); + return STATUS_INSUFFICIENT_RESOURCES; + } + + Message->Msg.hwnd = hWnd; + Message->Msg.message = Msg; + Message->Msg.wParam = wParam; + Message->Msg.lParam = lParamPacked; + Message->CompletionEvent = NULL; + Message->Result = 0; + Message->SenderQueue = Win32Thread->MessageQueue; + IntReferenceMessageQueue(Message->SenderQueue); + IntReferenceMessageQueue(Window->pti->MessageQueue); + Message->CompletionCallback = CompletionCallback; + Message->CompletionCallbackContext = CompletionCallbackContext; + Message->HookMessage = MSQ_NORMAL | MSQ_SENTNOWAIT; + Message->HasPackedLParam = (lParamBufferSize > 0); + + InsertTailList(&Window->pti->MessageQueue->SentMessagesListHead, &Message->ListEntry); + InsertTailList(&Win32Thread->MessageQueue->DispatchingMessagesHead, &Message->DispatchingListEntry); + IntDereferenceMessageQueue(Window->pti->MessageQueue); + IntDereferenceMessageQueue(Message->SenderQueue); + + RETURN(TRUE); + +CLEANUP: + if (Window) UserDerefObjectCo(Window); + END_CLEANUP; +} /* This function posts a message if the destination's message queue belongs to another thread, otherwise it sends the message. It does not support broadcast diff --git a/reactos/subsystems/win32/win32k/ntuser/msgqueue.c b/reactos/subsystems/win32/win32k/ntuser/msgqueue.c index 16323aeb5c4..4b45bac5c21 100644 --- a/reactos/subsystems/win32/win32k/ntuser/msgqueue.c +++ b/reactos/subsystems/win32/win32k/ntuser/msgqueue.c @@ -969,7 +969,7 @@ co_MsqDispatchOneSentMessage(PUSER_MESSAGE_QUEUE MessageQueue) /* remove the message from the dispatching list, so lock the sender's message queue */ SenderReturned = (Message->DispatchingListEntry.Flink == NULL); - if(!SenderReturned) + if (!SenderReturned) { /* only remove it from the dispatching list if not already removed by a timeout */ RemoveEntryList(&Message->DispatchingListEntry); @@ -983,6 +983,12 @@ co_MsqDispatchOneSentMessage(PUSER_MESSAGE_QUEUE MessageQueue) *Message->Result = Result; } + if (Message->HasPackedLParam == TRUE) + { + if (Message->Msg.lParam) + ExFreePool((PVOID)Message->Msg.lParam); + } + /* Notify the sender. */ if (Message->CompletionEvent != NULL) { @@ -1010,9 +1016,12 @@ co_MsqDispatchOneSentMessage(PUSER_MESSAGE_QUEUE MessageQueue) Notified: - /* dereference both sender and our queue */ - IntDereferenceMessageQueue(MessageQueue); - IntDereferenceMessageQueue(Message->SenderQueue); + /* Only if it is not a no wait message */ + if (!(Message->HookMessage & MSQ_SENTNOWAIT)) + { + IntDereferenceMessageQueue(Message->SenderQueue); + IntDereferenceMessageQueue(MessageQueue); + } /* free the message */ ExFreePool(Message); @@ -1147,6 +1156,7 @@ co_MsqSendMessage(PUSER_MESSAGE_QUEUE MessageQueue, IntReferenceMessageQueue(ThreadQueue); Message->CompletionCallback = NULL; Message->HookMessage = HookMessage; + Message->HasPackedLParam = FALSE; IntReferenceMessageQueue(MessageQueue); diff --git a/reactos/subsystems/win32/win32k/ntuser/winpos.c b/reactos/subsystems/win32/win32k/ntuser/winpos.c index ab45d978c41..6b5b0d9d6f6 100644 --- a/reactos/subsystems/win32/win32k/ntuser/winpos.c +++ b/reactos/subsystems/win32/win32k/ntuser/winpos.c @@ -69,9 +69,6 @@ IntGetClientOrigin(PWINDOW_OBJECT Window OPTIONAL, LPPOINT Point) return TRUE; } - - - BOOL FASTCALL UserGetClientOrigin(PWINDOW_OBJECT Window, LPPOINT Point) { @@ -120,8 +117,13 @@ BOOL FASTCALL can_activate_window( PWINDOW_OBJECT Wnd OPTIONAL) style = Wnd->Wnd->style; if (!(style & WS_VISIBLE) && Wnd->pti->pEThread->ThreadsProcess != CsrProcess) return FALSE; + if ((style & WS_MINIMIZE) && + Wnd->pti->pEThread->ThreadsProcess != CsrProcess) return FALSE; if ((style & (WS_POPUP|WS_CHILD)) == WS_CHILD) return FALSE; - return !(style & WS_DISABLED); + return TRUE; + /* FIXME: This window could be disable because the child that closed + was a popup. */ + //return !(style & WS_DISABLED); } @@ -312,7 +314,7 @@ co_WinPosMinMaximize(PWINDOW_OBJECT Window, UINT ShowFlag, RECT* NewPos) if (Wnd->style & WS_MINIMIZE) { - if (!co_IntSendMessage(Window->hSelf, WM_QUERYOPEN, 0, 0)) + if (!co_IntSendMessageNoWait(Window->hSelf, WM_QUERYOPEN, 0, 0)) { return(SWP_NOSIZE | SWP_NOMOVE); } @@ -531,7 +533,7 @@ co_WinPosDoNCCALCSize(PWINDOW_OBJECT Window, PWINDOWPOS WinPos, params.lppos = &winposCopy; winposCopy = *WinPos; - wvrFlags = co_IntSendMessage(Window->hSelf, WM_NCCALCSIZE, TRUE, (LPARAM) ¶ms); + wvrFlags = co_IntSendMessageNoWait(Window->hSelf, WM_NCCALCSIZE, TRUE, (LPARAM) ¶ms); /* If the application send back garbage, ignore it */ if (params.rgrc[0].left <= params.rgrc[0].right && @@ -590,7 +592,7 @@ co_WinPosDoWinPosChanging(PWINDOW_OBJECT Window, if (!(WinPos->flags & SWP_NOSENDCHANGING)) { - co_IntPostOrSendMessage(Window->hSelf, WM_WINDOWPOSCHANGING, 0, (LPARAM) WinPos); + co_IntSendMessageNoWait(Window->hSelf, WM_WINDOWPOSCHANGING, 0, (LPARAM) WinPos); } *WindowRect = Wnd->rcWindow; @@ -1320,7 +1322,7 @@ co_WinPosSetWindowPos( { if ((Window->Wnd->style & (WS_CHILD | WS_POPUP)) == WS_CHILD) { - co_IntSendMessage(WinPos.hwnd, WM_CHILDACTIVATE, 0, 0); + co_IntSendMessageNoWait(WinPos.hwnd, WM_CHILDACTIVATE, 0, 0); } else { @@ -1330,7 +1332,7 @@ co_WinPosSetWindowPos( } if ((WinPos.flags & SWP_AGG_STATUSFLAGS) != SWP_AGG_NOPOSCHANGE) - co_IntPostOrSendMessage(WinPos.hwnd, WM_WINDOWPOSCHANGED, 0, (LPARAM) &WinPos); + co_IntSendMessageNoWait(WinPos.hwnd, WM_WINDOWPOSCHANGED, 0, (LPARAM) &WinPos); return TRUE; } @@ -1343,7 +1345,7 @@ co_WinPosGetNonClientSize(PWINDOW_OBJECT Window, RECT* WindowRect, RECT* ClientR ASSERT_REFS_CO(Window); *ClientRect = *WindowRect; - Result = co_IntSendMessage(Window->hSelf, WM_NCCALCSIZE, FALSE, (LPARAM) ClientRect); + Result = co_IntSendMessageNoWait(Window->hSelf, WM_NCCALCSIZE, FALSE, (LPARAM) ClientRect); FixClientRect(ClientRect, WindowRect); @@ -1462,7 +1464,7 @@ co_WinPosShowWindow(PWINDOW_OBJECT Window, INT Cmd) if (ShowFlag != WasVisible) { - co_IntSendMessage(Window->hSelf, WM_SHOWWINDOW, ShowFlag, 0); + co_IntSendMessageNoWait(Window->hSelf, WM_SHOWWINDOW, ShowFlag, 0); } /* We can't activate a child window */ @@ -1476,7 +1478,7 @@ co_WinPosShowWindow(PWINDOW_OBJECT Window, INT Cmd) ? HWND_TOPMOST : HWND_TOP, NewPos.left, NewPos.top, NewPos.right, NewPos.bottom, LOWORD(Swp)); - if (Cmd == SW_HIDE) + if ((Cmd == SW_HIDE) || (Cmd == SW_MINIMIZE)) { PWINDOW_OBJECT ThreadFocusWindow; @@ -1520,12 +1522,12 @@ co_WinPosShowWindow(PWINDOW_OBJECT Window, INT Cmd) wParam = SIZE_MINIMIZED; } - co_IntSendMessage(Window->hSelf, WM_SIZE, wParam, + co_IntSendMessageNoWait(Window->hSelf, WM_SIZE, wParam, MAKELONG(Wnd->rcClient.right - Wnd->rcClient.left, Wnd->rcClient.bottom - Wnd->rcClient.top)); - co_IntSendMessage(Window->hSelf, WM_MOVE, 0, + co_IntSendMessageNoWait(Window->hSelf, WM_MOVE, 0, MAKELONG(Wnd->rcClient.left, Wnd->rcClient.top)); IntEngWindowChanged(Window, WOC_RGN_CLIENT); From 4545e038a2fbaf4674de61da4366745c9376c60a Mon Sep 17 00:00:00 2001 From: Sylvain Petreolle Date: Sat, 8 May 2010 16:27:15 +0000 Subject: [PATCH 08/12] Disable test_GetLongPathNameW() in kernel32:path test for now. Fixes testbot crash, bug 5370 svn path=/trunk/; revision=47127 --- rostests/winetests/kernel32/path.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/rostests/winetests/kernel32/path.c b/rostests/winetests/kernel32/path.c index 8232fdfaaa7..c418ef245ea 100755 --- a/rostests/winetests/kernel32/path.c +++ b/rostests/winetests/kernel32/path.c @@ -1601,7 +1601,8 @@ START_TEST(path) test_CleanupPathA(origdir,curdir); test_GetTempPath(); test_GetLongPathNameA(); - test_GetLongPathNameW(); + skip("skipping test_GetLongPathNameW(), bug 5370\n"); + //test_GetLongPathNameW(); test_GetShortPathNameW(); test_GetSystemDirectory(); test_GetWindowsDirectory(); From 0963ef8f610372bc04353244e77c6aab9e2e9601 Mon Sep 17 00:00:00 2001 From: Gregor Schneider Date: Sat, 8 May 2010 16:27:36 +0000 Subject: [PATCH 09/12] Add some win32k/gdi DC tests created by Jerome Gardou svn path=/trunk/; revision=47128 --- .../w32knapi/ntgdi/NtGdiCreateCompatibleDC.c | 2 ++ .../w32knapi/ntgdi/NtGdiDeleteObjectApp.c | 22 ++++++++++++++++++- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c index a53821b5889..3597eb67dca 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c @@ -22,6 +22,8 @@ Test_NtGdiCreateCompatibleDC(PTESTINFO pti) hObj = SelectObject(hDC, GetStockObject(WHITE_PEN)); TEST(hObj == GetStockObject(BLACK_PEN)); + TEST(NtGdiDeleteObjectApp(hDC) != 0); + return APISTATUS_NORMAL; } diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c index ef4daa228bd..0084b109a9a 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c @@ -16,7 +16,7 @@ Test_NtGdiDeleteObjectApp(PTESTINFO pti) TEST(NtGdiDeleteObjectApp((PVOID)(GDI_HANDLE_STOCK_MASK | 0x1234)) == 1); TEST(GetLastError() == 0); - /* Delete a DC */ + /* Delete a compatible DC */ SetLastError(0); hdc = CreateCompatibleDC(NULL); ASSERT(IsHandleValid(hdc) == 1); @@ -24,6 +24,26 @@ Test_NtGdiDeleteObjectApp(PTESTINFO pti) TEST(GetLastError() == 0); TEST(IsHandleValid(hdc) == 0); + /* Delete a display DC */ + SetLastError(0); + hdc = CreateDC("DISPLAY", NULL, NULL, NULL); + ASSERT(IsHandleValid(hdc) == 1); + TEST(NtGdiDeleteObjectApp(hdc) != 0); + TEST(GetLastError() == 0); + TEST(IsHandleValid(hdc) == 1); + TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); + TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); + + /* Once more */ + SetLastError(0); + hdc = GetDC(0); + ASSERT(IsHandleValid(hdc) == 1); + TEST(NtGdiDeleteObjectApp(hdc) != 0); + TEST(GetLastError() == 0); + TEST(IsHandleValid(hdc) == 1); + TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); + TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); + /* Delete a brush */ SetLastError(0); hbrush = CreateSolidBrush(0x123456); From e03efb63b2b6e78b4318041d4da2a1021020dfdc Mon Sep 17 00:00:00 2001 From: Eric Kohl Date: Sat, 8 May 2010 16:30:56 +0000 Subject: [PATCH 10/12] [WINLOGON] - Move environment creation to a separate file. - Impersonate the new user and create the 'Volatile Environment' key for the new user. svn path=/trunk/; revision=47129 --- reactos/base/system/winlogon/environment.c | 129 +++++++++++++++++++ reactos/base/system/winlogon/sas.c | 51 +------- reactos/base/system/winlogon/winlogon.h | 6 + reactos/base/system/winlogon/winlogon.rbuild | 1 + 4 files changed, 138 insertions(+), 49 deletions(-) create mode 100644 reactos/base/system/winlogon/environment.c diff --git a/reactos/base/system/winlogon/environment.c b/reactos/base/system/winlogon/environment.c new file mode 100644 index 00000000000..f0beeba90bd --- /dev/null +++ b/reactos/base/system/winlogon/environment.c @@ -0,0 +1,129 @@ +/* + * COPYRIGHT: See COPYING in the top level directory + * PROJECT: ReactOS Winlogon + * FILE: base/system/winlogon/environment.c + * PURPOSE: User environment routines + * PROGRAMMERS: Thomas Weidenmueller (w3seek@users.sourceforge.net) + * Hervé Poussineau (hpoussin@reactos.org) + * Eric Kohl + */ + +/* INCLUDES *****************************************************************/ + +#include "winlogon.h" + +#include + +WINE_DEFAULT_DEBUG_CHANNEL(winlogon); + +/* GLOBALS ******************************************************************/ + + +/* FUNCTIONS ****************************************************************/ + +BOOL +CreateUserEnvironment(IN PWLSESSION Session, + IN LPVOID *lpEnvironment, + IN LPWSTR *lpFullEnv) +{ + LPCWSTR wstr; + SIZE_T EnvBlockSize = 0, ProfileSize = 0; + LPVOID lpEnviron = NULL; + LPWSTR lpFullEnviron = NULL; + HKEY hKey; + DWORD dwDisp; + LONG lError; + HKEY hKeyCurrentUser; + + TRACE("WL: CreateUserEnvironment called\n"); + + /* Create environment block for the user */ + if (!CreateEnvironmentBlock(&lpEnviron, + Session->UserToken, + TRUE)) + { + WARN("WL: CreateEnvironmentBlock() failed\n"); + return FALSE; + } + + if (Session->Profile->dwType == WLX_PROFILE_TYPE_V2_0 && Session->Profile->pszEnvironment) + { + /* Count required size for full environment */ + wstr = (LPCWSTR)lpEnviron; + while (*wstr != UNICODE_NULL) + { + SIZE_T size = wcslen(wstr) + 1; + wstr += size; + EnvBlockSize += size; + } + + wstr = Session->Profile->pszEnvironment; + while (*wstr != UNICODE_NULL) + { + SIZE_T size = wcslen(wstr) + 1; + wstr += size; + ProfileSize += size; + } + + /* Allocate enough memory */ + lpFullEnviron = HeapAlloc(GetProcessHeap, 0, (EnvBlockSize + ProfileSize + 1) * sizeof(WCHAR)); + if (!lpFullEnviron) + { + TRACE("HeapAlloc() failed\n"); + return FALSE; + } + + /* Fill user environment block */ + CopyMemory(lpFullEnviron, + lpEnviron, + EnvBlockSize * sizeof(WCHAR)); + CopyMemory(&lpFullEnviron[EnvBlockSize], + Session->Profile->pszEnvironment, + ProfileSize * sizeof(WCHAR)); + lpFullEnviron[EnvBlockSize + ProfileSize] = UNICODE_NULL; + } + else + { + lpFullEnviron = (LPWSTR)lpEnviron; + } + + /* Impersonate the new user */ + ImpersonateLoggedOnUser(Session->UserToken); + + /* Open the new users HKCU key */ + lError = RegOpenCurrentUser(KEY_CREATE_SUB_KEY, + &hKeyCurrentUser); + if (lError == ERROR_SUCCESS) + { + /* Create the 'Volatile Environment' key */ + lError = RegCreateKeyExW(hKeyCurrentUser, + L"Volatile Environment", + 0, + NULL, + REG_OPTION_VOLATILE, + KEY_WRITE, + NULL, + &hKey, + &dwDisp); + if (lError == ERROR_SUCCESS) + { + RegCloseKey(hKey); + } + else + { + WARN("WL: RegCreateKeyExW() failed (Error: %ld)\n", lError); + } + + RegCloseKey(hKeyCurrentUser); + } + + /* Revert the impersonation */ + RevertToSelf(); + + *lpEnvironment = lpEnviron; + *lpFullEnv = lpFullEnviron; + + TRACE("WL: CreateUserEnvironment done\n"); + + return TRUE; +} diff --git a/reactos/base/system/winlogon/sas.c b/reactos/base/system/winlogon/sas.c index f560187d702..baecf988a73 100644 --- a/reactos/base/system/winlogon/sas.c +++ b/reactos/base/system/winlogon/sas.c @@ -171,8 +171,6 @@ HandleLogon( PROFILEINFOW ProfileInfo; LPVOID lpEnvironment = NULL; LPWSTR lpFullEnv = NULL; - LPCWSTR wstr; - SIZE_T EnvBlockSize = 0, ProfileSize = 0; BOOLEAN Old; BOOL ret = FALSE; @@ -210,57 +208,12 @@ HandleLogon( } /* Create environment block for the user */ - if (!CreateEnvironmentBlock( - &lpEnvironment, - Session->UserToken, - TRUE)) + if (!CreateUserEnvironment(Session, &lpEnvironment, &lpFullEnv)) { - WARN("WL: CreateEnvironmentBlock() failed\n"); + WARN("WL: SetUserEnvironment() failed\n"); goto cleanup; } - if (Session->Profile->dwType == WLX_PROFILE_TYPE_V2_0 && Session->Profile->pszEnvironment) - { - /* Count required size for full environment */ - wstr = (LPCWSTR)lpEnvironment; - while (*wstr != UNICODE_NULL) - { - SIZE_T size = wcslen(wstr) + 1; - wstr += size; - EnvBlockSize += size; - } - wstr = Session->Profile->pszEnvironment; - while (*wstr != UNICODE_NULL) - { - SIZE_T size = wcslen(wstr) + 1; - wstr += size; - ProfileSize += size; - } - - /* Allocate enough memory */ - lpFullEnv = HeapAlloc(GetProcessHeap, 0, (EnvBlockSize + ProfileSize + 1) * sizeof(WCHAR)); - if (!lpFullEnv) - { - TRACE("HeapAlloc() failed\n"); - goto cleanup; - } - - /* Fill user environment block */ - CopyMemory( - lpFullEnv, - lpEnvironment, - EnvBlockSize * sizeof(WCHAR)); - CopyMemory( - &lpFullEnv[EnvBlockSize], - Session->Profile->pszEnvironment, - ProfileSize * sizeof(WCHAR)); - lpFullEnv[EnvBlockSize + ProfileSize] = UNICODE_NULL; - } - else - { - lpFullEnv = (LPWSTR)lpEnvironment; - } - DisplayStatusMessage(Session, Session->WinlogonDesktop, IDS_APPLYINGYOURPERSONALSETTINGS); UpdatePerUserSystemParameters(0, TRUE); diff --git a/reactos/base/system/winlogon/winlogon.h b/reactos/base/system/winlogon/winlogon.h index 2df4e3aec03..c03bf697925 100644 --- a/reactos/base/system/winlogon/winlogon.h +++ b/reactos/base/system/winlogon/winlogon.h @@ -180,6 +180,12 @@ BOOL WINAPI UpdatePerUserSystemParameters(DWORD dwUnknown, DWORD dwReserved); +/* environment.c */ +BOOL +CreateUserEnvironment(IN PWLSESSION Session, + IN LPVOID *lpEnvironment, + IN LPWSTR *lpFullEnv); + /* sas.c */ BOOL SetDefaultLanguage( diff --git a/reactos/base/system/winlogon/winlogon.rbuild b/reactos/base/system/winlogon/winlogon.rbuild index 6a75ed19015..cc5b2a33ddc 100644 --- a/reactos/base/system/winlogon/winlogon.rbuild +++ b/reactos/base/system/winlogon/winlogon.rbuild @@ -8,6 +8,7 @@ advapi32 userenv secur32 + environment.c sas.c screensaver.c setup.c From 2545e830845a92035d3f4050a960f118f1d0251e Mon Sep 17 00:00:00 2001 From: Timo Kreuzer Date: Sat, 8 May 2010 16:38:05 +0000 Subject: [PATCH 11/12] [w32knapi} Patch by Jerome Gardou: add some more tests for NtGdiDeleteObjectApp svn path=/trunk/; revision=47130 --- .../w32knapi/ntgdi/NtGdiCreateCompatibleDC.c | 2 ++ .../w32knapi/ntgdi/NtGdiDeleteObjectApp.c | 22 ++++++++++++++++++- 2 files changed, 23 insertions(+), 1 deletion(-) diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c index 3597eb67dca..130e1005bd1 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c @@ -21,6 +21,8 @@ Test_NtGdiCreateCompatibleDC(PTESTINFO pti) /* The default pen should be GetStockObject(BLACK_PEN) */ hObj = SelectObject(hDC, GetStockObject(WHITE_PEN)); TEST(hObj == GetStockObject(BLACK_PEN)); + + TEST(NtGdiDeleteObjectApp(hDC) != 0); TEST(NtGdiDeleteObjectApp(hDC) != 0); diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c index 0084b109a9a..53d8d251b1a 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c @@ -23,7 +23,27 @@ Test_NtGdiDeleteObjectApp(PTESTINFO pti) TEST(NtGdiDeleteObjectApp(hdc) == 1); TEST(GetLastError() == 0); TEST(IsHandleValid(hdc) == 0); - + + /* Delete a display DC */ + SetLastError(0); + hdc = CreateDC("DISPLAY", NULL, NULL, NULL); + ASSERT(IsHandleValid(hdc) == 1); + TEST(NtGdiDeleteObjectApp(hdc) != 0); + TEST(GetLastError() == 0); + TEST(IsHandleValid(hdc) == 1); + TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); + TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); + + /* Once more */ + SetLastError(0); + hdc = GetDC(0); + ASSERT(IsHandleValid(hdc) == 1); + TEST(NtGdiDeleteObjectApp(hdc) != 0); + TEST(GetLastError() == 0); + TEST(IsHandleValid(hdc) == 1); + TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); + TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); + /* Delete a display DC */ SetLastError(0); hdc = CreateDC("DISPLAY", NULL, NULL, NULL); From bfe6479cf7d995ce442f18857b1208028d6ae643 Mon Sep 17 00:00:00 2001 From: Timo Kreuzer Date: Sat, 8 May 2010 16:42:03 +0000 Subject: [PATCH 12/12] Revert r47130, it was already comitted. svn path=/trunk/; revision=47132 --- .../w32knapi/ntgdi/NtGdiCreateCompatibleDC.c | 2 -- .../w32knapi/ntgdi/NtGdiDeleteObjectApp.c | 22 +------------------ 2 files changed, 1 insertion(+), 23 deletions(-) diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c index 130e1005bd1..3597eb67dca 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiCreateCompatibleDC.c @@ -21,8 +21,6 @@ Test_NtGdiCreateCompatibleDC(PTESTINFO pti) /* The default pen should be GetStockObject(BLACK_PEN) */ hObj = SelectObject(hDC, GetStockObject(WHITE_PEN)); TEST(hObj == GetStockObject(BLACK_PEN)); - - TEST(NtGdiDeleteObjectApp(hDC) != 0); TEST(NtGdiDeleteObjectApp(hDC) != 0); diff --git a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c index 53d8d251b1a..0084b109a9a 100644 --- a/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c +++ b/rostests/apitests/w32knapi/ntgdi/NtGdiDeleteObjectApp.c @@ -23,27 +23,7 @@ Test_NtGdiDeleteObjectApp(PTESTINFO pti) TEST(NtGdiDeleteObjectApp(hdc) == 1); TEST(GetLastError() == 0); TEST(IsHandleValid(hdc) == 0); - - /* Delete a display DC */ - SetLastError(0); - hdc = CreateDC("DISPLAY", NULL, NULL, NULL); - ASSERT(IsHandleValid(hdc) == 1); - TEST(NtGdiDeleteObjectApp(hdc) != 0); - TEST(GetLastError() == 0); - TEST(IsHandleValid(hdc) == 1); - TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); - TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); - - /* Once more */ - SetLastError(0); - hdc = GetDC(0); - ASSERT(IsHandleValid(hdc) == 1); - TEST(NtGdiDeleteObjectApp(hdc) != 0); - TEST(GetLastError() == 0); - TEST(IsHandleValid(hdc) == 1); - TEST(SelectObject(hdc, GetStockObject(WHITE_PEN)) == NULL); - TESTX(GetLastError() == ERROR_INVALID_PARAMETER, "GetLasterror returned 0x%08x\n", (unsigned int)GetLastError()); - + /* Delete a display DC */ SetLastError(0); hdc = CreateDC("DISPLAY", NULL, NULL, NULL);