ReactOS 0.4.16-dev-258-g81860b4
propsheet.c File Reference
#include <stdarg.h>
#include <string.h>
#include "windef.h"
#include "winbase.h"
#include "wingdi.h"
#include "winuser.h"
#include "winnls.h"
#include "commctrl.h"
#include "prsht.h"
#include "comctl32.h"
#include "uxtheme.h"
#include "wine/debug.h"
#include "pshpack2.h"
#include "poppack.h"
Include dependency graph for propsheet.c:

Go to the source code of this file.

Classes

struct  MyDLGTEMPLATEEX
 
struct  MyDLGITEMTEMPLATEEX
 
struct  tagPropPageInfo
 
struct  tagPropSheetInfo
 
struct  PADDING_INFO
 

Macros

#define NONAMELESSUNION
 
#define PSP_INTERNAL_UNICODE   0x80000000
 
#define MAX_CAPTION_LENGTH   255
 
#define MAX_TABTEXT_LENGTH   255
 
#define MAX_BUTTONTEXT_LENGTH   64
 
#define INTRNL_ANY_WIZARD   (PSH_WIZARD | PSH_WIZARD97_OLD | PSH_WIZARD97_NEW | PSH_WIZARD_LITE)
 
#define WIZARD_PADDING   7
 
#define WIZARD_HEADER_HEIGHT   36
 
#define add_flag(a)   if (dwFlags & a) {strcat(string, #a );strcat(string," ");}
 

Typedefs

typedef struct tagPropPageInfo PropPageInfo
 
typedef struct tagPropSheetInfo PropSheetInfo
 

Functions

static PADDING_INFO PROPSHEET_GetPaddingInfo (HWND hwndDlg)
 
static void PROPSHEET_SetTitleW (HWND hwndDlg, DWORD dwStyle, LPCWSTR lpszText)
 
static BOOL PROPSHEET_CanSetCurSel (HWND hwndDlg)
 
static BOOL PROPSHEET_SetCurSel (HWND hwndDlg, int index, int skipdir, HPROPSHEETPAGE hpage)
 
static int PROPSHEET_GetPageIndex (HPROPSHEETPAGE hpage, const PropSheetInfo *psInfo, int original_index)
 
static PADDING_INFO PROPSHEET_GetPaddingInfoWizard (HWND hwndDlg, const PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_DoCommand (HWND hwnd, WORD wID)
 
static BOOL PROPSHEET_RemovePage (HWND hwndDlg, int index, HPROPSHEETPAGE hpage)
 
static INT_PTR CALLBACK PROPSHEET_DialogProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
 
 WINE_DEFAULT_DEBUG_CHANNEL (propsheet)
 
static WCHARheap_strdupW (const WCHAR *str)
 
static WCHARheap_strdupAtoW (const char *str)
 
static VOID PROPSHEET_UnImplementedFlags (DWORD dwFlags)
 
static void PROPSHEET_GetPageRect (const PropSheetInfo *psInfo, HWND hwndDlg, RECT *rc, LPCPROPSHEETPAGEW ppshpage)
 
static INT PROPSHEET_FindPageByResId (const PropSheetInfo *psInfo, LRESULT resId)
 
static void PROPSHEET_CollectSheetInfoCommon (PropSheetInfo *psInfo, DWORD dwFlags)
 
static void PROPSHEET_CollectSheetInfoA (LPCPROPSHEETHEADERA lppsh, PropSheetInfo *psInfo)
 
static void PROPSHEET_CollectSheetInfoW (LPCPROPSHEETHEADERW lppsh, PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_CollectPageInfo (LPCPROPSHEETPAGEW lppsp, PropSheetInfo *psInfo, int index, BOOL resize)
 
static INT_PTR PROPSHEET_CreateDialog (PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_SizeMismatch (HWND hwndDlg, const PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_AdjustSize (HWND hwndDlg, PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_AdjustSizeWizard (HWND hwndDlg, const PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_AdjustButtons (HWND hwndParent, const PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_AdjustButtonsWizard (HWND hwndParent, const PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_CreateTabControl (HWND hwndParent, const PropSheetInfo *psInfo)
 
static LRESULT CALLBACK PROPSHEET_WizardSubclassProc (HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam, UINT_PTR uID, DWORD_PTR dwRef)
 
static UINT GetTemplateSize (const DLGTEMPLATE *pTemplate)
 
static BOOL PROPSHEET_CreatePage (HWND hwndParent, int index, const PropSheetInfo *psInfo, LPCPROPSHEETPAGEW ppshpage)
 
static VOID PROPSHEET_LoadWizardBitmaps (PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_ShowPage (HWND hwndDlg, int index, PropSheetInfo *psInfo)
 
static BOOL PROPSHEET_Back (HWND hwndDlg)
 
static BOOL PROPSHEET_Next (HWND hwndDlg)
 
static BOOL PROPSHEET_Finish (HWND hwndDlg)
 
static BOOL PROPSHEET_Apply (HWND hwndDlg, LPARAM lParam)
 
static void PROPSHEET_Cancel (HWND hwndDlg, LPARAM lParam)
 
static void PROPSHEET_Help (HWND hwndDlg)
 
static void PROPSHEET_Changed (HWND hwndDlg, HWND hwndDirtyPage)
 
static void PROPSHEET_UnChanged (HWND hwndDlg, HWND hwndCleanPage)
 
static void PROPSHEET_PressButton (HWND hwndDlg, int buttonID)
 
static void PROPSHEET_SetCurSelId (HWND hwndDlg, int id)
 
static void PROPSHEET_SetTitleA (HWND hwndDlg, DWORD dwStyle, LPCSTR lpszText)
 
static void PROPSHEET_SetFinishTextA (HWND hwndDlg, LPCSTR lpszText)
 
static void PROPSHEET_SetFinishTextW (HWND hwndDlg, LPCWSTR lpszText)
 
static LRESULT PROPSHEET_QuerySiblings (HWND hwndDlg, WPARAM wParam, LPARAM lParam)
 
static BOOL PROPSHEET_InsertPage (HWND hwndDlg, HPROPSHEETPAGE hpageInsertAfter, HPROPSHEETPAGE hpage)
 
static BOOL PROPSHEET_AddPage (HWND hwndDlg, HPROPSHEETPAGE hpage)
 
static void PROPSHEET_SetWizButtons (HWND hwndDlg, DWORD dwFlags)
 
static void PROPSHEET_SetHeaderTitleW (HWND hwndDlg, UINT page_index, const WCHAR *title)
 
static void PROPSHEET_SetHeaderTitleA (HWND hwndDlg, UINT page_index, const char *title)
 
static void PROPSHEET_SetHeaderSubTitleW (HWND hwndDlg, UINT page_index, const WCHAR *subtitle)
 
static void PROPSHEET_SetHeaderSubTitleA (HWND hwndDlg, UINT page_index, const char *subtitle)
 
static LRESULT PROPSHEET_HwndToIndex (HWND hwndDlg, HWND hPageDlg)
 
static LRESULT PROPSHEET_IndexToHwnd (HWND hwndDlg, int iPageIndex)
 
static LRESULT PROPSHEET_PageToIndex (HWND hwndDlg, HPROPSHEETPAGE hPage)
 
static LRESULT PROPSHEET_IndexToPage (HWND hwndDlg, int iPageIndex)
 
static LRESULT PROPSHEET_IdToIndex (HWND hwndDlg, int iPageId)
 
static LRESULT PROPSHEET_IndexToId (HWND hwndDlg, int iPageIndex)
 
static LRESULT PROPSHEET_GetResult (HWND hwndDlg)
 
static BOOL PROPSHEET_RecalcPageSizes (HWND hwndDlg)
 
static void PROPSHEET_CleanUp (HWND hwndDlg)
 
static INT do_loop (const PropSheetInfo *psInfo)
 
static INT_PTR PROPSHEET_PropertySheet (PropSheetInfo *psInfo, BOOL unicode)
 
INT_PTR WINAPI PropertySheetA (LPCPROPSHEETHEADERA lppsh)
 
INT_PTR WINAPI PropertySheetW (LPCPROPSHEETHEADERW lppsh)
 
static LPWSTR load_string (HINSTANCE instance, LPCWSTR str)
 
HPROPSHEETPAGE WINAPI CreatePropertySheetPageA (LPCPROPSHEETPAGEA lpPropSheetPage)
 
HPROPSHEETPAGE WINAPI CreatePropertySheetPageW (LPCPROPSHEETPAGEW lpPropSheetPage)
 
BOOL WINAPI DestroyPropertySheetPage (HPROPSHEETPAGE hPropPage)
 
static BOOL PROPSHEET_IsDialogMessage (HWND hwnd, LPMSG lpMsg)
 
static LRESULT PROPSHEET_Paint (HWND hwnd, HDC hdcParam)
 

Variables

static const WCHAR PropSheetInfoStr []
 

Macro Definition Documentation

◆ add_flag

#define add_flag (   a)    if (dwFlags & a) {strcat(string, #a );strcat(string," ");}

Definition at line 197 of file propsheet.c.

◆ INTRNL_ANY_WIZARD

#define INTRNL_ANY_WIZARD   (PSH_WIZARD | PSH_WIZARD97_OLD | PSH_WIZARD97_NEW | PSH_WIZARD_LITE)

Definition at line 151 of file propsheet.c.

◆ MAX_BUTTONTEXT_LENGTH

#define MAX_BUTTONTEXT_LENGTH   64

Definition at line 149 of file propsheet.c.

◆ MAX_CAPTION_LENGTH

#define MAX_CAPTION_LENGTH   255

Definition at line 147 of file propsheet.c.

◆ MAX_TABTEXT_LENGTH

#define MAX_TABTEXT_LENGTH   255

Definition at line 148 of file propsheet.c.

◆ NONAMELESSUNION

#define NONAMELESSUNION

Definition at line 55 of file propsheet.c.

◆ PSP_INTERNAL_UNICODE

#define PSP_INTERNAL_UNICODE   0x80000000

Definition at line 145 of file propsheet.c.

◆ WIZARD_HEADER_HEIGHT

#define WIZARD_HEADER_HEIGHT   36

Definition at line 155 of file propsheet.c.

◆ WIZARD_PADDING

#define WIZARD_PADDING   7

Definition at line 154 of file propsheet.c.

Typedef Documentation

◆ PropPageInfo

◆ PropSheetInfo

Function Documentation

◆ CreatePropertySheetPageA()

HPROPSHEETPAGE WINAPI CreatePropertySheetPageA ( LPCPROPSHEETPAGEA  lpPropSheetPage)

Definition at line 3002 of file propsheet.c.

3004{
3005 PROPSHEETPAGEW *ppsp;
3006
3007 if (lpPropSheetPage->dwSize < PROPSHEETPAGEA_V1_SIZE)
3008 return NULL;
3009
3010 /* original data is used for callback notifications */
3011 if ((lpPropSheetPage->dwFlags & PSP_USECALLBACK) && lpPropSheetPage->pfnCallback)
3012 {
3013 ppsp = Alloc(2 * sizeof(*ppsp));
3014 memcpy(ppsp, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEA)));
3015 memcpy(ppsp + 1, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEA)));
3016 }
3017 else
3018 {
3019 ppsp = Alloc(sizeof(*ppsp));
3020 memcpy(ppsp, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEA)));
3021 }
3022
3023 ppsp->dwFlags &= ~PSP_INTERNAL_UNICODE;
3024
3025 if ( !(ppsp->dwFlags & PSP_DLGINDIRECT) )
3026 {
3027 if (!IS_INTRESOURCE( ppsp->u.pszTemplate ))
3028 {
3029 int len = strlen(lpPropSheetPage->u.pszTemplate) + 1;
3030 char *template = Alloc( len );
3031
3032 ppsp->u.pszTemplate = (LPWSTR)strcpy( template, lpPropSheetPage->u.pszTemplate );
3033 }
3034 }
3035
3036 if (ppsp->dwFlags & PSP_USEICONID)
3037 {
3038 if (!IS_INTRESOURCE( ppsp->u2.pszIcon ))
3039 ppsp->u2.pszIcon = heap_strdupAtoW( lpPropSheetPage->u2.pszIcon );
3040 }
3041
3042 if (ppsp->dwFlags & PSP_USETITLE)
3043 {
3044 if (IS_INTRESOURCE( ppsp->pszTitle ))
3045 ppsp->pszTitle = load_string( ppsp->hInstance, ppsp->pszTitle );
3046 else
3047 ppsp->pszTitle = heap_strdupAtoW( lpPropSheetPage->pszTitle );
3048 }
3049 else
3050 ppsp->pszTitle = NULL;
3051
3052 if (ppsp->dwFlags & PSP_HIDEHEADER)
3053 ppsp->dwFlags &= ~(PSP_USEHEADERTITLE | PSP_USEHEADERSUBTITLE);
3054
3055 if (ppsp->dwFlags & PSP_USEHEADERTITLE)
3056 {
3057 if (IS_INTRESOURCE( ppsp->pszHeaderTitle ))
3058 ppsp->pszHeaderTitle = load_string( ppsp->hInstance, ppsp->pszHeaderTitle );
3059 else
3060 ppsp->pszHeaderTitle = heap_strdupAtoW( lpPropSheetPage->pszHeaderTitle );
3061 }
3062 else
3063 ppsp->pszHeaderTitle = NULL;
3064
3065 if (ppsp->dwFlags & PSP_USEHEADERSUBTITLE)
3066 {
3067 if (IS_INTRESOURCE( ppsp->pszHeaderSubTitle ))
3068 ppsp->pszHeaderSubTitle = load_string( ppsp->hInstance, ppsp->pszHeaderSubTitle );
3069 else
3070 ppsp->pszHeaderSubTitle = heap_strdupAtoW( lpPropSheetPage->pszHeaderSubTitle );
3071 }
3072 else
3073 ppsp->pszHeaderSubTitle = NULL;
3074
3075 if ((ppsp->dwFlags & PSP_USECALLBACK) && ppsp->dwSize > PROPSHEETPAGEA_V1_SIZE && ppsp->pfnCallback)
3076 ppsp->pfnCallback(0, PSPCB_ADDREF, ppsp + 1);
3077
3078 return (HPROPSHEETPAGE)ppsp;
3079}
ACPI_SIZE strlen(const char *String)
Definition: utclib.c:269
char * strcpy(char *DstString, const char *SrcString)
Definition: utclib.c:388
PVOID Alloc(IN DWORD dwFlags, IN SIZE_T dwBytes)
Definition: main.c:63
#define NULL
Definition: types.h:112
static WCHAR * heap_strdupAtoW(const char *str)
Definition: propsheet.c:185
static LPWSTR load_string(HINSTANCE instance, LPCWSTR str)
Definition: propsheet.c:2952
GLenum GLsizei len
Definition: glext.h:6722
#define memcpy(s1, s2, n)
Definition: mkisofs.h:878
#define min(a, b)
Definition: monoChain.cc:55
struct _PSP * HPROPSHEETPAGE
Definition: mstask.idl:90
#define PSP_USEICONID
Definition: prsht.h:25
#define PROPSHEETPAGEA_V1_SIZE
Definition: prsht.h:209
#define PSPCB_ADDREF
Definition: prsht.h:171
#define PSP_USETITLE
Definition: prsht.h:26
#define PSP_USECALLBACK
Definition: prsht.h:30
#define PSP_DLGINDIRECT
Definition: prsht.h:23
DWORD dwFlags
Definition: prsht.h:178
LPCSTR pszTemplate
Definition: prsht.h:181
LPCSTR pszIcon
Definition: prsht.h:186
DWORD dwSize
Definition: prsht.h:177
LPCSTR pszTitle
Definition: prsht.h:188
DWORD dwSize
Definition: prsht.h:214
DWORD dwFlags
Definition: prsht.h:215
LPCWSTR pszIcon
Definition: prsht.h:223
LPCWSTR pszTemplate
Definition: prsht.h:218
LPCWSTR pszTitle
Definition: prsht.h:225
HINSTANCE hInstance
Definition: prsht.h:216
#define IS_INTRESOURCE(i)
Definition: winuser.h:580
WCHAR * LPWSTR
Definition: xmlstorage.h:184

Referenced by init_functions(), PropertySheetA(), and WINHELP_CreateIndexWindow().

◆ CreatePropertySheetPageW()

HPROPSHEETPAGE WINAPI CreatePropertySheetPageW ( LPCPROPSHEETPAGEW  lpPropSheetPage)

Definition at line 3086 of file propsheet.c.

3087{
3088 PROPSHEETPAGEW *ppsp;
3089
3090 if (lpPropSheetPage->dwSize < PROPSHEETPAGEW_V1_SIZE)
3091 return NULL;
3092
3093 /* original data is used for callback notifications */
3094 if ((lpPropSheetPage->dwFlags & PSP_USECALLBACK) && lpPropSheetPage->pfnCallback)
3095 {
3096 ppsp = Alloc(2 * sizeof(*ppsp));
3097 memcpy(ppsp, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEW)));
3098 memcpy(ppsp + 1, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEW)));
3099 }
3100 else
3101 {
3102 ppsp = Alloc(sizeof(*ppsp));
3103 memcpy(ppsp, lpPropSheetPage, min(lpPropSheetPage->dwSize, sizeof(PROPSHEETPAGEW)));
3104 }
3105
3107
3108 if ( !(ppsp->dwFlags & PSP_DLGINDIRECT) )
3109 {
3110 if (!IS_INTRESOURCE( ppsp->u.pszTemplate ))
3111 ppsp->u.pszTemplate = heap_strdupW( lpPropSheetPage->u.pszTemplate );
3112 }
3113
3114 if ( ppsp->dwFlags & PSP_USEICONID )
3115 {
3116 if (!IS_INTRESOURCE( ppsp->u2.pszIcon ))
3117 ppsp->u2.pszIcon = heap_strdupW( lpPropSheetPage->u2.pszIcon );
3118 }
3119
3120 if (ppsp->dwFlags & PSP_USETITLE)
3121 ppsp->pszTitle = load_string( ppsp->hInstance, ppsp->pszTitle );
3122 else
3123 ppsp->pszTitle = NULL;
3124
3125 if (ppsp->dwFlags & PSP_HIDEHEADER)
3126 ppsp->dwFlags &= ~(PSP_USEHEADERTITLE | PSP_USEHEADERSUBTITLE);
3127
3128 if (ppsp->dwFlags & PSP_USEHEADERTITLE)
3129 ppsp->pszHeaderTitle = load_string( ppsp->hInstance, ppsp->pszHeaderTitle );
3130 else
3131 ppsp->pszHeaderTitle = NULL;
3132
3133 if (ppsp->dwFlags & PSP_USEHEADERSUBTITLE)
3134 ppsp->pszHeaderSubTitle = load_string( ppsp->hInstance, ppsp->pszHeaderSubTitle );
3135 else
3136 ppsp->pszHeaderSubTitle = NULL;
3137
3138 if ((ppsp->dwFlags & PSP_USECALLBACK) && ppsp->dwSize > PROPSHEETPAGEW_V1_SIZE && ppsp->pfnCallback)
3139 ppsp->pfnCallback(0, PSPCB_ADDREF, ppsp + 1);
3140
3141 return (HPROPSHEETPAGE)ppsp;
3142}
#define PSP_INTERNAL_UNICODE
Definition: propsheet.c:145
static WCHAR * heap_strdupW(const WCHAR *str)
Definition: propsheet.c:177
#define PROPSHEETPAGEW_V1_SIZE
Definition: prsht.h:246

Referenced by BtrfsPropSheet::AddPages(), BtrfsVolPropSheet::AddPages(), init_functions(), InitializePropertySheetPage(), NetPropPageProvider(), OleCreatePropertyFrameIndirect(), ParallelPortPropPageProvider(), PropertySheetW(), PS2MousePropPageProvider(), SerialPortPropPageProvider(), and SH_CreatePropertySheetPage().

◆ DestroyPropertySheetPage()

BOOL WINAPI DestroyPropertySheetPage ( HPROPSHEETPAGE  hPropPage)

Definition at line 3155 of file propsheet.c.

3156{
3157 PROPSHEETPAGEW *psp = (PROPSHEETPAGEW *)hPropPage;
3158
3159 if (!psp)
3160 return FALSE;
3161
3162 if ((psp->dwFlags & PSP_USECALLBACK) && psp->pfnCallback)
3163 psp->pfnCallback(0, PSPCB_RELEASE, psp + 1);
3164
3165 if (!(psp->dwFlags & PSP_DLGINDIRECT) && !IS_INTRESOURCE( psp->u.pszTemplate ))
3166 Free ((LPVOID)psp->u.pszTemplate);
3167
3168 if ((psp->dwFlags & PSP_USEICONID) && !IS_INTRESOURCE( psp->u2.pszIcon ))
3169 Free ((LPVOID)psp->u2.pszIcon);
3170
3171 if ((psp->dwFlags & PSP_USETITLE) && !IS_INTRESOURCE( psp->pszTitle ))
3172 Free ((LPVOID)psp->pszTitle);
3173
3174 if ((psp->dwFlags & PSP_USEHEADERTITLE) && !IS_INTRESOURCE( psp->pszHeaderTitle ))
3175 Free ((LPVOID)psp->pszHeaderTitle);
3176
3177 if ((psp->dwFlags & PSP_USEHEADERSUBTITLE) && !IS_INTRESOURCE( psp->pszHeaderSubTitle ))
3178 Free ((LPVOID)psp->pszHeaderSubTitle);
3179
3180 Free(hPropPage);
3181
3182 return TRUE;
3183}
#define TRUE
Definition: types.h:120
#define FALSE
Definition: types.h:117
#define PSPCB_RELEASE
Definition: prsht.h:37
_In_opt_ PALLOCATE_FUNCTION _In_opt_ PFREE_FUNCTION Free
Definition: exfuncs.h:815

Referenced by AddNetIdPage(), CNetConnectionPropertyUi::AddPages(), CVfdShExt::AddPages(), CLayerUIPropPage::AddPages(), BtrfsPropSheet::AddPages(), BtrfsVolPropSheet::AddPages(), INetCfgComponentPropertyUi_fnMergePropPages(), init_functions(), NetPropPageProvider(), ParallelPortPropPageProvider(), PropertySheetA(), PropertySheetW(), PROPSHEET_CleanUp(), PROPSHEET_RemovePage(), PropSheetExtProc(), PS2MousePropPageProvider(), and SerialPortPropPageProvider().

◆ do_loop()

static INT do_loop ( const PropSheetInfo psInfo)
static

Definition at line 2800 of file propsheet.c.

2801{
2802 MSG msg = { 0 };
2803 INT ret = 0;
2804 HWND hwnd = psInfo->hwnd;
2805 HWND parent = psInfo->ppshheader.hwndParent;
2806
2807 while(IsWindow(hwnd) && !psInfo->ended && (ret = GetMessageW(&msg, NULL, 0, 0)))
2808 {
2809 if(ret == -1)
2810 break;
2811
2812#ifdef __REACTOS__
2814#else
2815 if(!IsDialogMessageW(hwnd, &msg))
2816#endif
2817 {
2820 }
2821 }
2822
2823 if(ret == 0 && msg.message)
2824 PostQuitMessage(msg.wParam);
2825
2826 if(ret != -1)
2827 ret = psInfo->result;
2828
2829 if(parent)
2831
2833 return ret;
2834}
#define msg(x)
Definition: auth_time.c:54
static BOOL PROPSHEET_IsDialogMessage(HWND hwnd, LPMSG lpMsg)
Definition: propsheet.c:3188
r parent
Definition: btrfs.c:3010
HWND hwndParent
Definition: prsht.h:295
PROPSHEETHEADERW ppshheader
Definition: propsheet.c:110
TW_UINT32 TW_UINT16 TW_UINT16 MSG
Definition: twain.h:1829
int32_t INT
Definition: typedefs.h:58
int ret
_In_ LONG _In_ HWND hwnd
Definition: winddi.h:4023
BOOL WINAPI IsWindow(_In_opt_ HWND)
BOOL WINAPI TranslateMessage(_In_ const MSG *)
BOOL WINAPI IsDialogMessageW(_In_ HWND, _In_ LPMSG)
BOOL WINAPI GetMessageW(_Out_ LPMSG, _In_opt_ HWND, _In_ UINT, _In_ UINT)
__analysis_noreturn void WINAPI PostQuitMessage(_In_ int)
BOOL WINAPI EnableWindow(_In_ HWND, _In_ BOOL)
LRESULT WINAPI DispatchMessageW(_In_ const MSG *)
BOOL WINAPI DestroyWindow(_In_ HWND)

Referenced by PROPSHEET_PropertySheet(), and winetest_loop_todo().

◆ GetTemplateSize()

static UINT GetTemplateSize ( const DLGTEMPLATE pTemplate)
static

Definition at line 1208 of file propsheet.c.

1210{
1211 const WORD* p = (const WORD *)pTemplate;
1212 BOOL istemplateex = (((const MyDLGTEMPLATEEX*)pTemplate)->signature == 0xFFFF);
1213 WORD nrofitems;
1214 UINT ret;
1215
1216 if (istemplateex)
1217 {
1218 /* DLGTEMPLATEEX (not defined in any std. header file) */
1219
1220 TRACE("is DLGTEMPLATEEX\n");
1221 p++; /* dlgVer */
1222 p++; /* signature */
1223 p += 2; /* help ID */
1224 p += 2; /* ext style */
1225 p += 2; /* style */
1226 }
1227 else
1228 {
1229 /* DLGTEMPLATE */
1230
1231 TRACE("is DLGTEMPLATE\n");
1232 p += 2; /* style */
1233 p += 2; /* ext style */
1234 }
1235
1236 nrofitems = (WORD)*p; p++; /* nb items */
1237 p++; /* x */
1238 p++; /* y */
1239 p++; /* width */
1240 p++; /* height */
1241
1242 /* menu */
1243 switch ((WORD)*p)
1244 {
1245 case 0x0000:
1246 p++;
1247 break;
1248 case 0xffff:
1249 p += 2;
1250 break;
1251 default:
1252 TRACE("menu %s\n",debugstr_w( p ));
1253 p += lstrlenW( p ) + 1;
1254 break;
1255 }
1256
1257 /* class */
1258 switch ((WORD)*p)
1259 {
1260 case 0x0000:
1261 p++;
1262 break;
1263 case 0xffff:
1264 p += 2; /* 0xffff plus predefined window class ordinal value */
1265 break;
1266 default:
1267 TRACE("class %s\n",debugstr_w( p ));
1268 p += lstrlenW( p ) + 1;
1269 break;
1270 }
1271
1272 /* title */
1273 TRACE("title %s\n",debugstr_w( p ));
1274 p += lstrlenW( p ) + 1;
1275
1276 /* font, if DS_SETFONT set */
1277 if ((DS_SETFONT & ((istemplateex)? ((const MyDLGTEMPLATEEX*)pTemplate)->style :
1278 pTemplate->style)))
1279 {
1280 p+=(istemplateex)?3:1;
1281 TRACE("font %s\n",debugstr_w( p ));
1282 p += lstrlenW( p ) + 1; /* the font name */
1283 }
1284
1285 /* now process the DLGITEMTEMPLATE(EX) structs (plus custom data)
1286 * that are following the DLGTEMPLATE(EX) data */
1287 TRACE("%d items\n",nrofitems);
1288 while (nrofitems > 0)
1289 {
1290 p = (WORD*)(((DWORD_PTR)p + 3) & ~3); /* DWORD align */
1291
1292 /* skip header */
1293 p += (istemplateex ? sizeof(MyDLGITEMTEMPLATEEX) : sizeof(DLGITEMTEMPLATE))/sizeof(WORD);
1294
1295 /* check class */
1296 switch ((WORD)*p)
1297 {
1298 case 0x0000:
1299 p++;
1300 break;
1301 case 0xffff:
1302 TRACE("class ordinal 0x%08x\n",*(const DWORD*)p);
1303 p += 2;
1304 break;
1305 default:
1306 TRACE("class %s\n",debugstr_w( p ));
1307 p += lstrlenW( p ) + 1;
1308 break;
1309 }
1310
1311 /* check title text */
1312 switch ((WORD)*p)
1313 {
1314 case 0x0000:
1315 p++;
1316 break;
1317 case 0xffff:
1318 TRACE("text ordinal 0x%08x\n",*(const DWORD*)p);
1319 p += 2;
1320 break;
1321 default:
1322 TRACE("text %s\n",debugstr_w( p ));
1323 p += lstrlenW( p ) + 1;
1324 break;
1325 }
1326 p += *p / sizeof(WORD) + 1; /* Skip extra data */
1327 --nrofitems;
1328 }
1329
1330 ret = (p - (const WORD*)pTemplate) * sizeof(WORD);
1331 TRACE("%p %p size 0x%08x\n", p, pTemplate, ret);
1332 return ret;
1333}
Arabic default style
Definition: afstyles.h:94
#define lstrlenW
Definition: compat.h:750
unsigned int BOOL
Definition: ntddk_ex.h:94
unsigned long DWORD
Definition: ntddk_ex.h:95
unsigned short WORD
Definition: ntddk_ex.h:93
GLfloat GLfloat p
Definition: glext.h:8902
#define debugstr_w
Definition: kernel32.h:32
unsigned int UINT
Definition: ndis.h:50
#define TRACE(s)
Definition: solgame.cpp:4
uint32_t DWORD_PTR
Definition: typedefs.h:65
#define DS_SETFONT
Definition: winuser.h:378

Referenced by PROPSHEET_CreatePage().

◆ heap_strdupAtoW()

static WCHAR * heap_strdupAtoW ( const char str)
static

Definition at line 185 of file propsheet.c.

186{
187 WCHAR *ret;
188 INT len;
189
190 len = MultiByteToWideChar(CP_ACP, 0, str, -1, 0, 0);
191 ret = Alloc(len * sizeof(WCHAR));
193
194 return ret;
195}
#define CP_ACP
Definition: compat.h:109
#define MultiByteToWideChar
Definition: compat.h:110
const WCHAR * str
__wchar_t WCHAR
Definition: xmlstorage.h:180

Referenced by CreatePropertySheetPageA(), PROPSHEET_SetHeaderSubTitleA(), and PROPSHEET_SetHeaderTitleA().

◆ heap_strdupW()

static WCHAR * heap_strdupW ( const WCHAR str)
static

Definition at line 177 of file propsheet.c.

178{
179 int len = lstrlenW(str) + 1;
180 WCHAR *ret = Alloc(len * sizeof(WCHAR));
181 lstrcpyW(ret, str);
182 return ret;
183}
#define lstrcpyW
Definition: compat.h:749

Referenced by CreatePropertySheetPageW(), PROPSHEET_CollectPageInfo(), PROPSHEET_CollectSheetInfoW(), PROPSHEET_SetHeaderSubTitleW(), and PROPSHEET_SetHeaderTitleW().

◆ load_string()

static LPWSTR load_string ( HINSTANCE  instance,
LPCWSTR  str 
)
static

Definition at line 2952 of file propsheet.c.

2953{
2954 LPWSTR ret;
2955
2956 if (IS_INTRESOURCE(str))
2957 {
2958 HRSRC hrsrc;
2959 HGLOBAL hmem;
2960 WCHAR *ptr;
2961 WORD i, id = LOWORD(str);
2962 UINT len;
2963
2964 if (!(hrsrc = FindResourceW( instance, MAKEINTRESOURCEW((id >> 4) + 1), (LPWSTR)RT_STRING )))
2965 return NULL;
2966 if (!(hmem = LoadResource( instance, hrsrc ))) return NULL;
2967 if (!(ptr = LockResource( hmem ))) return NULL;
2968 for (i = id & 0x0f; i > 0; i--) ptr += *ptr + 1;
2969 len = *ptr;
2970 if (!len) return NULL;
2971 ret = Alloc( (len + 1) * sizeof(WCHAR) );
2972 if (ret)
2973 {
2974 memcpy( ret, ptr + 1, len * sizeof(WCHAR) );
2975 ret[len] = 0;
2976 }
2977 }
2978 else
2979 {
2980 int len = (lstrlenW(str) + 1) * sizeof(WCHAR);
2981 ret = Alloc( len );
2982 if (ret) memcpy( ret, str, len );
2983 }
2984 return ret;
2985}
static HINSTANCE instance
Definition: main.c:40
HRSRC WINAPI FindResourceW(HINSTANCE hModule, LPCWSTR name, LPCWSTR type)
Definition: res.c:176
LPVOID WINAPI LockResource(HGLOBAL handle)
Definition: res.c:550
HGLOBAL WINAPI LoadResource(HINSTANCE hModule, HRSRC hRsrc)
Definition: res.c:532
GLsizei GLenum const GLvoid GLsizei GLenum GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLint GLint GLint GLshort GLshort GLshort GLubyte GLubyte GLubyte GLuint GLuint GLuint GLushort GLushort GLushort GLbyte GLbyte GLbyte GLbyte GLdouble GLdouble GLdouble GLdouble GLfloat GLfloat GLfloat GLfloat GLint GLint GLint GLint GLshort GLshort GLshort GLshort GLubyte GLubyte GLubyte GLubyte GLuint GLuint GLuint GLuint GLushort GLushort GLushort GLushort GLboolean const GLdouble const GLfloat const GLint const GLshort const GLbyte const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLdouble const GLfloat const GLfloat const GLint const GLint const GLshort const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort const GLdouble const GLfloat const GLint const GLshort GLenum GLenum GLenum GLfloat GLenum GLint GLenum GLenum GLenum GLfloat GLenum GLenum GLint GLenum GLfloat GLenum GLint GLint GLushort GLenum GLenum GLfloat GLenum GLenum GLint GLfloat const GLubyte GLenum GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLint GLint GLsizei GLsizei GLint GLenum GLenum const GLvoid GLenum GLenum const GLfloat GLenum GLenum const GLint GLenum GLenum const GLdouble GLenum GLenum const GLfloat GLenum GLenum const GLint GLsizei GLuint GLfloat GLuint GLbitfield GLfloat GLint GLuint GLboolean GLenum GLfloat GLenum GLbitfield GLenum GLfloat GLfloat GLint GLint const GLfloat GLenum GLfloat GLfloat GLint GLint GLfloat GLfloat GLint GLint const GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat GLint GLfloat GLfloat const GLdouble const GLfloat const GLdouble const GLfloat GLint i
Definition: glfuncs.h:248
static PVOID ptr
Definition: dispmode.c:27
#define LOWORD(l)
Definition: pedump.c:82
#define RT_STRING
Definition: pedump.c:368
#define MAKEINTRESOURCEW(i)
Definition: winuser.h:582

Referenced by CreatePropertySheetPageA(), and CreatePropertySheetPageW().

◆ PropertySheetA()

INT_PTR WINAPI PropertySheetA ( LPCPROPSHEETHEADERA  lppsh)

Definition at line 2875 of file propsheet.c.

2876{
2877 PropSheetInfo* psInfo = GlobalAlloc(GPTR, sizeof(PropSheetInfo));
2878 UINT i, n;
2879 const BYTE* pByte;
2880
2881 TRACE("(%p)\n", lppsh);
2882
2883 PROPSHEET_CollectSheetInfoA(lppsh, psInfo);
2884
2885 psInfo->proppage = Alloc(sizeof(PropPageInfo) * lppsh->nPages);
2886 pByte = (const BYTE*) psInfo->ppshheader.u3.ppsp;
2887
2888 for (n = i = 0; i < lppsh->nPages; i++, n++)
2889 {
2890 if (!psInfo->usePropPage)
2891 psInfo->proppage[n].hpage = psInfo->ppshheader.u3.phpage[i];
2892 else
2893 {
2895 pByte += ((LPCPROPSHEETPAGEA)pByte)->dwSize;
2896 }
2897
2899 psInfo, n, TRUE))
2900 {
2901 if (psInfo->usePropPage)
2903 n--;
2904 psInfo->nPages--;
2905 }
2906 }
2907
2908 return PROPSHEET_PropertySheet(psInfo, FALSE);
2909}
static void PROPSHEET_CollectSheetInfoA(LPCPROPSHEETHEADERA lppsh, PropSheetInfo *psInfo)
Definition: propsheet.c:316
static BOOL PROPSHEET_CollectPageInfo(LPCPROPSHEETPAGEW lppsp, PropSheetInfo *psInfo, int index, BOOL resize)
Definition: propsheet.c:398
static INT_PTR PROPSHEET_PropertySheet(PropSheetInfo *psInfo, BOOL unicode)
Definition: propsheet.c:2841
HPROPSHEETPAGE WINAPI CreatePropertySheetPageA(LPCPROPSHEETPAGEA lpPropSheetPage)
Definition: propsheet.c:3002
BOOL WINAPI DestroyPropertySheetPage(HPROPSHEETPAGE hPropPage)
Definition: propsheet.c:3155
GLdouble n
Definition: glext.h:7729
HGLOBAL NTAPI GlobalAlloc(UINT uFlags, SIZE_T dwBytes)
Definition: heapmem.c:368
#define for
Definition: utility.h:88
const PROPSHEETPAGEA * LPCPROPSHEETPAGEA
Definition: prsht.h:208
LPCPROPSHEETPAGEW ppsp
Definition: prsht.h:308
HPROPSHEETPAGE * phpage
Definition: prsht.h:309
HPROPSHEETPAGE hpage
Definition: propsheet.c:98
PropPageInfo * proppage
Definition: propsheet.c:122
#define GPTR
Definition: winbase.h:322
unsigned char BYTE
Definition: xxhash.c:193

Referenced by init_functions(), and WINHELP_CreateIndexWindow().

◆ PropertySheetW()

INT_PTR WINAPI PropertySheetW ( LPCPROPSHEETHEADERW  lppsh)

Definition at line 2916 of file propsheet.c.

2917{
2918 PropSheetInfo* psInfo = GlobalAlloc(GPTR, sizeof(PropSheetInfo));
2919 UINT i, n;
2920 const BYTE* pByte;
2921
2922 TRACE("(%p)\n", lppsh);
2923
2924 PROPSHEET_CollectSheetInfoW(lppsh, psInfo);
2925
2926 psInfo->proppage = Alloc(sizeof(PropPageInfo) * lppsh->nPages);
2927 pByte = (const BYTE*) psInfo->ppshheader.u3.ppsp;
2928
2929 for (n = i = 0; i < lppsh->nPages; i++, n++)
2930 {
2931 if (!psInfo->usePropPage)
2932 psInfo->proppage[n].hpage = psInfo->ppshheader.u3.phpage[i];
2933 else
2934 {
2936 pByte += ((LPCPROPSHEETPAGEW)pByte)->dwSize;
2937 }
2938
2940 psInfo, n, TRUE))
2941 {
2942 if (psInfo->usePropPage)
2944 n--;
2945 psInfo->nPages--;
2946 }
2947 }
2948
2949 return PROPSHEET_PropertySheet(psInfo, TRUE);
2950}
static void PROPSHEET_CollectSheetInfoW(LPCPROPSHEETHEADERW lppsh, PropSheetInfo *psInfo)
Definition: propsheet.c:360
HPROPSHEETPAGE WINAPI CreatePropertySheetPageW(LPCPROPSHEETPAGEW lpPropSheetPage)
Definition: propsheet.c:3086
const PROPSHEETPAGEW * LPCPROPSHEETPAGEW
Definition: prsht.h:245

Referenced by Applet(), CreatePropSheet(), CustomizeLocalePropertySheet(), dialog_viewproperties(), display_cpl_sheets(), EventLogProperties(), INetCfgComponent_fnRaisePropertyUi(), InitApplet(), LaunchAdvancedTcpipSettings(), MmSysApplet(), OleCreatePropertyFrameIndirect(), PropSheetThread(), CZipExtract::runWizard(), SH_ShowPropertiesDialog(), SH_ShowRecycleBinProperties(), show_cert_dialog(), show_edit_cert_properties_dialog(), show_export_ui(), show_import_ui(), ShowAudioPropertySheet(), ShowDrivePropThreadProc(), ShowFolderOptionsDialogThreadProc(), ShowFullControlPanel(), ShowNetConnectionProperties(), ShowPropSheetW(), ShowStatusPropertyDialog(), SpeakerVolume(), SystemApplet(), and wmain().

◆ PROPSHEET_AddPage()

static BOOL PROPSHEET_AddPage ( HWND  hwndDlg,
HPROPSHEETPAGE  hpage 
)
static

Definition at line 2348 of file propsheet.c.

2349{
2350 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2351 TRACE("hwndDlg %p, hpage %p\n", hwndDlg, hpage);
2352 return PROPSHEET_InsertPage(hwndDlg, UlongToPtr(psInfo->nPages), hpage);
2353}
static const WCHAR PropSheetInfoStr[]
Definition: propsheet.c:142
static BOOL PROPSHEET_InsertPage(HWND hwndDlg, HPROPSHEETPAGE hpageInsertAfter, HPROPSHEETPAGE hpage)
Definition: propsheet.c:2254
#define UlongToPtr(u)
Definition: config.h:106
HANDLE WINAPI GetPropW(_In_ HWND, _In_ LPCWSTR)

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_AdjustButtons()

static BOOL PROPSHEET_AdjustButtons ( HWND  hwndParent,
const PropSheetInfo psInfo 
)
static

Definition at line 838 of file propsheet.c.

839{
840 HWND hwndButton = GetDlgItem(hwndParent, IDOK);
841 RECT rcSheet;
842 int x, y;
843 int num_buttons = 2;
844 int buttonWidth, buttonHeight;
846
847 if (psInfo->hasApply)
848 num_buttons++;
849
850 if (psInfo->hasHelp)
851 num_buttons++;
852
853 /*
854 * Obtain the size of the buttons.
855 */
856 GetClientRect(hwndButton, &rcSheet);
857 buttonWidth = rcSheet.right;
858 buttonHeight = rcSheet.bottom;
859
860 /*
861 * Get the size of the property sheet.
862 */
863 GetClientRect(hwndParent, &rcSheet);
864
865 /*
866 * All buttons will be at this y coordinate.
867 */
868 y = rcSheet.bottom - (padding.y + buttonHeight);
869
870 /*
871 * Position OK button and make it default.
872 */
873 hwndButton = GetDlgItem(hwndParent, IDOK);
874
875 x = rcSheet.right - ((padding.x + buttonWidth) * num_buttons);
876
877 SetWindowPos(hwndButton, 0, x, y, 0, 0,
879
881
882
883 /*
884 * Position Cancel button.
885 */
886 hwndButton = GetDlgItem(hwndParent, IDCANCEL);
887
888 x += padding.x + buttonWidth;
889
890 SetWindowPos(hwndButton, 0, x, y, 0, 0,
892
893 /*
894 * Position Apply button.
895 */
897
898 if(psInfo->hasApply)
899 x += padding.x + buttonWidth;
900 else
901 ShowWindow(hwndButton, SW_HIDE);
902
903 SetWindowPos(hwndButton, 0, x, y, 0, 0,
905 EnableWindow(hwndButton, FALSE);
906
907 /*
908 * Position Help button.
909 */
910 hwndButton = GetDlgItem(hwndParent, IDHELP);
911
912 x += padding.x + buttonWidth;
913 SetWindowPos(hwndButton, 0, x, y, 0, 0,
915
916 if(!psInfo->hasHelp)
917 ShowWindow(hwndButton, SW_HIDE);
918
919 return TRUE;
920}
#define IDC_APPLY_BUTTON
Definition: comctl32.h:54
static HWND hwndParent
Definition: cryptui.c:300
static PADDING_INFO PROPSHEET_GetPaddingInfo(HWND hwndDlg)
Definition: propsheet.c:1054
GLint GLint GLint GLint GLint x
Definition: gl.h:1548
GLint GLint GLint GLint GLint GLint y
Definition: gl.h:1548
static const DWORD padding[]
Definition: mciwnd.c:89
#define IDHELP
Definition: resource_2.h:8
LONG right
Definition: windef.h:308
LONG bottom
Definition: windef.h:309
#define SW_HIDE
Definition: winuser.h:771
#define SWP_NOACTIVATE
Definition: winuser.h:1245
#define DM_SETDEFID
Definition: winuser.h:2102
BOOL WINAPI ShowWindow(_In_ HWND, _In_ int)
#define IDCANCEL
Definition: winuser.h:834
BOOL WINAPI SetWindowPos(_In_ HWND, _In_opt_ HWND, _In_ int, _In_ int, _In_ int, _In_ int, _In_ UINT)
#define SWP_NOSIZE
Definition: winuser.h:1248
HWND WINAPI GetDlgItem(_In_opt_ HWND, _In_ int)
#define IDOK
Definition: winuser.h:833
BOOL WINAPI GetClientRect(_In_ HWND, _Out_ LPRECT)
#define SWP_NOZORDER
Definition: winuser.h:1250
LRESULT WINAPI SendMessageW(_In_ HWND, _In_ UINT, _In_ WPARAM, _In_ LPARAM)

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_AdjustButtonsWizard()

static BOOL PROPSHEET_AdjustButtonsWizard ( HWND  hwndParent,
const PropSheetInfo psInfo 
)
static

Definition at line 927 of file propsheet.c.

929{
930 HWND hwndButton = GetDlgItem(hwndParent, IDCANCEL);
933 RECT rcSheet;
934 int x, y;
935 int num_buttons = 3;
936 int buttonWidth, buttonHeight, lineHeight, lineWidth;
938
939 if (psInfo->hasHelp)
940 num_buttons++;
941 if (psInfo->hasFinish)
942 num_buttons++;
943
944 /*
945 * Obtain the size of the buttons.
946 */
947 GetClientRect(hwndButton, &rcSheet);
948 buttonWidth = rcSheet.right;
949 buttonHeight = rcSheet.bottom;
950
951 GetClientRect(hwndLine, &rcSheet);
952 lineHeight = rcSheet.bottom;
953
954 /*
955 * Get the size of the property sheet.
956 */
957 GetClientRect(hwndParent, &rcSheet);
958
959 /*
960 * All buttons will be at this y coordinate.
961 */
962 y = rcSheet.bottom - (padding.y + buttonHeight);
963
964 /*
965 * Position the Back button.
966 */
968
969 x = rcSheet.right - ((padding.x + buttonWidth) * (num_buttons - 1)) - buttonWidth;
970
971 SetWindowPos(hwndButton, 0, x, y, 0, 0,
973
974 /*
975 * Position the Next button.
976 */
978
979 x += buttonWidth;
980
981 SetWindowPos(hwndButton, 0, x, y, 0, 0,
983
984 /*
985 * Position the Finish button.
986 */
988
989 if (psInfo->hasFinish)
990 x += padding.x + buttonWidth;
991
992 SetWindowPos(hwndButton, 0, x, y, 0, 0,
994
995 if (!psInfo->hasFinish)
996 ShowWindow(hwndButton, SW_HIDE);
997
998 /*
999 * Position the Cancel button.
1000 */
1001 hwndButton = GetDlgItem(hwndParent, IDCANCEL);
1002
1003 x += padding.x + buttonWidth;
1004
1005 SetWindowPos(hwndButton, 0, x, y, 0, 0,
1007
1008 /*
1009 * Position Help button.
1010 */
1011 hwndButton = GetDlgItem(hwndParent, IDHELP);
1012
1013 if (psInfo->hasHelp)
1014 {
1015 x += padding.x + buttonWidth;
1016
1017 SetWindowPos(hwndButton, 0, x, y, 0, 0,
1019 }
1020 else
1021 ShowWindow(hwndButton, SW_HIDE);
1022
1023 if (psInfo->ppshheader.dwFlags &
1024 (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW | PSH_WIZARD_LITE))
1025 padding.x = 0;
1026
1027 /*
1028 * Position and resize the sunken line.
1029 */
1030 x = padding.x;
1031 y = rcSheet.bottom - ((padding.y * 2) + buttonHeight + lineHeight);
1032
1033 lineWidth = rcSheet.right - (padding.x * 2);
1034 SetWindowPos(hwndLine, 0, x, y, lineWidth, 2,
1036
1037 /*
1038 * Position and resize the header sunken line.
1039 */
1040
1041 SetWindowPos(hwndLineHeader, 0, 0, 0, rcSheet.right, 2,
1043 if (!(psInfo->ppshheader.dwFlags & (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW)))
1044 ShowWindow(hwndLineHeader, SW_HIDE);
1045
1046 return TRUE;
1047}
#define IDC_NEXT_BUTTON
Definition: comctl32.h:56
#define IDC_SUNKEN_LINEHEADER
Definition: comctl32.h:59
#define IDC_FINISH_BUTTON
Definition: comctl32.h:57
#define IDC_BACK_BUTTON
Definition: comctl32.h:55
#define IDC_SUNKEN_LINE
Definition: comctl32.h:58
static PADDING_INFO PROPSHEET_GetPaddingInfoWizard(HWND hwndDlg, const PropSheetInfo *psInfo)
Definition: propsheet.c:1081
DWORD dwFlags
Definition: prsht.h:294
#define SWP_NOMOVE
Definition: winuser.h:1247

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_AdjustSize()

static BOOL PROPSHEET_AdjustSize ( HWND  hwndDlg,
PropSheetInfo psInfo 
)
static

Definition at line 722 of file propsheet.c.

723{
724 HWND hwndTabCtrl = GetDlgItem(hwndDlg, IDC_TABCONTROL);
725 HWND hwndButton = GetDlgItem(hwndDlg, IDOK);
726 RECT rc,tabRect;
727 int buttonHeight;
729 RECT units;
730 LONG style;
731
732 /* Get the height of buttons */
733 GetClientRect(hwndButton, &rc);
734 buttonHeight = rc.bottom;
735
736 /*
737 * Biggest page size.
738 */
739 SetRect(&rc, 0, 0, psInfo->width, psInfo->height);
740 MapDialogRect(hwndDlg, &rc);
741
742 /* retrieve the dialog units */
743 units.left = units.right = 4;
744 units.top = units.bottom = 8;
745 MapDialogRect(hwndDlg, &units);
746
747 /*
748 * Resize the tab control.
749 */
750 GetClientRect(hwndTabCtrl,&tabRect);
751
752 SendMessageW(hwndTabCtrl, TCM_ADJUSTRECT, FALSE, (LPARAM)&tabRect);
753
754 if ((rc.bottom - rc.top) < (tabRect.bottom - tabRect.top))
755 {
756 rc.bottom = rc.top + tabRect.bottom - tabRect.top;
757 psInfo->height = MulDiv((rc.bottom - rc.top),8,units.top);
758 }
759
760 if ((rc.right - rc.left) < (tabRect.right - tabRect.left))
761 {
762 rc.right = rc.left + tabRect.right - tabRect.left;
763 psInfo->width = MulDiv((rc.right - rc.left),4,units.left);
764 }
765
766 SendMessageW(hwndTabCtrl, TCM_ADJUSTRECT, TRUE, (LPARAM)&rc);
767
768 rc.right -= rc.left;
769 rc.bottom -= rc.top;
770 TRACE("setting tab %p, rc (0,0)-(%d,%d)\n",
771 hwndTabCtrl, rc.right, rc.bottom);
772 SetWindowPos(hwndTabCtrl, 0, 0, 0, rc.right, rc.bottom,
774
775 GetClientRect(hwndTabCtrl, &rc);
776
777 TRACE("tab client rc %s\n", wine_dbgstr_rect(&rc));
778
779 rc.right += (padding.x * 2);
780 rc.bottom += buttonHeight + (3 * padding.y);
781
782 style = GetWindowLongW(hwndDlg, GWL_STYLE);
783 if (!(style & WS_CHILD))
785
786 rc.right -= rc.left;
787 rc.bottom -= rc.top;
788
789 /*
790 * Resize the property sheet.
791 */
792 TRACE("setting dialog %p, rc (0,0)-(%d,%d)\n",
793 hwndDlg, rc.right, rc.bottom);
794 SetWindowPos(hwndDlg, 0, 0, 0, rc.right, rc.bottom,
796 return TRUE;
797}
static const char * wine_dbgstr_rect(const RECT *prc)
Definition: atltest.h:160
#define IDC_TABCONTROL
Definition: comctl32.h:53
GLfloat units
Definition: glext.h:11727
INT WINAPI MulDiv(INT nNumber, INT nNumerator, INT nDenominator)
Definition: muldiv.c:25
#define WS_CHILD
Definition: pedump.c:617
long LONG
Definition: pedump.c:60
#define TCM_ADJUSTRECT
Definition: commctrl.h:4090
LONG top
Definition: windef.h:307
LONG left
Definition: windef.h:306
LONG_PTR LPARAM
Definition: windef.h:208
BOOL WINAPI MapDialogRect(_In_ HWND, _Inout_ LPRECT)
BOOL WINAPI AdjustWindowRect(_Inout_ LPRECT, _In_ DWORD, _In_ BOOL)
LONG WINAPI GetWindowLongW(_In_ HWND, _In_ int)
#define GWL_STYLE
Definition: winuser.h:855
BOOL WINAPI SetRect(_Out_ LPRECT, _In_ int, _In_ int, _In_ int, _In_ int)

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_AdjustSizeWizard()

static BOOL PROPSHEET_AdjustSizeWizard ( HWND  hwndDlg,
const PropSheetInfo psInfo 
)
static

Definition at line 804 of file propsheet.c.

805{
806 HWND hwndLine = GetDlgItem(hwndDlg, IDC_SUNKEN_LINE);
807 RECT rc, lineRect, dialogRect;
808
809 /* Biggest page size */
810 SetRect(&rc, 0, 0, psInfo->width, psInfo->height);
811 MapDialogRect(hwndDlg, &rc);
812
813 TRACE("Biggest page %s\n", wine_dbgstr_rect(&rc));
814
815 /* Add space for the buttons row */
816 GetWindowRect(hwndLine, &lineRect);
817 MapWindowPoints(NULL, hwndDlg, (LPPOINT)&lineRect, 2);
818 GetClientRect(hwndDlg, &dialogRect);
819 rc.bottom += dialogRect.bottom - lineRect.top - 1;
820
821 /* Convert the client coordinates to window coordinates */
823
824 /* Resize the property sheet */
825 TRACE("setting dialog %p, rc (0,0)-(%d,%d)\n",
826 hwndDlg, rc.right, rc.bottom);
827 SetWindowPos(hwndDlg, 0, 0, 0, rc.right - rc.left, rc.bottom - rc.top,
829
830 return TRUE;
831}
BOOL WINAPI GetWindowRect(_In_ HWND, _Out_ LPRECT)
int WINAPI MapWindowPoints(_In_opt_ HWND hWndFrom, _In_opt_ HWND hWndTo, _Inout_updates_(cPoints) LPPOINT lpPoints, _In_ UINT cPoints)

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_Apply()

static BOOL PROPSHEET_Apply ( HWND  hwndDlg,
LPARAM  lParam 
)
static

Definition at line 1706 of file propsheet.c.

1707{
1708 int i;
1709 HWND hwndPage;
1710 PSHNOTIFY psn;
1711 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1712
1713 TRACE("active_page %d\n", psInfo->active_page);
1714 if (psInfo->active_page < 0)
1715 return FALSE;
1716
1717 psn.hdr.hwndFrom = hwndDlg;
1718 psn.hdr.idFrom = 0;
1719 psn.lParam = 0;
1720
1721
1722 /*
1723 * Send PSN_KILLACTIVE to the current page.
1724 */
1725 psn.hdr.code = PSN_KILLACTIVE;
1726
1727 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1728
1729 if (SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn) != FALSE)
1730 return FALSE;
1731
1732 /*
1733 * Send PSN_APPLY to all pages.
1734 */
1735 psn.hdr.code = PSN_APPLY;
1736 psn.lParam = lParam;
1737
1738 for (i = 0; i < psInfo->nPages; i++)
1739 {
1740 hwndPage = psInfo->proppage[i].hwndPage;
1741 if (hwndPage)
1742 {
1743 switch (SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn))
1744 {
1745 case PSNRET_INVALID:
1746 PROPSHEET_ShowPage(hwndDlg, i, psInfo);
1747 /* fall through */
1749 return FALSE;
1750 }
1751 }
1752 }
1753
1754 if(lParam)
1755 {
1756 psInfo->activeValid = FALSE;
1757 }
1758 else if(psInfo->active_page >= 0)
1759 {
1760 psn.hdr.code = PSN_SETACTIVE;
1761 psn.lParam = 0;
1762 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1763 SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1764 }
1765
1766 return TRUE;
1767}
LPARAM lParam
Definition: combotst.c:139
static BOOL PROPSHEET_ShowPage(HWND hwndDlg, int index, PropSheetInfo *psInfo)
Definition: propsheet.c:1522
#define PSNRET_INVALID_NOCHANGEPAGE
Definition: prsht.h:131
#define PSNRET_INVALID
Definition: prsht.h:130
#define PSN_KILLACTIVE
Definition: prsht.h:116
#define PSN_APPLY
Definition: prsht.h:117
#define PSN_SETACTIVE
Definition: prsht.h:115
#define WM_NOTIFY
Definition: richedit.h:61
LPARAM lParam
Definition: prsht.h:331
NMHDR hdr
Definition: prsht.h:330
UINT_PTR idFrom
Definition: winuser.h:3161
UINT code
Definition: winuser.h:3162
HWND hwndFrom
Definition: winuser.h:3160

Referenced by PROPSHEET_DialogProc(), and PROPSHEET_DoCommand().

◆ PROPSHEET_Back()

static BOOL PROPSHEET_Back ( HWND  hwndDlg)
static

Definition at line 1583 of file propsheet.c.

1584{
1585 PSHNOTIFY psn;
1586 HWND hwndPage;
1587 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1589 int idx;
1590
1591 TRACE("active_page %d\n", psInfo->active_page);
1592 if (psInfo->active_page < 0)
1593 return FALSE;
1594
1595 psn.hdr.code = PSN_WIZBACK;
1596 psn.hdr.hwndFrom = hwndDlg;
1597 psn.hdr.idFrom = 0;
1598 psn.lParam = 0;
1599
1600 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1601
1602 result = SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1603 if (result == -1)
1604 return FALSE;
1605 else if (result == 0)
1606 idx = psInfo->active_page - 1;
1607 else
1609
1610 if (idx >= 0 && idx < psInfo->nPages)
1611 {
1612 if (PROPSHEET_CanSetCurSel(hwndDlg))
1613 {
1616 PROPSHEET_SetCurSel(hwndDlg, idx, -1, 0);
1617 }
1618 }
1619 return TRUE;
1620}
unsigned int idx
Definition: utils.c:41
static INT PROPSHEET_FindPageByResId(const PropSheetInfo *psInfo, LRESULT resId)
Definition: propsheet.c:273
static BOOL PROPSHEET_SetCurSel(HWND hwndDlg, int index, int skipdir, HPROPSHEETPAGE hpage)
Definition: propsheet.c:1981
static BOOL PROPSHEET_CanSetCurSel(HWND hwndDlg)
Definition: propsheet.c:1942
GLuint64EXT * result
Definition: glext.h:11304
#define PSN_WIZBACK
Definition: prsht.h:120
LONG_PTR LRESULT
Definition: windef.h:209
HWND WINAPI SetFocus(_In_opt_ HWND)

Referenced by PROPSHEET_DoCommand(), and PROPSHEET_PressButton().

◆ PROPSHEET_Cancel()

static void PROPSHEET_Cancel ( HWND  hwndDlg,
LPARAM  lParam 
)
static

Definition at line 1772 of file propsheet.c.

1773{
1774 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1775 HWND hwndPage;
1776 PSHNOTIFY psn;
1777 int i;
1778
1779 TRACE("active_page %d\n", psInfo->active_page);
1780 if (psInfo->active_page < 0)
1781 return;
1782
1783 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1784 psn.hdr.code = PSN_QUERYCANCEL;
1785 psn.hdr.hwndFrom = hwndDlg;
1786 psn.hdr.idFrom = 0;
1787 psn.lParam = 0;
1788
1789 if (SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn))
1790 return;
1791
1792 psn.hdr.code = PSN_RESET;
1793 psn.lParam = lParam;
1794
1795 for (i = 0; i < psInfo->nPages; i++)
1796 {
1797 hwndPage = psInfo->proppage[i].hwndPage;
1798
1799 if (hwndPage)
1800 SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1801 }
1802
1803 if (psInfo->isModeless)
1804 {
1805 /* makes PSM_GETCURRENTPAGEHWND return NULL */
1806 psInfo->activeValid = FALSE;
1807 }
1808 else
1809 psInfo->ended = TRUE;
1810}
#define PSN_QUERYCANCEL
Definition: prsht.h:123
#define PSN_RESET
Definition: prsht.h:118

Referenced by PROPSHEET_DialogProc(), and PROPSHEET_DoCommand().

◆ PROPSHEET_CanSetCurSel()

static BOOL PROPSHEET_CanSetCurSel ( HWND  hwndDlg)
static

Definition at line 1942 of file propsheet.c.

1943{
1944 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1945 HWND hwndPage;
1946 PSHNOTIFY psn;
1947 BOOL res = FALSE;
1948
1949 if (!psInfo)
1950 {
1951 res = FALSE;
1952 goto end;
1953 }
1954
1955 TRACE("active_page %d\n", psInfo->active_page);
1956 if (psInfo->active_page < 0)
1957 {
1958 res = TRUE;
1959 goto end;
1960 }
1961
1962 /*
1963 * Notify the current page.
1964 */
1965 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1966 psn.hdr.code = PSN_KILLACTIVE;
1967 psn.hdr.hwndFrom = hwndDlg;
1968 psn.hdr.idFrom = 0;
1969 psn.lParam = 0;
1970
1971 res = !SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1972
1973end:
1974 TRACE("<-- %d\n", res);
1975 return res;
1976}
GLuint GLuint end
Definition: gl.h:1545
GLuint res
Definition: glext.h:9613

Referenced by PROPSHEET_Back(), PROPSHEET_DialogProc(), PROPSHEET_IsDialogMessage(), PROPSHEET_Next(), and PROPSHEET_SetCurSelId().

◆ PROPSHEET_Changed()

static void PROPSHEET_Changed ( HWND  hwndDlg,
HWND  hwndDirtyPage 
)
static

Definition at line 1837 of file propsheet.c.

1838{
1839 int i;
1840 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1841
1842 TRACE("\n");
1843 if (!psInfo) return;
1844 /*
1845 * Set the dirty flag of this page.
1846 */
1847 for (i = 0; i < psInfo->nPages; i++)
1848 {
1849 if (psInfo->proppage[i].hwndPage == hwndDirtyPage)
1850 psInfo->proppage[i].isDirty = TRUE;
1851 }
1852
1853 /*
1854 * Enable the Apply button.
1855 */
1856 if (psInfo->hasApply)
1857 {
1858 HWND hwndApplyBtn = GetDlgItem(hwndDlg, IDC_APPLY_BUTTON);
1859
1860 EnableWindow(hwndApplyBtn, TRUE);
1861 }
1862}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_CleanUp()

static void PROPSHEET_CleanUp ( HWND  hwndDlg)
static

Definition at line 2744 of file propsheet.c.

2745{
2746 int i;
2747 PropSheetInfo* psInfo = RemovePropW(hwndDlg, PropSheetInfoStr);
2748
2749 TRACE("\n");
2750 if (!psInfo) return;
2751 if (!IS_INTRESOURCE(psInfo->ppshheader.pszCaption))
2752 Free ((LPVOID)psInfo->ppshheader.pszCaption);
2753
2754 for (i = 0; i < psInfo->nPages; i++)
2755 {
2756 PROPSHEETPAGEA* psp = (PROPSHEETPAGEA*)psInfo->proppage[i].hpage;
2757
2758 /* Unsubclass the page dialog window */
2759 if((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD)) &&
2760 (psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
2761 (psp->dwFlags & PSP_HIDEHEADER))
2762 {
2765 }
2766
2767 if(psInfo->proppage[i].hwndPage)
2768 DestroyWindow(psInfo->proppage[i].hwndPage);
2769
2770 if(psp)
2771 {
2772 if (psp->dwFlags & PSP_USETITLE)
2773 Free ((LPVOID)psInfo->proppage[i].pszText);
2774
2776 }
2777 }
2778
2779 DeleteObject(psInfo->hFont);
2780 DeleteObject(psInfo->hFontBold);
2781 /* If we created the bitmaps, destroy them */
2782 if ((psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
2783 (!(psInfo->ppshheader.dwFlags & PSH_USEHBMWATERMARK)) )
2784 DeleteObject(psInfo->ppshheader.u4.hbmWatermark);
2785 if ((psInfo->ppshheader.dwFlags & PSH_HEADER) &&
2786 (!(psInfo->ppshheader.dwFlags & PSH_USEHBMHEADER)) )
2787 DeleteObject(psInfo->ppshheader.u5.hbmHeader);
2788
2789 Free(psInfo->proppage);
2790 Free(psInfo->strPropertiesFor);
2792
2793 GlobalFree(psInfo);
2794}
BOOL WINAPI RemoveWindowSubclass(HWND hWnd, SUBCLASSPROC pfnSubclass, UINT_PTR uID)
Definition: commctrl.c:1397
BOOL WINAPI ImageList_Destroy(HIMAGELIST himl)
Definition: imagelist.c:928
static LRESULT CALLBACK PROPSHEET_WizardSubclassProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam, UINT_PTR uID, DWORD_PTR dwRef)
Definition: propsheet.c:1186
pKey DeleteObject()
HGLOBAL NTAPI GlobalFree(HGLOBAL hMem)
Definition: heapmem.c:611
LPCWSTR pszCaption
Definition: prsht.h:301
LPCWSTR pszText
Definition: propsheet.c:101
HIMAGELIST hImageList
Definition: propsheet.c:127
LPWSTR strPropertiesFor
Definition: propsheet.c:112
HANDLE WINAPI RemovePropW(_In_ HWND, _In_ LPCWSTR)

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_CollectPageInfo()

static BOOL PROPSHEET_CollectPageInfo ( LPCPROPSHEETPAGEW  lppsp,
PropSheetInfo psInfo,
int  index,
BOOL  resize 
)
static

Definition at line 398 of file propsheet.c.

401{
402 const DLGTEMPLATE* pTemplate;
403 const WORD* p;
405 int width, height;
406
407 if (!lppsp)
408 return FALSE;
409
410 TRACE("\n");
411 psInfo->proppage[index].hpage = (HPROPSHEETPAGE)lppsp;
412 psInfo->proppage[index].hwndPage = 0;
413 psInfo->proppage[index].isDirty = FALSE;
414
415 /*
416 * Process property page flags.
417 */
418 dwFlags = lppsp->dwFlags;
419 psInfo->proppage[index].useCallback = (dwFlags & PSP_USECALLBACK) && (lppsp->pfnCallback);
422
423 /* as soon as we have a page with the help flag, set the sheet flag on */
424 if (psInfo->proppage[index].hasHelp)
425 psInfo->hasHelp = TRUE;
426
427 /*
428 * Process page template.
429 */
431 pTemplate = lppsp->u.pResource;
432 else if(dwFlags & PSP_INTERNAL_UNICODE )
433 {
434 HRSRC hResource = FindResourceW(lppsp->hInstance,
435 lppsp->u.pszTemplate,
437 HGLOBAL hTemplate = LoadResource(lppsp->hInstance,
438 hResource);
439 pTemplate = LockResource(hTemplate);
440 }
441 else
442 {
443 HRSRC hResource = FindResourceA(lppsp->hInstance,
444 (LPCSTR)lppsp->u.pszTemplate,
446 HGLOBAL hTemplate = LoadResource(lppsp->hInstance,
447 hResource);
448 pTemplate = LockResource(hTemplate);
449 }
450
451 /*
452 * Extract the size of the page and the caption.
453 */
454 if (!pTemplate)
455 return FALSE;
456
457 p = (const WORD *)pTemplate;
458
459 if (((const MyDLGTEMPLATEEX*)pTemplate)->signature == 0xFFFF)
460 {
461 /* DLGTEMPLATEEX (not defined in any std. header file) */
462
463 p++; /* dlgVer */
464 p++; /* signature */
465 p += 2; /* help ID */
466 p += 2; /* ext style */
467 p += 2; /* style */
468 }
469 else
470 {
471 /* DLGTEMPLATE */
472
473 p += 2; /* style */
474 p += 2; /* ext style */
475 }
476
477 p++; /* nb items */
478 p++; /* x */
479 p++; /* y */
480 width = (WORD)*p; p++;
481 height = (WORD)*p; p++;
482
483 if (lppsp->dwFlags & (PSP_USEHEADERTITLE | PSP_USEHEADERSUBTITLE))
484 psInfo->ppshheader.dwFlags |= PSH_HEADER;
485
486 /* Special calculation for interior wizard pages so the largest page is
487 * calculated correctly. We need to add all the padding and space occupied
488 * by the header so the width and height sums up to the whole wizard client
489 * area. */
490 if ((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW)) &&
491 (psInfo->ppshheader.dwFlags & PSH_HEADER) &&
492 !(dwFlags & PSP_HIDEHEADER))
493 {
495 width += 2 * WIZARD_PADDING;
496 }
497 if (psInfo->ppshheader.dwFlags & PSH_WIZARD)
498 {
499 height += 2 * WIZARD_PADDING;
500 width += 2 * WIZARD_PADDING;
501 }
502
503 /* remember the largest width and height */
504 if (resize)
505 {
506 if (width > psInfo->width)
507 psInfo->width = width;
508
509 if (height > psInfo->height)
510 psInfo->height = height;
511 }
512
513 /* menu */
514 switch ((WORD)*p)
515 {
516 case 0x0000:
517 p++;
518 break;
519 case 0xffff:
520 p += 2;
521 break;
522 default:
523 p += lstrlenW( p ) + 1;
524 break;
525 }
526
527 /* class */
528 switch ((WORD)*p)
529 {
530 case 0x0000:
531 p++;
532 break;
533 case 0xffff:
534 p += 2;
535 break;
536 default:
537 p += lstrlenW( p ) + 1;
538 break;
539 }
540
541 /* Extract the caption */
542 psInfo->proppage[index].pszText = p;
543 TRACE("Tab %d %s\n",index,debugstr_w( p ));
544
545 if (dwFlags & PSP_USETITLE)
546 {
547 WCHAR szTitle[256];
548 const WCHAR *pTitle;
549 static const WCHAR pszNull[] = { '(','n','u','l','l',')',0 };
550
551 if (IS_INTRESOURCE( lppsp->pszTitle ))
552 {
554 pTitle = szTitle;
555 else if (*p)
556 pTitle = p;
557 else
558 pTitle = pszNull;
559 }
560 else
561 pTitle = lppsp->pszTitle;
562
563 psInfo->proppage[index].pszText = heap_strdupW( pTitle );
564 }
565
566 /*
567 * Build the image list for icons
568 */
570 {
571 HICON hIcon;
572 int icon_cx = GetSystemMetrics(SM_CXSMICON);
573 int icon_cy = GetSystemMetrics(SM_CYSMICON);
574
576 hIcon = LoadImageW(lppsp->hInstance, lppsp->u2.pszIcon, IMAGE_ICON,
577 icon_cx, icon_cy, LR_DEFAULTCOLOR);
578 else
579 hIcon = lppsp->u2.hIcon;
580
581 if ( hIcon )
582 {
583 if (psInfo->hImageList == 0 )
584 psInfo->hImageList = ImageList_Create(icon_cx, icon_cy, ILC_COLOR, 1, 1);
585
587 }
588
589 }
590
591 return TRUE;
592}
#define index(s, c)
Definition: various.h:29
#define ARRAY_SIZE(A)
Definition: main.h:20
HIMAGELIST WINAPI ImageList_Create(INT cx, INT cy, UINT flags, INT cInitial, INT cGrow)
Definition: imagelist.c:804
#define WIZARD_HEADER_HEIGHT
Definition: propsheet.c:155
#define WIZARD_PADDING
Definition: propsheet.c:154
HRSRC WINAPI FindResourceA(HMODULE hModule, LPCSTR name, LPCSTR type)
Definition: res.c:155
GLint GLint GLsizei GLsizei height
Definition: gl.h:1546
GLint GLint GLsizei width
Definition: gl.h:1546
GLuint index
Definition: glext.h:6031
if(dx< 0)
Definition: linetemp.h:194
TCHAR szTitle[MAX_LOADSTRING]
Definition: magnifier.c:35
static HICON
Definition: imagelist.c:80
HICON hIcon
Definition: msconfig.c:44
#define RT_DIALOG
Definition: pedump.c:367
#define PSP_HASHELP
Definition: prsht.h:28
#define PSP_USEHICON
Definition: prsht.h:24
#define PSH_WIZARD
Definition: prsht.h:45
#define ImageList_AddIcon(himl, hicon)
Definition: commctrl.h:415
#define ILC_COLOR
Definition: commctrl.h:352
HICON hIcon
Definition: prsht.h:222
LPCDLGTEMPLATE pResource
Definition: prsht.h:219
_In_ PCCERT_CONTEXT _In_ DWORD dwFlags
Definition: wincrypt.h:1176
#define IMAGE_ICON
Definition: winuser.h:212
int WINAPI LoadStringW(_In_opt_ HINSTANCE hInstance, _In_ UINT uID, _Out_writes_to_(cchBufferMax, return+1) LPWSTR lpBuffer, _In_ int cchBufferMax)
HANDLE WINAPI LoadImageW(_In_opt_ HINSTANCE hInst, _In_ LPCWSTR name, _In_ UINT type, _In_ int cx, _In_ int cy, _In_ UINT fuLoad)
Definition: cursoricon.c:2255
#define SM_CYSMICON
Definition: winuser.h:1016
#define SM_CXSMICON
Definition: winuser.h:1015
#define LR_DEFAULTCOLOR
Definition: winuser.h:1090
int WINAPI GetSystemMetrics(_In_ int)
const char * LPCSTR
Definition: xmlstorage.h:183
char * LPSTR
Definition: xmlstorage.h:182

Referenced by PropertySheetA(), PropertySheetW(), and PROPSHEET_InsertPage().

◆ PROPSHEET_CollectSheetInfoA()

static void PROPSHEET_CollectSheetInfoA ( LPCPROPSHEETHEADERA  lppsh,
PropSheetInfo psInfo 
)
static

Definition at line 316 of file propsheet.c.

318{
319 DWORD dwSize = min(lppsh->dwSize,sizeof(PROPSHEETHEADERA));
320 DWORD dwFlags = lppsh->dwFlags;
321
322 psInfo->useCallback = (dwFlags & PSH_USECALLBACK )&& (lppsh->pfnCallback);
323
324 memcpy(&psInfo->ppshheader,lppsh,dwSize);
325 TRACE("\n** PROPSHEETHEADER **\ndwSize\t\t%d\ndwFlags\t\t%08x\nhwndParent\t%p\nhInstance\t%p\npszCaption\t'%s'\nnPages\t\t%d\npfnCallback\t%p\n",
326 lppsh->dwSize, lppsh->dwFlags, lppsh->hwndParent, lppsh->hInstance,
327 debugstr_a(lppsh->pszCaption), lppsh->nPages, lppsh->pfnCallback);
328
329 if (lppsh->dwFlags & INTRNL_ANY_WIZARD)
330 psInfo->ppshheader.pszCaption = NULL;
331 else
332 {
333 if (!IS_INTRESOURCE(lppsh->pszCaption))
334 {
335 int len = MultiByteToWideChar(CP_ACP, 0, lppsh->pszCaption, -1, NULL, 0);
336 WCHAR *caption = Alloc( len*sizeof (WCHAR) );
337
338 MultiByteToWideChar(CP_ACP, 0, lppsh->pszCaption, -1, caption, len);
339 psInfo->ppshheader.pszCaption = caption;
340 }
341 }
342 psInfo->nPages = lppsh->nPages;
343
345 {
346 TRACE("PSH_USEPSTARTPAGE is on\n");
347 psInfo->active_page = 0;
348 }
349 else
350 psInfo->active_page = lppsh->u2.nStartPage;
351
353}
#define INTRNL_ANY_WIZARD
Definition: propsheet.c:151
static void PROPSHEET_CollectSheetInfoCommon(PropSheetInfo *psInfo, DWORD dwFlags)
Definition: propsheet.c:294
#define debugstr_a
Definition: kernel32.h:31
PSDBQUERYRESULT_VISTA PVOID DWORD * dwSize
Definition: env.c:56
#define PSH_USEPSTARTPAGE
Definition: prsht.h:46
#define PSH_USECALLBACK
Definition: prsht.h:48
DWORD dwFlags
Definition: prsht.h:259
PFNPROPSHEETCALLBACK pfnCallback
Definition: prsht.h:276
DWORD dwSize
Definition: prsht.h:258
HINSTANCE hInstance
Definition: prsht.h:261
HWND hwndParent
Definition: prsht.h:260
UINT nStartPage
Definition: prsht.h:269
LPCSTR pszCaption
Definition: prsht.h:266

Referenced by PropertySheetA().

◆ PROPSHEET_CollectSheetInfoCommon()

static void PROPSHEET_CollectSheetInfoCommon ( PropSheetInfo psInfo,
DWORD  dwFlags 
)
static

Definition at line 294 of file propsheet.c.

295{
297
298 psInfo->hasHelp = dwFlags & PSH_HASHELP;
299 psInfo->hasApply = !(dwFlags & PSH_NOAPPLYNOW);
301 psInfo->isModeless = dwFlags & PSH_MODELESS;
303 if (psInfo->active_page < 0 || psInfo->active_page >= psInfo->nPages)
304 psInfo->active_page = 0;
305
306 psInfo->result = 0;
307 psInfo->hImageList = 0;
308 psInfo->activeValid = FALSE;
309}
static VOID PROPSHEET_UnImplementedFlags(DWORD dwFlags)
Definition: propsheet.c:203
#define PSH_MODELESS
Definition: prsht.h:50
#define PSH_HASHELP
Definition: prsht.h:49
#define PSH_WIZARDHASFINISH
Definition: prsht.h:44
#define PSH_PROPSHEETPAGE
Definition: prsht.h:43
#define PSH_NOAPPLYNOW
Definition: prsht.h:47

Referenced by PROPSHEET_CollectSheetInfoA(), and PROPSHEET_CollectSheetInfoW().

◆ PROPSHEET_CollectSheetInfoW()

static void PROPSHEET_CollectSheetInfoW ( LPCPROPSHEETHEADERW  lppsh,
PropSheetInfo psInfo 
)
static

Definition at line 360 of file propsheet.c.

362{
363 DWORD dwSize = min(lppsh->dwSize,sizeof(PROPSHEETHEADERW));
364 DWORD dwFlags = lppsh->dwFlags;
365
366 psInfo->useCallback = (dwFlags & PSH_USECALLBACK) && (lppsh->pfnCallback);
367
368 memcpy(&psInfo->ppshheader,lppsh,dwSize);
369 TRACE("\n** PROPSHEETHEADER **\ndwSize\t\t%d\ndwFlags\t\t%08x\nhwndParent\t%p\nhInstance\t%p\npszCaption\t%s\nnPages\t\t%d\npfnCallback\t%p\n",
370 lppsh->dwSize, lppsh->dwFlags, lppsh->hwndParent, lppsh->hInstance, debugstr_w(lppsh->pszCaption), lppsh->nPages, lppsh->pfnCallback);
371
372 if (lppsh->dwFlags & INTRNL_ANY_WIZARD)
373 psInfo->ppshheader.pszCaption = NULL;
374 else
375 {
376 if (!IS_INTRESOURCE(lppsh->pszCaption))
377 psInfo->ppshheader.pszCaption = heap_strdupW( lppsh->pszCaption );
378 }
379 psInfo->nPages = lppsh->nPages;
380
382 {
383 TRACE("PSH_USEPSTARTPAGE is on\n");
384 psInfo->active_page = 0;
385 }
386 else
387 psInfo->active_page = lppsh->u2.nStartPage;
388
390}
HINSTANCE hInstance
Definition: prsht.h:296
DWORD dwSize
Definition: prsht.h:293
PFNPROPSHEETCALLBACK pfnCallback
Definition: prsht.h:311
UINT nStartPage
Definition: prsht.h:304

Referenced by PropertySheetW().

◆ PROPSHEET_CreateDialog()

static INT_PTR PROPSHEET_CreateDialog ( PropSheetInfo psInfo)
static

Definition at line 599 of file propsheet.c.

600{
601 LRESULT ret;
602 LPCVOID template;
603 LPVOID temp = 0;
604 HRSRC hRes;
605 DWORD resSize;
606 WORD resID = IDD_PROPSHEET;
607
608 TRACE("(%p)\n", psInfo);
610 resID = IDD_WIZARD;
611
612 if( psInfo->unicode )
613 {
615 MAKEINTRESOURCEW(resID),
616 (LPWSTR)RT_DIALOG)))
617 return -1;
618 }
619 else
620 {
622 MAKEINTRESOURCEA(resID),
623 (LPSTR)RT_DIALOG)))
624 return -1;
625 }
626
627 if(!(template = LoadResource(COMCTL32_hModule, hRes)))
628 return -1;
629
630 /*
631 * Make a copy of the dialog template.
632 */
633 resSize = SizeofResource(COMCTL32_hModule, hRes);
634
635 temp = Alloc(2 * resSize);
636
637 if (!temp)
638 return -1;
639
640 memcpy(temp, template, resSize);
641
642 if (psInfo->ppshheader.dwFlags & PSH_NOCONTEXTHELP)
643 {
644 if (((MyDLGTEMPLATEEX*)temp)->signature == 0xFFFF)
645 ((MyDLGTEMPLATEEX*)temp)->style &= ~DS_CONTEXTHELP;
646 else
648 }
649 if ((psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD) &&
651 {
652 if (((MyDLGTEMPLATEEX*)temp)->signature == 0xFFFF)
653 ((MyDLGTEMPLATEEX*)temp)->style |= DS_CONTEXTHELP;
654 else
656 }
657
658 if (psInfo->useCallback)
660
661 /* NOTE: MSDN states "Returns a positive value if successful, or -1
662 * otherwise for modal property sheets.", but this is wrong. The
663 * actual return value is either TRUE (success), FALSE (cancel) or
664 * -1 (error). */
665 if( psInfo->unicode )
666 {
668 temp, psInfo->ppshheader.hwndParent,
670 if ( !ret ) ret = -1;
671 }
672 else
673 {
675 temp, psInfo->ppshheader.hwndParent,
677 if ( !ret ) ret = -1;
678 }
679
680 Free(temp);
681
682 return ret;
683}
#define IDD_WIZARD
Definition: comctl32.h:51
#define IDD_PROPSHEET
Definition: comctl32.h:50
HMODULE COMCTL32_hModule
Definition: commctrl.c:79
static INT_PTR CALLBACK PROPSHEET_DialogProc(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam)
Definition: propsheet.c:3504
DWORD WINAPI SizeofResource(HINSTANCE hModule, HRSRC hRsrc)
Definition: res.c:568
#define PSCB_PRECREATE
Definition: prsht.h:76
#define PSH_WIZARDCONTEXTHELP
Definition: prsht.h:52
static calc_node_t temp
Definition: rpn_ieee.c:38
int32_t INT_PTR
Definition: typedefs.h:64
CONST void * LPCVOID
Definition: windef.h:191
HWND WINAPI CreateDialogIndirectParamA(_In_opt_ HINSTANCE, _In_ LPCDLGTEMPLATE, _In_opt_ HWND, _In_opt_ DLGPROC, _In_ LPARAM)
#define MAKEINTRESOURCEA(i)
Definition: winuser.h:581
#define DS_CONTEXTHELP
Definition: winuser.h:371
HWND WINAPI CreateDialogIndirectParamW(_In_opt_ HINSTANCE, _In_ LPCDLGTEMPLATE, _In_opt_ HWND, _In_opt_ DLGPROC, _In_ LPARAM)

Referenced by PROPSHEET_PropertySheet().

◆ PROPSHEET_CreatePage()

static BOOL PROPSHEET_CreatePage ( HWND  hwndParent,
int  index,
const PropSheetInfo psInfo,
LPCPROPSHEETPAGEW  ppshpage 
)
static

Definition at line 1343 of file propsheet.c.

1347{
1348 const DLGTEMPLATE* pTemplate;
1349 HWND hwndPage;
1350 DWORD resSize;
1351 DLGTEMPLATE* pTemplateCopy = NULL;
1352
1353 TRACE("index %d\n", index);
1354
1355 if (ppshpage == NULL)
1356 {
1357 return FALSE;
1358 }
1359
1360 if (ppshpage->dwFlags & PSP_DLGINDIRECT)
1361 {
1362 pTemplate = ppshpage->u.pResource;
1363 resSize = GetTemplateSize(pTemplate);
1364 }
1365 else if(ppshpage->dwFlags & PSP_INTERNAL_UNICODE)
1366 {
1367 HRSRC hResource;
1368 HANDLE hTemplate;
1369
1370 hResource = FindResourceW(ppshpage->hInstance,
1371 ppshpage->u.pszTemplate,
1372 (LPWSTR)RT_DIALOG);
1373 if(!hResource)
1374 return FALSE;
1375
1376 resSize = SizeofResource(ppshpage->hInstance, hResource);
1377
1378 hTemplate = LoadResource(ppshpage->hInstance, hResource);
1379 if(!hTemplate)
1380 return FALSE;
1381
1382 pTemplate = LockResource(hTemplate);
1383 /*
1384 * Make a copy of the dialog template to make it writable
1385 */
1386 }
1387 else
1388 {
1389 HRSRC hResource;
1390 HANDLE hTemplate;
1391
1392 hResource = FindResourceA(ppshpage->hInstance,
1393 (LPCSTR)ppshpage->u.pszTemplate,
1394 (LPSTR)RT_DIALOG);
1395 if(!hResource)
1396 return FALSE;
1397
1398 resSize = SizeofResource(ppshpage->hInstance, hResource);
1399
1400 hTemplate = LoadResource(ppshpage->hInstance, hResource);
1401 if(!hTemplate)
1402 return FALSE;
1403
1404 pTemplate = LockResource(hTemplate);
1405 /*
1406 * Make a copy of the dialog template to make it writable
1407 */
1408 }
1409 pTemplateCopy = Alloc(resSize);
1410 if (!pTemplateCopy)
1411 return FALSE;
1412
1413 TRACE("copying pTemplate %p into pTemplateCopy %p (%d)\n", pTemplate, pTemplateCopy, resSize);
1414 memcpy(pTemplateCopy, pTemplate, resSize);
1415
1416 if (((MyDLGTEMPLATEEX*)pTemplateCopy)->signature == 0xFFFF)
1417 {
1418 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style |= WS_CHILD | WS_TABSTOP | DS_CONTROL;
1419 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~DS_MODALFRAME;
1420 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_CAPTION;
1421 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_SYSMENU;
1422 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_POPUP;
1423 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_DISABLED;
1424 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_VISIBLE;
1425 ((MyDLGTEMPLATEEX*)pTemplateCopy)->style &= ~WS_THICKFRAME;
1426
1427 ((MyDLGTEMPLATEEX*)pTemplateCopy)->exStyle |= WS_EX_CONTROLPARENT;
1428 }
1429 else
1430 {
1431 pTemplateCopy->style |= WS_CHILD | WS_TABSTOP | DS_CONTROL;
1432 pTemplateCopy->style &= ~DS_MODALFRAME;
1433 pTemplateCopy->style &= ~WS_CAPTION;
1434 pTemplateCopy->style &= ~WS_SYSMENU;
1435 pTemplateCopy->style &= ~WS_POPUP;
1436 pTemplateCopy->style &= ~WS_DISABLED;
1437 pTemplateCopy->style &= ~WS_VISIBLE;
1438 pTemplateCopy->style &= ~WS_THICKFRAME;
1439
1440 pTemplateCopy->dwExtendedStyle |= WS_EX_CONTROLPARENT;
1441 }
1442
1443 if (psInfo->proppage[index].useCallback)
1444 (*(ppshpage->pfnCallback))(0, PSPCB_CREATE,
1445 (LPPROPSHEETPAGEW)ppshpage);
1446
1447 if(ppshpage->dwFlags & PSP_INTERNAL_UNICODE)
1448 hwndPage = CreateDialogIndirectParamW(ppshpage->hInstance,
1449 pTemplateCopy,
1450 hwndParent,
1451 ppshpage->pfnDlgProc,
1452 (LPARAM)ppshpage);
1453 else
1454 hwndPage = CreateDialogIndirectParamA(ppshpage->hInstance,
1455 pTemplateCopy,
1456 hwndParent,
1457 ppshpage->pfnDlgProc,
1458 (LPARAM)ppshpage);
1459 /* Free a no more needed copy */
1460 Free(pTemplateCopy);
1461
1462 if(!hwndPage)
1463 return FALSE;
1464
1465 psInfo->proppage[index].hwndPage = hwndPage;
1466
1467 /* Subclass exterior wizard pages */
1468 if((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD)) &&
1469 (psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
1470 (ppshpage->dwFlags & PSP_HIDEHEADER))
1471 {
1472#ifdef __REACTOS__
1473 if (psInfo->ppshheader.u4.hbmWatermark)
1474#endif
1476 (DWORD_PTR)ppshpage);
1477 }
1478 if (!(psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD))
1480
1481#ifdef __REACTOS__
1483#endif
1484 return TRUE;
1485}
BOOL WINAPI SetWindowSubclass(HWND hWnd, SUBCLASSPROC pfnSubclass, UINT_PTR uIDSubclass, DWORD_PTR dwRef)
Definition: commctrl.c:1268
static void PROPSHEET_UnChanged(HWND hwndDlg, HWND hwndCleanPage)
Definition: propsheet.c:1867
static UINT GetTemplateSize(const DLGTEMPLATE *pTemplate)
Definition: propsheet.c:1208
#define ETDT_ENABLETAB
Definition: dxdiag.c:30
#define WS_TABSTOP
Definition: pedump.c:634
#define PSPCB_CREATE
Definition: prsht.h:38
struct _PROPSHEETPAGEW * LPPROPSHEETPAGEW
DLGPROC pfnDlgProc
Definition: prsht.h:226
HRESULT WINAPI EnableThemeDialogTexture(_In_ HWND hwnd, _In_ DWORD dwFlags)
Definition: uxthemesupp.c:55
#define WS_EX_CONTROLPARENT
Definition: winuser.h:387
#define DS_CONTROL
Definition: winuser.h:372

Referenced by PROPSHEET_InsertPage(), PROPSHEET_SetCurSel(), and PROPSHEET_ShowPage().

◆ PROPSHEET_CreateTabControl()

static BOOL PROPSHEET_CreateTabControl ( HWND  hwndParent,
const PropSheetInfo psInfo 
)
static

Definition at line 1136 of file propsheet.c.

1138{
1139 HWND hwndTabCtrl = GetDlgItem(hwndParent, IDC_TABCONTROL);
1140 TCITEMW item;
1141 int i, nTabs;
1142 int iImage = 0;
1143
1144 TRACE("\n");
1145 item.mask = TCIF_TEXT;
1146 item.cchTextMax = MAX_TABTEXT_LENGTH;
1147
1148 nTabs = psInfo->nPages;
1149
1150 /*
1151 * Set the image list for icons.
1152 */
1153 if (psInfo->hImageList)
1154 {
1155 SendMessageW(hwndTabCtrl, TCM_SETIMAGELIST, 0, (LPARAM)psInfo->hImageList);
1156 }
1157
1158 SendMessageW(hwndTabCtrl, WM_SETREDRAW, 0, 0);
1159 for (i = 0; i < nTabs; i++)
1160 {
1161 if ( psInfo->proppage[i].hasIcon )
1162 {
1163 item.mask |= TCIF_IMAGE;
1164 item.iImage = iImage++;
1165 }
1166 else
1167 {
1168 item.mask &= ~TCIF_IMAGE;
1169 }
1170
1171 item.pszText = (LPWSTR) psInfo->proppage[i].pszText;
1172 SendMessageW(hwndTabCtrl, TCM_INSERTITEMW, i, (LPARAM)&item);
1173 }
1174 SendMessageW(hwndTabCtrl, WM_SETREDRAW, 1, 0);
1175
1176 return TRUE;
1177}
#define MAX_TABTEXT_LENGTH
Definition: propsheet.c:148
static ATOM item
Definition: dde.c:856
#define TCM_SETIMAGELIST
Definition: commctrl.h:3970
#define TCM_INSERTITEMW
Definition: commctrl.h:4052
#define TCIF_TEXT
Definition: commctrl.h:3976
#define TCIF_IMAGE
Definition: commctrl.h:3977
#define WM_SETREDRAW
Definition: winuser.h:1619

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_DialogProc()

static INT_PTR CALLBACK PROPSHEET_DialogProc ( HWND  hwnd,
UINT  uMsg,
WPARAM  wParam,
LPARAM  lParam 
)
static

Definition at line 3504 of file propsheet.c.

3505{
3506 TRACE("hwnd=%p msg=0x%04x wparam=%lx lparam=%lx\n",
3507 hwnd, uMsg, wParam, lParam);
3508
3509 switch (uMsg)
3510 {
3511 case WM_INITDIALOG:
3512 {
3513 PropSheetInfo* psInfo = (PropSheetInfo*) lParam;
3514 WCHAR* strCaption = Alloc(MAX_CAPTION_LENGTH*sizeof(WCHAR));
3515 HWND hwndTabCtrl = GetDlgItem(hwnd, IDC_TABCONTROL);
3516 int idx;
3517 LOGFONTW logFont;
3518
3519 /* Using PropSheetInfoStr to store extra data doesn't match the native
3520 * common control: native uses TCM_[GS]ETITEM
3521 */
3522 SetPropW(hwnd, PropSheetInfoStr, psInfo);
3523
3524 /*
3525 * psInfo->hwnd is not being used by WINE code - it exists
3526 * for compatibility with "real" Windoze. The same about
3527 * SetWindowLongPtr - WINE is only using the PropSheetInfoStr
3528 * property.
3529 */
3530 psInfo->hwnd = hwnd;
3532
3533 if (psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD)
3534 {
3535 /* set up the Next and Back buttons by default */
3537 }
3538
3539 /* Set up fonts */
3541 psInfo->hFont = CreateFontIndirectW (&logFont);
3542 logFont.lfWeight = FW_BOLD;
3543 psInfo->hFontBold = CreateFontIndirectW (&logFont);
3544
3545 /*
3546 * Small icon in the title bar.
3547 */
3548 if ((psInfo->ppshheader.dwFlags & PSH_USEICONID) ||
3549 (psInfo->ppshheader.dwFlags & PSH_USEHICON))
3550 {
3551 HICON hIcon;
3552 int icon_cx = GetSystemMetrics(SM_CXSMICON);
3553 int icon_cy = GetSystemMetrics(SM_CYSMICON);
3554
3555 if (psInfo->ppshheader.dwFlags & PSH_USEICONID)
3557 psInfo->ppshheader.u.pszIcon,
3558 IMAGE_ICON,
3559 icon_cx, icon_cy,
3561 else
3562 hIcon = psInfo->ppshheader.u.hIcon;
3563
3564 SendMessageW(hwnd, WM_SETICON, 0, (LPARAM)hIcon);
3565 }
3566
3567 if (psInfo->ppshheader.dwFlags & PSH_USEHICON)
3568 SendMessageW(hwnd, WM_SETICON, 0, (LPARAM)psInfo->ppshheader.u.hIcon);
3569
3570 psInfo->strPropertiesFor = strCaption;
3571
3573
3575
3577
3578 if (psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD)
3579 {
3580 ShowWindow(hwndTabCtrl, SW_HIDE);
3584 }
3585 else
3586 {
3587 if (PROPSHEET_SizeMismatch(hwnd, psInfo))
3588 {
3589 PROPSHEET_AdjustSize(hwnd, psInfo);
3591 }
3593 }
3594#ifdef __REACTOS__
3595 /* Move the window position if necessary */
3596 {
3597 INT dx, dy;
3598 RECT rcInit;
3600 BOOL bMove = FALSE;
3601
3602 GetWindowRect(hwnd, &rcInit);
3603 dx = rcInit.right - rcInit.left;
3604 dy = rcInit.bottom - rcInit.top;
3605
3606 if (IsWindow(hwndParent))
3607 {
3608 WINDOWPLACEMENT wndpl = { sizeof(wndpl) };
3609 bMove = TRUE;
3610
3611 /* hwndParent can be minimized (See Control_ShowAppletInTaskbar).
3612 Use normal position. */
3614 rcInit = wndpl.rcNormalPosition;
3616 {
3617 /* Is it Right-to-Left layout? */
3619 rcInit.left = rcInit.right - dx - GetSystemMetrics(SM_CXSMICON);
3620 else
3622
3623 rcInit.top += GetSystemMetrics(SM_CYSMICON);
3624 }
3625 }
3626 else
3627 {
3628 /* We cannot foresee CW_USEDEFAULT's position without communicating with USER32.
3629 Use a top-level STATIC control to get the proper position. */
3630 HWND hwndDummy = CreateWindowExW(0, WC_STATICW, NULL, 0,
3633 if (hwndDummy)
3634 {
3635 bMove = TRUE;
3636 GetWindowRect(hwndDummy, &rcInit);
3637 DestroyWindow(hwndDummy);
3638 }
3639 }
3640
3641 if (bMove)
3642 {
3643 MONITORINFO mi = { sizeof(mi) };
3644 HMONITOR hMonitor = MonitorFromWindow(hwnd, MONITOR_DEFAULTTONEAREST);
3645 if (GetMonitorInfo(hMonitor, &mi))
3646 {
3647 /* Try to fit it onto the desktop */
3648 if (mi.rcWork.right < rcInit.left + dx)
3649 rcInit.left = mi.rcWork.right - dx;
3650 if (mi.rcWork.bottom < rcInit.top + dy)
3651 rcInit.top = mi.rcWork.bottom - dy;
3652 if (rcInit.left < mi.rcWork.left)
3653 rcInit.left = mi.rcWork.left;
3654 if (rcInit.top < mi.rcWork.top)
3655 rcInit.top = mi.rcWork.top;
3656 SetWindowPos(hwnd, NULL, rcInit.left, rcInit.top, 0, 0,
3658 }
3659 }
3660 }
3661#endif
3662
3663 if (IS_INTRESOURCE(psInfo->ppshheader.pszCaption) &&
3664 psInfo->ppshheader.hInstance)
3665 {
3666 WCHAR szText[256];
3667
3668 if (LoadStringW(psInfo->ppshheader.hInstance,
3669 (UINT_PTR)psInfo->ppshheader.pszCaption, szText, 255))
3670 PROPSHEET_SetTitleW(hwnd, psInfo->ppshheader.dwFlags, szText);
3671 }
3672 else
3673 {
3675 psInfo->ppshheader.pszCaption);
3676 }
3677
3678
3679 if (psInfo->useCallback)
3680 (*(psInfo->ppshheader.pfnCallback))(hwnd, PSCB_INITIALIZED, 0);
3681
3682 idx = psInfo->active_page;
3683 psInfo->active_page = -1;
3684
3686
3687 /* doing TCM_SETCURSEL seems to be needed even in case of PSH_WIZARD,
3688 * as some programs call TCM_GETCURSEL to get the current selection
3689 * from which to switch to the next page */
3690 SendMessageW(hwndTabCtrl, TCM_SETCURSEL, psInfo->active_page, 0);
3691
3693
3694 /* wizards set their focus during init */
3695 if (psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD)
3696 return FALSE;
3697
3698 return TRUE;
3699 }
3700
3701 case WM_PRINTCLIENT:
3702 case WM_PAINT:
3704 return TRUE;
3705
3706 case WM_DESTROY:
3708 return TRUE;
3709
3710 case WM_CLOSE:
3712 return FALSE; /* let DefDlgProc post us WM_COMMAND/IDCANCEL */
3713
3714 case WM_COMMAND:
3716 {
3718
3719 if (!psInfo)
3720 return FALSE;
3721
3722 /* No default handler, forward notification to active page */
3723 if (psInfo->activeValid && psInfo->active_page != -1)
3724 {
3725 HWND hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
3726 SendMessageW(hwndPage, WM_COMMAND, wParam, lParam);
3727 }
3728 }
3729 return TRUE;
3730
3731 case WM_NOTIFY:
3732 {
3733 NMHDR* pnmh = (LPNMHDR) lParam;
3734
3735 if (pnmh->code == TCN_SELCHANGE)
3736 {
3737 int index = SendMessageW(pnmh->hwndFrom, TCM_GETCURSEL, 0, 0);
3739 }
3740
3741 if(pnmh->code == TCN_SELCHANGING)
3742 {
3745 return TRUE;
3746 }
3747
3748 return FALSE;
3749 }
3750
3751 case WM_SYSCOLORCHANGE:
3753 return FALSE;
3754
3756 {
3758 HWND hwndPage = 0;
3759
3760 if (!psInfo)
3761 return FALSE;
3762
3763 if (psInfo->activeValid && psInfo->active_page != -1)
3764 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
3765
3767
3768 return TRUE;
3769 }
3770
3771 case PSM_CHANGED:
3773 return TRUE;
3774
3775 case PSM_UNCHANGED:
3777 return TRUE;
3778
3779 case PSM_GETTABCONTROL:
3780 {
3781 HWND hwndTabCtrl = GetDlgItem(hwnd, IDC_TABCONTROL);
3782
3784
3785 return TRUE;
3786 }
3787
3788 case PSM_SETCURSEL:
3789 {
3790 BOOL msgResult;
3791
3792 msgResult = PROPSHEET_CanSetCurSel(hwnd);
3793 if(msgResult != FALSE)
3794 {
3795 msgResult = PROPSHEET_SetCurSel(hwnd,
3796 (int)wParam,
3797 1,
3799 }
3800
3802
3803 return TRUE;
3804 }
3805
3806 case PSM_CANCELTOCLOSE:
3807 {
3809 HWND hwndOK = GetDlgItem(hwnd, IDOK);
3810 HWND hwndCancel = GetDlgItem(hwnd, IDCANCEL);
3811
3812 EnableWindow(hwndCancel, FALSE);
3814 SetWindowTextW(hwndOK, buf);
3815
3816 return FALSE;
3817 }
3818
3819 case PSM_RESTARTWINDOWS:
3820 {
3822
3823 if (!psInfo)
3824 return FALSE;
3825
3826 /* reboot system takes precedence over restart windows */
3827 if (psInfo->result != ID_PSREBOOTSYSTEM)
3828 psInfo->result = ID_PSRESTARTWINDOWS;
3829
3830 return TRUE;
3831 }
3832
3833 case PSM_REBOOTSYSTEM:
3834 {
3836
3837 if (!psInfo)
3838 return FALSE;
3839
3840 psInfo->result = ID_PSREBOOTSYSTEM;
3841
3842 return TRUE;
3843 }
3844
3845 case PSM_SETTITLEA:
3847 return TRUE;
3848
3849 case PSM_SETTITLEW:
3851 return TRUE;
3852
3853 case PSM_APPLY:
3854 {
3855 BOOL msgResult = PROPSHEET_Apply(hwnd, 0);
3856
3858
3859 return TRUE;
3860 }
3861
3862 case PSM_QUERYSIBLINGS:
3863 {
3865
3867
3868 return TRUE;
3869 }
3870
3871 case PSM_ADDPAGE:
3872 {
3873 /*
3874 * Note: MSVC++ 6.0 documentation says that PSM_ADDPAGE does not have
3875 * a return value. This is not true. PSM_ADDPAGE returns TRUE
3876 * on success or FALSE otherwise, as specified on MSDN Online.
3877 * Also see the MFC code for
3878 * CPropertySheet::AddPage(CPropertyPage* pPage).
3879 */
3880
3882
3884
3885 return TRUE;
3886 }
3887
3888 case PSM_REMOVEPAGE:
3890 return TRUE;
3891
3893 {
3896 return TRUE;
3897 }
3898
3899 case PSM_PRESSBUTTON:
3901 return TRUE;
3902
3903 case PSM_SETFINISHTEXTA:
3905 return TRUE;
3906
3907 case PSM_SETWIZBUTTONS:
3909 return TRUE;
3910
3911 case PSM_SETCURSELID:
3913 return TRUE;
3914
3915 case PSM_SETFINISHTEXTW:
3917 return FALSE;
3918
3919 case PSM_INSERTPAGE:
3920 {
3923 return TRUE;
3924 }
3925
3926 case PSM_SETHEADERTITLEW:
3928 return TRUE;
3929
3930 case PSM_SETHEADERTITLEA:
3932 return TRUE;
3933
3934 case PSM_SETHEADERSUBTITLEW:
3936 return TRUE;
3937
3938 case PSM_SETHEADERSUBTITLEA:
3940 return TRUE;
3941
3942 case PSM_HWNDTOINDEX:
3943 {
3946 return TRUE;
3947 }
3948
3949 case PSM_INDEXTOHWND:
3950 {
3951 LRESULT msgResult = PROPSHEET_IndexToHwnd(hwnd, (int)wParam);
3953 return TRUE;
3954 }
3955
3956 case PSM_PAGETOINDEX:
3957 {
3960 return TRUE;
3961 }
3962
3963 case PSM_INDEXTOPAGE:
3964 {
3965 LRESULT msgResult = PROPSHEET_IndexToPage(hwnd, (int)wParam);
3967 return TRUE;
3968 }
3969
3970 case PSM_IDTOINDEX:
3971 {
3972 LRESULT msgResult = PROPSHEET_IdToIndex(hwnd, (int)lParam);
3974 return TRUE;
3975 }
3976
3977 case PSM_INDEXTOID:
3978 {
3979 LRESULT msgResult = PROPSHEET_IndexToId(hwnd, (int)wParam);
3981 return TRUE;
3982 }
3983
3984 case PSM_GETRESULT:
3985 {
3986 LRESULT msgResult = PROPSHEET_GetResult(hwnd);
3988 return TRUE;
3989 }
3990
3991 case PSM_RECALCPAGESIZES:
3992 {
3995 return TRUE;
3996 }
3997
3998 default:
3999 return FALSE;
4000 }
4001}
WPARAM wParam
Definition: combotst.c:138
#define IDS_CLOSE
Definition: comctl32.h:61
VOID COMCTL32_RefreshSysColors(void) DECLSPEC_HIDDEN
Definition: commctrl.c:1593
static LRESULT PROPSHEET_HwndToIndex(HWND hwndDlg, HWND hPageDlg)
Definition: propsheet.c:2610
static void PROPSHEET_SetHeaderSubTitleA(HWND hwndDlg, UINT page_index, const char *subtitle)
Definition: propsheet.c:2596
static LRESULT PROPSHEET_IdToIndex(HWND hwndDlg, int iPageId)
Definition: propsheet.c:2669
static void PROPSHEET_PressButton(HWND hwndDlg, int buttonID)
Definition: propsheet.c:1897
static void PROPSHEET_SetHeaderSubTitleW(HWND hwndDlg, UINT page_index, const WCHAR *subtitle)
Definition: propsheet.c:2574
static void PROPSHEET_SetFinishTextA(HWND hwndDlg, LPCSTR lpszText)
Definition: propsheet.c:2175
static BOOL PROPSHEET_AdjustButtonsWizard(HWND hwndParent, const PropSheetInfo *psInfo)
Definition: propsheet.c:927
static void PROPSHEET_CleanUp(HWND hwndDlg)
Definition: propsheet.c:2744
static BOOL PROPSHEET_AdjustSize(HWND hwndDlg, PropSheetInfo *psInfo)
Definition: propsheet.c:722
static void PROPSHEET_Cancel(HWND hwndDlg, LPARAM lParam)
Definition: propsheet.c:1772
static void PROPSHEET_SetHeaderTitleW(HWND hwndDlg, UINT page_index, const WCHAR *title)
Definition: propsheet.c:2538
static void PROPSHEET_SetCurSelId(HWND hwndDlg, int id)
Definition: propsheet.c:2112
static BOOL PROPSHEET_Apply(HWND hwndDlg, LPARAM lParam)
Definition: propsheet.c:1706
static BOOL PROPSHEET_AdjustButtons(HWND hwndParent, const PropSheetInfo *psInfo)
Definition: propsheet.c:838
static LRESULT PROPSHEET_IndexToHwnd(HWND hwndDlg, int iPageIndex)
Definition: propsheet.c:2627
static BOOL PROPSHEET_DoCommand(HWND hwnd, WORD wID)
Definition: propsheet.c:3241
static BOOL PROPSHEET_CreateTabControl(HWND hwndParent, const PropSheetInfo *psInfo)
Definition: propsheet.c:1136
static BOOL PROPSHEET_RecalcPageSizes(HWND hwndDlg)
Definition: propsheet.c:2715
static void PROPSHEET_Changed(HWND hwndDlg, HWND hwndDirtyPage)
Definition: propsheet.c:1837
static void PROPSHEET_SetWizButtons(HWND hwndDlg, DWORD dwFlags)
Definition: propsheet.c:2464
static BOOL PROPSHEET_SizeMismatch(HWND hwndDlg, const PropSheetInfo *psInfo)
Definition: propsheet.c:691
static LRESULT PROPSHEET_IndexToPage(HWND hwndDlg, int iPageIndex)
Definition: propsheet.c:2655
#define MAX_BUTTONTEXT_LENGTH
Definition: propsheet.c:149
static LRESULT PROPSHEET_IndexToId(HWND hwndDlg, int iPageIndex)
Definition: propsheet.c:2687
static BOOL PROPSHEET_RemovePage(HWND hwndDlg, int index, HPROPSHEETPAGE hpage)
Definition: propsheet.c:2358
static BOOL PROPSHEET_AdjustSizeWizard(HWND hwndDlg, const PropSheetInfo *psInfo)
Definition: propsheet.c:804
static void PROPSHEET_SetHeaderTitleA(HWND hwndDlg, UINT page_index, const char *title)
Definition: propsheet.c:2560
static LRESULT PROPSHEET_Paint(HWND hwnd, HDC hdcParam)
Definition: propsheet.c:3303
static BOOL PROPSHEET_AddPage(HWND hwndDlg, HPROPSHEETPAGE hpage)
Definition: propsheet.c:2348
static LRESULT PROPSHEET_PageToIndex(HWND hwndDlg, HPROPSHEETPAGE hPage)
Definition: propsheet.c:2643
static LRESULT PROPSHEET_GetResult(HWND hwndDlg)
Definition: propsheet.c:2706
static void PROPSHEET_SetTitleA(HWND hwndDlg, DWORD dwStyle, LPCSTR lpszText)
Definition: propsheet.c:2128
static VOID PROPSHEET_LoadWizardBitmaps(PropSheetInfo *psInfo)
Definition: propsheet.c:1492
static void PROPSHEET_SetFinishTextW(HWND hwndDlg, LPCWSTR lpszText)
Definition: propsheet.c:2204
static LRESULT PROPSHEET_QuerySiblings(HWND hwndDlg, WPARAM wParam, LPARAM lParam)
Definition: propsheet.c:2233
#define MAX_CAPTION_LENGTH
Definition: propsheet.c:147
static void PROPSHEET_SetTitleW(HWND hwndDlg, DWORD dwStyle, LPCWSTR lpszText)
Definition: propsheet.c:2145
HMODULE WINAPI GetModuleHandleW(LPCWSTR lpModuleName)
Definition: loader.c:838
GLenum GLuint GLenum GLsizei const GLchar * buf
Definition: glext.h:7751
GLint dy
Definition: linetemp.h:97
GLint dx
Definition: linetemp.h:97
static HDC
Definition: imagelist.c:88
unsigned __int3264 UINT_PTR
Definition: mstsclib_h.h:274
HMONITOR WINAPI MonitorFromWindow(HWND, DWORD)
#define ID_PSRESTARTWINDOWS
Definition: prsht.h:132
#define PSM_GETTABCONTROL
Definition: prsht.h:80
#define PSM_CHANGED
Definition: prsht.h:164
#define PSM_ISDIALOGMESSAGE
Definition: prsht.h:96
#define PSM_SETWIZBUTTONS
Definition: prsht.h:157
#define PSH_USEHICON
Definition: prsht.h:41
#define PSM_REMOVEPAGE
Definition: prsht.h:166
#define PSM_ADDPAGE
Definition: prsht.h:165
#define PSM_UNCHANGED
Definition: prsht.h:159
#define PSWIZB_NEXT
Definition: prsht.h:154
#define PSM_GETCURRENTPAGEHWND
Definition: prsht.h:81
#define PSM_RESTARTWINDOWS
Definition: prsht.h:163
#define PSWIZB_BACK
Definition: prsht.h:153
#define PSM_SETTITLEA
Definition: prsht.h:168
#define PSM_SETCURSELID
Definition: prsht.h:104
#define PSM_SETTITLEW
Definition: prsht.h:169
#define PSM_SETFINISHTEXTW
Definition: prsht.h:105
#define PSM_SETFINISHTEXTA
Definition: prsht.h:106
#define PSM_CANCELTOCLOSE
Definition: prsht.h:161
#define ID_PSREBOOTSYSTEM
Definition: prsht.h:133
#define PSH_USEICONID
Definition: prsht.h:42
#define PSCB_INITIALIZED
Definition: prsht.h:75
#define PSM_APPLY
Definition: prsht.h:158
#define PSM_SETCURSEL
Definition: prsht.h:167
#define PSM_PRESSBUTTON
Definition: prsht.h:100
#define PSM_REBOOTSYSTEM
Definition: prsht.h:162
#define PSM_QUERYSIBLINGS
Definition: prsht.h:160
#define TCM_GETCURSEL
Definition: commctrl.h:4067
#define TCN_SELCHANGING
Definition: commctrl.h:4138
#define TCN_SELCHANGE
Definition: commctrl.h:4137
#define TCM_SETCURSEL
Definition: commctrl.h:4070
#define WC_STATICW
Definition: commctrl.h:4685
#define WM_PRINTCLIENT
Definition: richedit.h:70
LONG lfWeight
Definition: dimm.idl:63
LPCWSTR pszIcon
Definition: prsht.h:299
RECT rcNormalPosition
Definition: winuser.h:3298
int WINAPI GetWindowTextW(HWND hWnd, LPWSTR lpString, int nMaxCount)
Definition: window.c:1384
static MONITORINFO mi
Definition: win.c:7338
#define PSM_GETRESULT
Definition: window.cpp:1319
#define FW_BOLD
Definition: wingdi.h:378
HFONT WINAPI CreateFontIndirectW(_In_ const LOGFONTW *)
#define WM_PAINT
Definition: winuser.h:1623
#define GetMonitorInfo
Definition: winuser.h:5803
#define WM_CLOSE
Definition: winuser.h:1624
#define DWLP_USER
Definition: winuser.h:875
#define GetWindowLongPtrW
Definition: winuser.h:4832
BOOL WINAPI GetWindowPlacement(_In_ HWND, _Inout_ WINDOWPLACEMENT *)
#define WM_COMMAND
Definition: winuser.h:1743
#define WM_INITDIALOG
Definition: winuser.h:1742
#define SPI_GETICONTITLELOGFONT
Definition: winuser.h:1383
#define WM_SYSCOLORCHANGE
Definition: winuser.h:1629
BOOL WINAPI IsIconic(_In_ HWND)
BOOL WINAPI SetWindowTextW(_In_ HWND, _In_opt_ LPCWSTR)
HWND WINAPI CreateWindowExW(_In_ DWORD dwExStyle, _In_opt_ LPCWSTR lpClassName, _In_opt_ LPCWSTR lpWindowName, _In_ DWORD dwStyle, _In_ int X, _In_ int Y, _In_ int nWidth, _In_ int nHeight, _In_opt_ HWND hWndParent, _In_opt_ HMENU hMenu, _In_opt_ HINSTANCE hInstance, _In_opt_ LPVOID lpParam)
BOOL WINAPI SetPropW(_In_ HWND, _In_ LPCWSTR, _In_opt_ HANDLE)
struct tagNMHDR * LPNMHDR
BOOL WINAPI SystemParametersInfoW(_In_ UINT uiAction, _In_ UINT uiParam, _Inout_opt_ PVOID pvParam, _In_ UINT fWinIni)
#define CW_USEDEFAULT
Definition: winuser.h:225
#define DWLP_MSGRESULT
Definition: winuser.h:873
#define WM_DESTROY
Definition: winuser.h:1612
#define SetWindowLongPtrW
Definition: winuser.h:5358
#define WS_EX_RTLREADING
Definition: winuser.h:402
BOOL WINAPI IsWindowVisible(_In_ HWND)
#define GWL_EXSTYLE
Definition: winuser.h:854
const WCHAR * LPCWSTR
Definition: xmlstorage.h:185

Referenced by PROPSHEET_CreateDialog().

◆ PROPSHEET_DoCommand()

static BOOL PROPSHEET_DoCommand ( HWND  hwnd,
WORD  wID 
)
static

Definition at line 3241 of file propsheet.c.

3242{
3243
3244 switch (wID) {
3245
3246 case IDOK:
3247 case IDC_APPLY_BUTTON:
3248 {
3249 HWND hwndApplyBtn = GetDlgItem(hwnd, IDC_APPLY_BUTTON);
3250
3251 if (PROPSHEET_Apply(hwnd, wID == IDOK ? 1: 0) == FALSE)
3252 break;
3253
3254 if (wID == IDOK)
3255 {
3257
3258 /* don't overwrite ID_PSRESTARTWINDOWS or ID_PSREBOOTSYSTEM */
3259 if (psInfo->result == 0)
3260 psInfo->result = IDOK;
3261
3262 if (psInfo->isModeless)
3263 psInfo->activeValid = FALSE;
3264 else
3265 psInfo->ended = TRUE;
3266 }
3267 else
3268 EnableWindow(hwndApplyBtn, FALSE);
3269
3270 break;
3271 }
3272
3273 case IDC_BACK_BUTTON:
3275 break;
3276
3277 case IDC_NEXT_BUTTON:
3279 break;
3280
3281 case IDC_FINISH_BUTTON:
3283 break;
3284
3285 case IDCANCEL:
3287 break;
3288
3289 case IDHELP:
3291 break;
3292
3293 default:
3294 return FALSE;
3295 }
3296
3297 return TRUE;
3298}
static BOOL PROPSHEET_Finish(HWND hwndDlg)
Definition: propsheet.c:1668
static BOOL PROPSHEET_Next(HWND hwndDlg)
Definition: propsheet.c:1625
static void PROPSHEET_Help(HWND hwndDlg)
Definition: propsheet.c:1815
static BOOL PROPSHEET_Back(HWND hwndDlg)
Definition: propsheet.c:1583

Referenced by PROPSHEET_DialogProc(), and PROPSHEET_PressButton().

◆ PROPSHEET_FindPageByResId()

static INT PROPSHEET_FindPageByResId ( const PropSheetInfo psInfo,
LRESULT  resId 
)
static

Definition at line 273 of file propsheet.c.

274{
275 INT i;
276
277 for (i = 0; i < psInfo->nPages; i++)
278 {
280
281 /* Fixme: if resource ID is a string shall we use strcmp ??? */
282 if (lppsp->u.pszTemplate == (LPVOID)resId)
283 break;
284 }
285
286 return i;
287}

Referenced by PROPSHEET_Back(), PROPSHEET_Next(), PROPSHEET_SetCurSel(), and PROPSHEET_SetCurSelId().

◆ PROPSHEET_Finish()

static BOOL PROPSHEET_Finish ( HWND  hwndDlg)
static

Definition at line 1668 of file propsheet.c.

1669{
1670 PSHNOTIFY psn;
1671 HWND hwndPage;
1672 LRESULT msgResult = 0;
1673 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1674
1675 TRACE("active_page %d\n", psInfo->active_page);
1676 if (psInfo->active_page < 0)
1677 return FALSE;
1678
1679 psn.hdr.code = PSN_WIZFINISH;
1680 psn.hdr.hwndFrom = hwndDlg;
1681 psn.hdr.idFrom = 0;
1682 psn.lParam = 0;
1683
1684 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1685
1686 msgResult = SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1687
1688 TRACE("msg result %ld\n", msgResult);
1689
1690 if (msgResult != 0)
1691 return FALSE;
1692
1693 if (psInfo->result == 0)
1694 psInfo->result = IDOK;
1695 if (psInfo->isModeless)
1696 psInfo->activeValid = FALSE;
1697 else
1698 psInfo->ended = TRUE;
1699
1700 return TRUE;
1701}
#define PSN_WIZFINISH
Definition: prsht.h:122

Referenced by PROPSHEET_DoCommand(), and PROPSHEET_PressButton().

◆ PROPSHEET_GetPaddingInfo()

static PADDING_INFO PROPSHEET_GetPaddingInfo ( HWND  hwndDlg)
static

Definition at line 1054 of file propsheet.c.

1055{
1056 HWND hwndTab = GetDlgItem(hwndDlg, IDC_TABCONTROL);
1057 RECT rcTab;
1059
1060 GetWindowRect(hwndTab, &rcTab);
1061 MapWindowPoints( 0, hwndDlg, (POINT *)&rcTab, 2 );
1062
1063 padding.x = rcTab.left;
1064 padding.y = rcTab.top;
1065
1066 return padding;
1067}

Referenced by PROPSHEET_AdjustButtons(), and PROPSHEET_AdjustSize().

◆ PROPSHEET_GetPaddingInfoWizard()

static PADDING_INFO PROPSHEET_GetPaddingInfoWizard ( HWND  hwndDlg,
const PropSheetInfo psInfo 
)
static

Definition at line 1081 of file propsheet.c.

1083{
1085 RECT rc;
1086 HWND hwndControl;
1087 INT idButton;
1088 POINT ptButton, ptLine;
1089
1090 TRACE("\n");
1091 if (psInfo->hasHelp)
1092 {
1093 idButton = IDHELP;
1094 }
1095 else
1096 {
1097 if (psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD)
1098 {
1099 idButton = IDC_NEXT_BUTTON;
1100 }
1101 else
1102 {
1103 /* hopefully this is ok */
1104 idButton = IDCANCEL;
1105 }
1106 }
1107
1108 hwndControl = GetDlgItem(hwndDlg, idButton);
1109 GetWindowRect(hwndControl, &rc);
1110 MapWindowPoints( 0, hwndDlg, (POINT *)&rc, 2 );
1111 ptButton.x = rc.left;
1112 ptButton.y = rc.top;
1113
1114 /* Line */
1115 hwndControl = GetDlgItem(hwndDlg, IDC_SUNKEN_LINE);
1116 GetWindowRect(hwndControl, &rc);
1117 MapWindowPoints( 0, hwndDlg, (POINT *)&rc, 2 );
1118 ptLine.x = rc.left;
1119 ptLine.y = rc.bottom;
1120
1121 padding.y = ptButton.y - ptLine.y;
1122
1123 if (padding.y < 0)
1124 ERR("padding negative ! Please report this !\n");
1125
1126 /* this is most probably not correct, but the best we have now */
1127 padding.x = padding.y;
1128 return padding;
1129}
#define ERR(fmt,...)
Definition: precomp.h:57
long y
Definition: polytest.cpp:48
long x
Definition: polytest.cpp:48

Referenced by PROPSHEET_AdjustButtonsWizard().

◆ PROPSHEET_GetPageIndex()

static int PROPSHEET_GetPageIndex ( HPROPSHEETPAGE  hpage,
const PropSheetInfo psInfo,
int  original_index 
)
static

Definition at line 2728 of file propsheet.c.

2729{
2730 int index;
2731
2732 TRACE("page %p index %d\n", page, original_index);
2733
2734 for (index = 0; index < psInfo->nPages; index++)
2735 if (psInfo->proppage[index].hpage == page)
2736 return index;
2737
2738 return original_index;
2739}
Definition: module.h:576

Referenced by PROPSHEET_InsertPage(), PROPSHEET_PageToIndex(), PROPSHEET_RemovePage(), and PROPSHEET_SetCurSel().

◆ PROPSHEET_GetPageRect()

static void PROPSHEET_GetPageRect ( const PropSheetInfo psInfo,
HWND  hwndDlg,
RECT rc,
LPCPROPSHEETPAGEW  ppshpage 
)
static

Definition at line 229 of file propsheet.c.

231{
232 if (psInfo->ppshheader.dwFlags & INTRNL_ANY_WIZARD) {
233 HWND hwndChild;
234 RECT r;
235
236 if (((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD)) &&
237 (psInfo->ppshheader.dwFlags & PSH_HEADER) &&
238 !(ppshpage->dwFlags & PSP_HIDEHEADER)) ||
239 (psInfo->ppshheader.dwFlags & PSH_WIZARD))
240 {
241 rc->left = rc->top = WIZARD_PADDING;
242 }
243 else
244 {
245 rc->left = rc->top = 0;
246 }
247 rc->right = psInfo->width - rc->left;
248 rc->bottom = psInfo->height - rc->top;
249 MapDialogRect(hwndDlg, rc);
250
251 if ((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD)) &&
252 (psInfo->ppshheader.dwFlags & PSH_HEADER) &&
253 !(ppshpage->dwFlags & PSP_HIDEHEADER))
254 {
255 hwndChild = GetDlgItem(hwndDlg, IDC_SUNKEN_LINEHEADER);
256 GetClientRect(hwndChild, &r);
257 MapWindowPoints(hwndChild, hwndDlg, (LPPOINT) &r, 2);
258 rc->top += r.bottom + 1;
259 }
260 } else {
261 HWND hwndTabCtrl = GetDlgItem(hwndDlg, IDC_TABCONTROL);
262 GetClientRect(hwndTabCtrl, rc);
263 SendMessageW(hwndTabCtrl, TCM_ADJUSTRECT, FALSE, (LPARAM)rc);
264 MapWindowPoints(hwndTabCtrl, hwndDlg, (LPPOINT)rc, 2);
265 }
266}
GLdouble GLdouble GLdouble r
Definition: gl.h:2055

Referenced by PROPSHEET_SetCurSel().

◆ PROPSHEET_GetResult()

static LRESULT PROPSHEET_GetResult ( HWND  hwndDlg)
static

Definition at line 2706 of file propsheet.c.

2707{
2708 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2709 return psInfo->result;
2710}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_Help()

static void PROPSHEET_Help ( HWND  hwndDlg)
static

Definition at line 1815 of file propsheet.c.

1816{
1817 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1818 HWND hwndPage;
1819 PSHNOTIFY psn;
1820
1821 TRACE("active_page %d\n", psInfo->active_page);
1822 if (psInfo->active_page < 0)
1823 return;
1824
1825 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1826 psn.hdr.code = PSN_HELP;
1827 psn.hdr.hwndFrom = hwndDlg;
1828 psn.hdr.idFrom = 0;
1829 psn.lParam = 0;
1830
1831 SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1832}
#define PSN_HELP
Definition: prsht.h:119

Referenced by PROPSHEET_DoCommand().

◆ PROPSHEET_HwndToIndex()

static LRESULT PROPSHEET_HwndToIndex ( HWND  hwndDlg,
HWND  hPageDlg 
)
static

Definition at line 2610 of file propsheet.c.

2611{
2612 int index;
2613 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2614
2615 TRACE("(%p, %p)\n", hwndDlg, hPageDlg);
2616
2617 for (index = 0; index < psInfo->nPages; index++)
2618 if (psInfo->proppage[index].hwndPage == hPageDlg)
2619 return index;
2620 WARN("%p not found\n", hPageDlg);
2621 return -1;
2622}
#define WARN(fmt,...)
Definition: precomp.h:61

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_IdToIndex()

static LRESULT PROPSHEET_IdToIndex ( HWND  hwndDlg,
int  iPageId 
)
static

Definition at line 2669 of file propsheet.c.

2670{
2671 int index;
2673 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2674 TRACE("(%p, %d)\n", hwndDlg, iPageId);
2675 for (index = 0; index < psInfo->nPages; index++) {
2676 psp = (LPCPROPSHEETPAGEW)psInfo->proppage[index].hpage;
2677 if (psp->u.pszTemplate == MAKEINTRESOURCEW(iPageId))
2678 return index;
2679 }
2680
2681 return -1;
2682}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_IndexToHwnd()

static LRESULT PROPSHEET_IndexToHwnd ( HWND  hwndDlg,
int  iPageIndex 
)
static

Definition at line 2627 of file propsheet.c.

2628{
2629 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2630 TRACE("(%p, %d)\n", hwndDlg, iPageIndex);
2631 if (!psInfo)
2632 return 0;
2633 if (iPageIndex<0 || iPageIndex>=psInfo->nPages) {
2634 WARN("%d out of range.\n", iPageIndex);
2635 return 0;
2636 }
2637 return (LRESULT)psInfo->proppage[iPageIndex].hwndPage;
2638}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_IndexToId()

static LRESULT PROPSHEET_IndexToId ( HWND  hwndDlg,
int  iPageIndex 
)
static

Definition at line 2687 of file propsheet.c.

2688{
2689 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2691 TRACE("(%p, %d)\n", hwndDlg, iPageIndex);
2692 if (iPageIndex<0 || iPageIndex>=psInfo->nPages) {
2693 WARN("%d out of range.\n", iPageIndex);
2694 return 0;
2695 }
2696 psp = (LPCPROPSHEETPAGEW)psInfo->proppage[iPageIndex].hpage;
2697 if (psp->dwFlags & PSP_DLGINDIRECT || !IS_INTRESOURCE(psp->u.pszTemplate)) {
2698 return 0;
2699 }
2700 return (LRESULT)psp->u.pszTemplate;
2701}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_IndexToPage()

static LRESULT PROPSHEET_IndexToPage ( HWND  hwndDlg,
int  iPageIndex 
)
static

Definition at line 2655 of file propsheet.c.

2656{
2657 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2658 TRACE("(%p, %d)\n", hwndDlg, iPageIndex);
2659 if (iPageIndex<0 || iPageIndex>=psInfo->nPages) {
2660 WARN("%d out of range.\n", iPageIndex);
2661 return 0;
2662 }
2663 return (LRESULT)psInfo->proppage[iPageIndex].hpage;
2664}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_InsertPage()

static BOOL PROPSHEET_InsertPage ( HWND  hwndDlg,
HPROPSHEETPAGE  hpageInsertAfter,
HPROPSHEETPAGE  hpage 
)
static

Definition at line 2254 of file propsheet.c.

2255{
2256 PropSheetInfo *psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2257 PropPageInfo *ppi, *prev_ppi = psInfo->proppage;
2258 HWND hwndTabControl = GetDlgItem(hwndDlg, IDC_TABCONTROL);
2260 TCITEMW item;
2261 int index;
2262
2263 TRACE("hwndDlg %p, hpageInsertAfter %p, hpage %p\n", hwndDlg, hpageInsertAfter, hpage);
2264
2265 if (IS_INTRESOURCE(hpageInsertAfter))
2266 index = LOWORD(hpageInsertAfter);
2267 else
2268 {
2269 index = PROPSHEET_GetPageIndex(hpageInsertAfter, psInfo, -1);
2270 if (index < 0)
2271 {
2272 TRACE("Could not find page to insert after!\n");
2273 return FALSE;
2274 }
2275 index++;
2276 }
2277
2278 if (index > psInfo->nPages)
2279 index = psInfo->nPages;
2280
2281 ppi = Alloc(sizeof(PropPageInfo) * (psInfo->nPages + 1));
2282 if (!ppi)
2283 return FALSE;
2284
2285 /*
2286 * Fill in a new PropPageInfo entry.
2287 */
2288 if (index > 0)
2289 memcpy(ppi, prev_ppi, index * sizeof(PropPageInfo));
2290 memset(&ppi[index], 0, sizeof(PropPageInfo));
2291 if (index < psInfo->nPages)
2292 memcpy(&ppi[index + 1], &prev_ppi[index], (psInfo->nPages - index) * sizeof(PropPageInfo));
2293 psInfo->proppage = ppi;
2294
2295 if (!PROPSHEET_CollectPageInfo(ppsp, psInfo, index, FALSE))
2296 {
2297 psInfo->proppage = prev_ppi;
2298 Free(ppi);
2299 return FALSE;
2300 }
2301
2302 psInfo->proppage[index].hpage = hpage;
2303
2304 if (ppsp->dwFlags & PSP_PREMATURE)
2305 {
2306 /* Create the page but don't show it */
2307 if (!PROPSHEET_CreatePage(hwndDlg, index, psInfo, ppsp))
2308 {
2309 psInfo->proppage = prev_ppi;
2310 Free(ppi);
2311 return FALSE;
2312 }
2313 }
2314
2315 Free(prev_ppi);
2316 psInfo->nPages++;
2317 if (index <= psInfo->active_page)
2318 psInfo->active_page++;
2319
2320 /*
2321 * Add a new tab to the tab control.
2322 */
2323 item.mask = TCIF_TEXT;
2324 item.pszText = (LPWSTR) psInfo->proppage[index].pszText;
2325 item.cchTextMax = MAX_TABTEXT_LENGTH;
2326
2327 if (psInfo->hImageList)
2328 SendMessageW(hwndTabControl, TCM_SETIMAGELIST, 0, (LPARAM)psInfo->hImageList);
2329
2330 if (psInfo->proppage[index].hasIcon)
2331 {
2332 item.mask |= TCIF_IMAGE;
2333 item.iImage = index;
2334 }
2335
2336 SendMessageW(hwndTabControl, TCM_INSERTITEMW, index, (LPARAM)&item);
2337
2338 /* If it is the only page - show it */
2339 if (psInfo->nPages == 1)
2340 PROPSHEET_SetCurSel(hwndDlg, 0, 1, 0);
2341
2342 return TRUE;
2343}
static BOOL PROPSHEET_CreatePage(HWND hwndParent, int index, const PropSheetInfo *psInfo, LPCPROPSHEETPAGEW ppshpage)
Definition: propsheet.c:1343
static int PROPSHEET_GetPageIndex(HPROPSHEETPAGE hpage, const PropSheetInfo *psInfo, int original_index)
Definition: propsheet.c:2728
static LONG active_page
Definition: propsheet.c:37
#define PSP_PREMATURE
Definition: prsht.h:31
#define memset(x, y, z)
Definition: compat.h:39

Referenced by PROPSHEET_AddPage(), and PROPSHEET_DialogProc().

◆ PROPSHEET_IsDialogMessage()

static BOOL PROPSHEET_IsDialogMessage ( HWND  hwnd,
LPMSG  lpMsg 
)
static

Definition at line 3188 of file propsheet.c.

3189{
3191
3192 TRACE("\n");
3193 if (!psInfo || (hwnd != lpMsg->hwnd && !IsChild(hwnd, lpMsg->hwnd)))
3194 return FALSE;
3195
3196 if (lpMsg->message == WM_KEYDOWN && (GetKeyState(VK_CONTROL) & 0x8000))
3197 {
3198 int new_page = 0;
3199 INT dlgCode = SendMessageW(lpMsg->hwnd, WM_GETDLGCODE, 0, (LPARAM)lpMsg);
3200
3201 if (!(dlgCode & DLGC_WANTMESSAGE))
3202 {
3203 switch (lpMsg->wParam)
3204 {
3205 case VK_TAB:
3206 if (GetKeyState(VK_SHIFT) & 0x8000)
3207 new_page = -1;
3208 else
3209 new_page = 1;
3210 break;
3211
3212 case VK_NEXT: new_page = 1; break;
3213 case VK_PRIOR: new_page = -1; break;
3214 }
3215 }
3216
3217 if (new_page)
3218 {
3220 {
3221 new_page += psInfo->active_page;
3222
3223 if (new_page < 0)
3224 new_page = psInfo->nPages - 1;
3225 else if (new_page >= psInfo->nPages)
3226 new_page = 0;
3227
3228 PROPSHEET_SetCurSel(hwnd, new_page, 1, 0);
3229 }
3230
3231 return TRUE;
3232 }
3233 }
3234
3235 return IsDialogMessageW(hwnd, lpMsg);
3236}
UINT message
Definition: winuser.h:3118
HWND hwnd
Definition: winuser.h:3117
WPARAM wParam
Definition: winuser.h:3119
#define VK_TAB
Definition: winuser.h:2202
#define VK_CONTROL
Definition: winuser.h:2206
#define VK_NEXT
Definition: winuser.h:2224
BOOL WINAPI IsChild(_In_ HWND, _In_ HWND)
#define VK_SHIFT
Definition: winuser.h:2205
#define DLGC_WANTMESSAGE
Definition: winuser.h:2616
#define VK_PRIOR
Definition: winuser.h:2223
#define WM_KEYDOWN
Definition: winuser.h:1718
#define WM_GETDLGCODE
Definition: winuser.h:1692
SHORT WINAPI GetKeyState(_In_ int)

Referenced by do_loop(), and PROPSHEET_DialogProc().

◆ PROPSHEET_LoadWizardBitmaps()

static VOID PROPSHEET_LoadWizardBitmaps ( PropSheetInfo psInfo)
static

Definition at line 1492 of file propsheet.c.

1493{
1494 if (psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD))
1495 {
1496 /* if PSH_USEHBMWATERMARK is not set, load the resource from pszbmWatermark
1497 and put the HBITMAP in hbmWatermark. Thus all the rest of the code always
1498 considers hbmWatermark as valid. */
1499 if ((psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
1500 !(psInfo->ppshheader.dwFlags & PSH_USEHBMWATERMARK))
1501 {
1502 psInfo->ppshheader.u4.hbmWatermark =
1503 CreateMappedBitmap(psInfo->ppshheader.hInstance, (INT_PTR)psInfo->ppshheader.u4.pszbmWatermark, 0, NULL, 0);
1504 }
1505
1506 /* Same behavior as for watermarks */
1507 if ((psInfo->ppshheader.dwFlags & PSH_HEADER) &&
1508 !(psInfo->ppshheader.dwFlags & PSH_USEHBMHEADER))
1509 {
1510 psInfo->ppshheader.u5.hbmHeader =
1511 CreateMappedBitmap(psInfo->ppshheader.hInstance, (INT_PTR)psInfo->ppshheader.u5.pszbmHeader, 0, NULL, 0);
1512 }
1513 }
1514}
HBITMAP WINAPI CreateMappedBitmap(HINSTANCE hInstance, INT_PTR idBitmap, UINT wFlags, LPCOLORMAP lpColorMap, INT iNumMaps)
Definition: commctrl.c:1005

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_Next()

static BOOL PROPSHEET_Next ( HWND  hwndDlg)
static

Definition at line 1625 of file propsheet.c.

1626{
1627 PSHNOTIFY psn;
1628 HWND hwndPage;
1629 LRESULT msgResult = 0;
1630 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1631 int idx;
1632
1633 TRACE("active_page %d\n", psInfo->active_page);
1634 if (psInfo->active_page < 0)
1635 return FALSE;
1636
1637 psn.hdr.code = PSN_WIZNEXT;
1638 psn.hdr.hwndFrom = hwndDlg;
1639 psn.hdr.idFrom = 0;
1640 psn.lParam = 0;
1641
1642 hwndPage = psInfo->proppage[psInfo->active_page].hwndPage;
1643
1644 msgResult = SendMessageW(hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
1645 if (msgResult == -1)
1646 return FALSE;
1647 else if (msgResult == 0)
1648 idx = psInfo->active_page + 1;
1649 else
1650 idx = PROPSHEET_FindPageByResId(psInfo, msgResult);
1651
1652 if (idx < psInfo->nPages )
1653 {
1654 if (PROPSHEET_CanSetCurSel(hwndDlg) != FALSE)
1655 {
1658 PROPSHEET_SetCurSel(hwndDlg, idx, 1, 0);
1659 }
1660 }
1661
1662 return TRUE;
1663}
#define PSN_WIZNEXT
Definition: prsht.h:121

Referenced by PROPSHEET_DoCommand(), and PROPSHEET_PressButton().

◆ PROPSHEET_PageToIndex()

static LRESULT PROPSHEET_PageToIndex ( HWND  hwndDlg,
HPROPSHEETPAGE  hPage 
)
static

Definition at line 2643 of file propsheet.c.

2644{
2645 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2646
2647 TRACE("(%p, %p)\n", hwndDlg, hPage);
2648
2649 return PROPSHEET_GetPageIndex(hPage, psInfo, -1);
2650}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_Paint()

static LRESULT PROPSHEET_Paint ( HWND  hwnd,
HDC  hdcParam 
)
static

Definition at line 3303 of file propsheet.c.

3304{
3306 PAINTSTRUCT ps;
3307 HDC hdc, hdcSrc;
3308 BITMAP bm;
3309 HBITMAP hbmp;
3310 HPALETTE hOldPal = 0;
3311 int offsety = 0;
3312 HBRUSH hbr;
3313 RECT r, rzone;
3314 LPCPROPSHEETPAGEW ppshpage;
3315 WCHAR szBuffer[256];
3316 int nLength;
3317
3318 hdc = hdcParam ? hdcParam : BeginPaint(hwnd, &ps);
3319 if (!hdc) return 1;
3320
3322
3323 if (psInfo->ppshheader.dwFlags & PSH_USEHPLWATERMARK)
3324 hOldPal = SelectPalette(hdc, psInfo->ppshheader.hplWatermark, FALSE);
3325
3326 if (psInfo->active_page < 0)
3327 ppshpage = NULL;
3328 else
3329 ppshpage = (LPCPROPSHEETPAGEW)psInfo->proppage[psInfo->active_page].hpage;
3330
3331 if ( (ppshpage && !(ppshpage->dwFlags & PSP_HIDEHEADER)) &&
3332 (psInfo->ppshheader.dwFlags & (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW)) &&
3333 (psInfo->ppshheader.dwFlags & PSH_HEADER) )
3334 {
3335 HWND hwndLineHeader = GetDlgItem(hwnd, IDC_SUNKEN_LINEHEADER);
3336 HFONT hOldFont;
3337 COLORREF clrOld = 0;
3338 int oldBkMode = 0;
3339
3340 GetClientRect(hwndLineHeader, &r);
3341 MapWindowPoints(hwndLineHeader, hwnd, (LPPOINT) &r, 2);
3342 SetRect(&rzone, 0, 0, r.right + 1, r.top - 1);
3343
3344 hOldFont = SelectObject(hdc, psInfo->hFontBold);
3345
3346#ifdef __REACTOS__
3347 if (psInfo->ppshheader.u5.hbmHeader)
3348#else
3349 if (psInfo->ppshheader.dwFlags & PSH_USEHBMHEADER)
3350#endif
3351 {
3352 hbmp = SelectObject(hdcSrc, psInfo->ppshheader.u5.hbmHeader);
3353
3354 GetObjectW(psInfo->ppshheader.u5.hbmHeader, sizeof(BITMAP), &bm);
3355 if (psInfo->ppshheader.dwFlags & PSH_WIZARD97_OLD)
3356 {
3357 /* Fill the unoccupied part of the header with color of the
3358 * left-top pixel, but do it only when needed.
3359 */
3360 if (bm.bmWidth < r.right || bm.bmHeight < r.bottom)
3361 {
3362 hbr = CreateSolidBrush(GetPixel(hdcSrc, 0, 0));
3363 r = rzone;
3364 if (bm.bmWidth < r.right)
3365 {
3366 r.left = bm.bmWidth;
3367 FillRect(hdc, &r, hbr);
3368 }
3369 if (bm.bmHeight < r.bottom)
3370 {
3371 r.left = 0;
3372 r.top = bm.bmHeight;
3373 FillRect(hdc, &r, hbr);
3374 }
3375 DeleteObject(hbr);
3376 }
3377
3378 /* Draw the header itself. */
3379 BitBlt(hdc, 0, 0, bm.bmWidth, min(bm.bmHeight, rzone.bottom),
3380 hdcSrc, 0, 0, SRCCOPY);
3381 }
3382 else
3383 {
3384 int margin;
3386 FillRect(hdc, &rzone, hbr);
3387
3388 /* Draw the header bitmap. It's always centered like a
3389 * common 49 x 49 bitmap. */
3390 margin = (rzone.bottom - 49) / 2;
3391 BitBlt(hdc, rzone.right - 49 - margin, margin,
3392 min(bm.bmWidth, 49), min(bm.bmHeight, 49),
3393 hdcSrc, 0, 0, SRCCOPY);
3394
3395 /* NOTE: Native COMCTL32 draws a white stripe over the bitmap
3396 * if its height is smaller than 49 pixels. Because the reason
3397 * for this bug is unknown the current code doesn't try to
3398 * replicate it. */
3399 }
3400
3402 }
3403
3404 clrOld = SetTextColor (hdc, 0x00000000);
3405 oldBkMode = SetBkMode (hdc, TRANSPARENT);
3406
3407 if (ppshpage->dwFlags & PSP_USEHEADERTITLE) {
3408 SetRect(&r, 20, 10, 0, 0);
3409 if (!IS_INTRESOURCE(ppshpage->pszHeaderTitle))
3410 DrawTextW(hdc, ppshpage->pszHeaderTitle, -1, &r, DT_LEFT | DT_SINGLELINE | DT_NOCLIP);
3411 else
3412 {
3413 nLength = LoadStringW(ppshpage->hInstance, (UINT_PTR)ppshpage->pszHeaderTitle,
3414 szBuffer, 256);
3415 if (nLength != 0)
3416 {
3418 }
3419 }
3420 }
3421
3422 if (ppshpage->dwFlags & PSP_USEHEADERSUBTITLE) {
3423 SelectObject(hdc, psInfo->hFont);
3424 SetRect(&r, 40, 25, rzone.right - 69, rzone.bottom);
3425#ifdef __REACTOS__
3426 if (!IS_INTRESOURCE(ppshpage->pszHeaderSubTitle))
3427#else
3428 if (!IS_INTRESOURCE(ppshpage->pszHeaderTitle))
3429#endif
3430 DrawTextW(hdc, ppshpage->pszHeaderSubTitle, -1, &r, DT_LEFT | DT_WORDBREAK);
3431 else
3432 {
3433 nLength = LoadStringW(ppshpage->hInstance, (UINT_PTR)ppshpage->pszHeaderSubTitle,
3434 szBuffer, 256);
3435 if (nLength != 0)
3436 {
3437 DrawTextW(hdc, szBuffer, nLength, &r, DT_LEFT | DT_WORDBREAK);
3438 }
3439 }
3440 }
3441
3442 offsety = rzone.bottom + 2;
3443
3444 SetTextColor(hdc, clrOld);
3445 SetBkMode(hdc, oldBkMode);
3446 SelectObject(hdc, hOldFont);
3447 }
3448
3449 if ( (ppshpage && (ppshpage->dwFlags & PSP_HIDEHEADER)) &&
3450 (psInfo->ppshheader.dwFlags & (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW)) &&
3451#ifdef __REACTOS__
3452 (psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
3453 (psInfo->ppshheader.u4.hbmWatermark) )
3454#else
3455 (psInfo->ppshheader.dwFlags & PSH_WATERMARK) )
3456#endif
3457 {
3458 HWND hwndLine = GetDlgItem(hwnd, IDC_SUNKEN_LINE);
3459
3460 GetClientRect(hwndLine, &r);
3461 MapWindowPoints(hwndLine, hwnd, (LPPOINT) &r, 2);
3462 SetRect(&rzone, 0, 0, r.right, r.top - 1);
3463
3465 FillRect(hdc, &rzone, hbr);
3466
3467 GetObjectW(psInfo->ppshheader.u4.hbmWatermark, sizeof(BITMAP), &bm);
3468 hbmp = SelectObject(hdcSrc, psInfo->ppshheader.u4.hbmWatermark);
3469
3470 /* The watermark is truncated to a width of 164 pixels */
3471 r.right = min(r.right, 164);
3472 BitBlt(hdc, 0, offsety, min(bm.bmWidth, r.right),
3473 min(bm.bmHeight, r.bottom), hdcSrc, 0, 0, SRCCOPY);
3474
3475 /* If the bitmap is not big enough, fill the remaining area
3476 with the color of pixel (0,0) of bitmap - see MSDN */
3477 if (r.top > bm.bmHeight) {
3478 r.bottom = r.top - 1;
3479 r.top = bm.bmHeight;
3480 r.left = 0;
3481 r.right = bm.bmWidth;
3482 hbr = CreateSolidBrush(GetPixel(hdcSrc, 0, 0));
3483 FillRect(hdc, &r, hbr);
3484 DeleteObject(hbr);
3485 }
3486
3488 }
3489
3490 if (psInfo->ppshheader.dwFlags & PSH_USEHPLWATERMARK)
3491 SelectPalette(hdc, hOldPal, FALSE);
3492
3494
3495 if (!hdcParam) EndPaint(hwnd, &ps);
3496
3497 return 0;
3498}
DWORD GetPixel(LPDIRECTDRAWSURFACE7 Surface, UINT x, UINT y)
Definition: blt.cpp:2
HBITMAP hbmp
static VOID BitBlt(_In_ ULONG Left, _In_ ULONG Top, _In_ ULONG Width, _In_ ULONG Height, _In_reads_bytes_(Delta *Height) PUCHAR Buffer, _In_ ULONG BitsPerPixel, _In_ ULONG Delta)
Definition: common.c:57
HDC hdc
Definition: main.c:9
static HBITMAP
Definition: button.c:44
static DWORD *static HFONT(WINAPI *pCreateFontIndirectExA)(const ENUMLOGFONTEXDVA *)
INT WINAPI DrawTextW(HDC hdc, LPCWSTR str, INT count, LPRECT rect, UINT flags)
Definition: defwnd.c:16
Definition: bl.h:1331
_In_ DWORD nLength
Definition: wincon.h:473
DWORD COLORREF
Definition: windef.h:300
int WINAPI GetObjectW(_In_ HANDLE h, _In_ int c, _Out_writes_bytes_opt_(c) LPVOID pv)
HPALETTE WINAPI SelectPalette(_In_ HDC, _In_ HPALETTE, _In_ BOOL)
HGDIOBJ WINAPI SelectObject(_In_ HDC, _In_ HGDIOBJ)
Definition: dc.c:1546
HDC WINAPI CreateCompatibleDC(_In_opt_ HDC hdc)
#define TRANSPARENT
Definition: wingdi.h:950
#define SRCCOPY
Definition: wingdi.h:333
int WINAPI FillRect(HDC, LPCRECT, HBRUSH)
int WINAPI SetBkMode(_In_ HDC, _In_ int)
Definition: dc.c:1056
COLORREF WINAPI SetTextColor(_In_ HDC, _In_ COLORREF)
Definition: text.c:918
HBRUSH WINAPI CreateSolidBrush(_In_ COLORREF)
BOOL WINAPI DeleteDC(_In_ HDC)
#define COLOR_WINDOW
Definition: winuser.h:921
HBRUSH WINAPI GetSysColorBrush(_In_ int)
#define DT_SINGLELINE
Definition: winuser.h:540
#define DT_NOCLIP
Definition: winuser.h:536
#define DT_LEFT
Definition: winuser.h:534
BOOL WINAPI EndPaint(_In_ HWND, _In_ const PAINTSTRUCT *)
#define DT_WORDBREAK
Definition: winuser.h:544
HDC WINAPI BeginPaint(_In_ HWND, _Out_ LPPAINTSTRUCT)
static HDC hdcSrc
Definition: xlate.c:32

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_PressButton()

static void PROPSHEET_PressButton ( HWND  hwndDlg,
int  buttonID 
)
static

Definition at line 1897 of file propsheet.c.

1898{
1899 TRACE("buttonID %d\n", buttonID);
1900 switch (buttonID)
1901 {
1902 case PSBTN_APPLYNOW:
1904 break;
1905 case PSBTN_BACK:
1906 PROPSHEET_Back(hwndDlg);
1907 break;
1908 case PSBTN_CANCEL:
1909 PROPSHEET_DoCommand(hwndDlg, IDCANCEL);
1910 break;
1911 case PSBTN_FINISH:
1912 PROPSHEET_Finish(hwndDlg);
1913 break;
1914 case PSBTN_HELP:
1915 PROPSHEET_DoCommand(hwndDlg, IDHELP);
1916 break;
1917 case PSBTN_NEXT:
1918 PROPSHEET_Next(hwndDlg);
1919 break;
1920 case PSBTN_OK:
1921 PROPSHEET_DoCommand(hwndDlg, IDOK);
1922 break;
1923 default:
1924 FIXME("Invalid button index %d\n", buttonID);
1925 }
1926}
#define FIXME(fmt,...)
Definition: precomp.h:53
#define PSBTN_CANCEL
Definition: prsht.h:151
#define PSBTN_FINISH
Definition: prsht.h:148
#define PSBTN_NEXT
Definition: prsht.h:147
#define PSBTN_BACK
Definition: prsht.h:146
#define PSBTN_APPLYNOW
Definition: prsht.h:150
#define PSBTN_HELP
Definition: prsht.h:152
#define PSBTN_OK
Definition: prsht.h:149

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_PropertySheet()

static INT_PTR PROPSHEET_PropertySheet ( PropSheetInfo psInfo,
BOOL  unicode 
)
static

Definition at line 2841 of file propsheet.c.

2842{
2843 INT_PTR bRet = 0;
2844 HWND parent = NULL;
2845 if (psInfo->active_page >= psInfo->nPages) psInfo->active_page = 0;
2846 TRACE("startpage: %d of %d pages\n", psInfo->active_page, psInfo->nPages);
2847
2848 psInfo->unicode = unicode;
2849 psInfo->ended = FALSE;
2850
2851 if(!psInfo->isModeless)
2852 {
2853 parent = psInfo->ppshheader.hwndParent;
2855 }
2856 bRet = PROPSHEET_CreateDialog(psInfo);
2857 if(!psInfo->isModeless)
2858 bRet = do_loop(psInfo);
2859 return bRet;
2860}
static INT_PTR PROPSHEET_CreateDialog(PropSheetInfo *psInfo)
Definition: propsheet.c:599
static INT do_loop(const PropSheetInfo *psInfo)
Definition: propsheet.c:2800

Referenced by PropertySheetA(), and PropertySheetW().

◆ PROPSHEET_QuerySiblings()

static LRESULT PROPSHEET_QuerySiblings ( HWND  hwndDlg,
WPARAM  wParam,
LPARAM  lParam 
)
static

Definition at line 2233 of file propsheet.c.

2235{
2236 int i = 0;
2237 HWND hwndPage;
2238 LRESULT msgResult = 0;
2239 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2240
2241 while ((i < psInfo->nPages) && (msgResult == 0))
2242 {
2243 hwndPage = psInfo->proppage[i].hwndPage;
2244 msgResult = SendMessageW(hwndPage, PSM_QUERYSIBLINGS, wParam, lParam);
2245 i++;
2246 }
2247
2248 return msgResult;
2249}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_RecalcPageSizes()

static BOOL PROPSHEET_RecalcPageSizes ( HWND  hwndDlg)
static

Definition at line 2715 of file propsheet.c.

2716{
2717 FIXME("(%p): stub\n", hwndDlg);
2718 return FALSE;
2719}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_RemovePage()

static BOOL PROPSHEET_RemovePage ( HWND  hwndDlg,
int  index,
HPROPSHEETPAGE  hpage 
)
static

Definition at line 2358 of file propsheet.c.

2361{
2362 PropSheetInfo * psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2363 HWND hwndTabControl = GetDlgItem(hwndDlg, IDC_TABCONTROL);
2364 PropPageInfo* oldPages;
2365
2366 TRACE("index %d, hpage %p\n", index, hpage);
2367 if (!psInfo) {
2368 return FALSE;
2369 }
2370
2371 index = PROPSHEET_GetPageIndex(hpage, psInfo, index);
2372
2373 /* Make sure that index is within range */
2374 if (index < 0 || index >= psInfo->nPages)
2375 {
2376 TRACE("Could not find page to remove!\n");
2377 return FALSE;
2378 }
2379
2380 TRACE("total pages %d removing page %d active page %d\n",
2381 psInfo->nPages, index, psInfo->active_page);
2382 /*
2383 * Check if we're removing the active page.
2384 */
2385 if (index == psInfo->active_page)
2386 {
2387 if (psInfo->nPages > 1)
2388 {
2389 if (index > 0)
2390 {
2391 /* activate previous page */
2392 PROPSHEET_SetCurSel(hwndDlg, index - 1, -1, 0);
2393 }
2394 else
2395 {
2396 /* activate the next page */
2397 PROPSHEET_SetCurSel(hwndDlg, index + 1, 1, 0);
2398 psInfo->active_page = index;
2399 }
2400 }
2401 else
2402 {
2403 psInfo->active_page = -1;
2404 if (!psInfo->isModeless)
2405 {
2406 psInfo->ended = TRUE;
2407 return TRUE;
2408 }
2409 }
2410 }
2411 else if (index < psInfo->active_page)
2412 psInfo->active_page--;
2413
2414 /* Unsubclass the page dialog window */
2415 if((psInfo->ppshheader.dwFlags & (PSH_WIZARD97_NEW | PSH_WIZARD97_OLD) &&
2416 (psInfo->ppshheader.dwFlags & PSH_WATERMARK) &&
2417 ((PROPSHEETPAGEW*)psInfo->proppage[index].hpage)->dwFlags & PSP_HIDEHEADER))
2418 {
2421 }
2422
2423 /* Destroy page dialog window */
2425
2426 /* Free page resources */
2427 if(psInfo->proppage[index].hpage)
2428 {
2430
2431 if (psp->dwFlags & PSP_USETITLE)
2432 Free ((LPVOID)psInfo->proppage[index].pszText);
2433
2435 }
2436
2437 /* Remove the tab */
2438 SendMessageW(hwndTabControl, TCM_DELETEITEM, index, 0);
2439
2440 oldPages = psInfo->proppage;
2441 psInfo->nPages--;
2442 psInfo->proppage = Alloc(sizeof(PropPageInfo) * psInfo->nPages);
2443
2444 if (index > 0)
2445 memcpy(&psInfo->proppage[0], &oldPages[0], index * sizeof(PropPageInfo));
2446
2447 if (index < psInfo->nPages)
2448 memcpy(&psInfo->proppage[index], &oldPages[index + 1],
2449 (psInfo->nPages - index) * sizeof(PropPageInfo));
2450
2451 Free(oldPages);
2452
2453 return FALSE;
2454}
#define TCM_DELETEITEM
Definition: commctrl.h:4058

Referenced by PROPSHEET_DialogProc(), and PROPSHEET_SetCurSel().

◆ PROPSHEET_SetCurSel()

static BOOL PROPSHEET_SetCurSel ( HWND  hwndDlg,
int  index,
int  skipdir,
HPROPSHEETPAGE  hpage 
)
static

Definition at line 1981 of file propsheet.c.

1986{
1987 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
1988 HWND hwndHelp = GetDlgItem(hwndDlg, IDHELP);
1989 HWND hwndTabControl = GetDlgItem(hwndDlg, IDC_TABCONTROL);
1990
1991 TRACE("index %d, skipdir %d, hpage %p\n", index, skipdir, hpage);
1992
1993 index = PROPSHEET_GetPageIndex(hpage, psInfo, index);
1994
1995 if (index < 0 || index >= psInfo->nPages)
1996 {
1997 TRACE("Could not find page to select!\n");
1998 return FALSE;
1999 }
2000
2001 /* unset active page while doing this transition. */
2002 if (psInfo->active_page != -1)
2003 ShowWindow(psInfo->proppage[psInfo->active_page].hwndPage, SW_HIDE);
2004 psInfo->active_page = -1;
2005
2006 while (1) {
2007 int result;
2008 PSHNOTIFY psn;
2009 RECT rc;
2011
2012 if (hwndTabControl)
2013 SendMessageW(hwndTabControl, TCM_SETCURSEL, index, 0);
2014
2015 psn.hdr.code = PSN_SETACTIVE;
2016 psn.hdr.hwndFrom = hwndDlg;
2017 psn.hdr.idFrom = 0;
2018 psn.lParam = 0;
2019
2020 if (!psInfo->proppage[index].hwndPage) {
2021 if(!PROPSHEET_CreatePage(hwndDlg, index, psInfo, ppshpage)) {
2022 PROPSHEET_RemovePage(hwndDlg, index, NULL);
2023
2024 if (!psInfo->isModeless)
2025 {
2026 DestroyWindow(hwndDlg);
2027 return FALSE;
2028 }
2029
2030 if(index >= psInfo->nPages)
2031 index--;
2032 if(index < 0)
2033 return FALSE;
2034 continue;
2035 }
2036 }
2037
2038 /* Resize the property sheet page to the fit in the Tab control
2039 * (for regular property sheets) or to fit in the client area (for
2040 * wizards).
2041 * NOTE: The resizing happens every time the page is selected and
2042 * not only when it's created (some applications depend on it). */
2043 PROPSHEET_GetPageRect(psInfo, hwndDlg, &rc, ppshpage);
2044 TRACE("setting page %p, rc (%s) w=%d, h=%d\n",
2045 psInfo->proppage[index].hwndPage, wine_dbgstr_rect(&rc),
2046 rc.right - rc.left, rc.bottom - rc.top);
2048 rc.left, rc.top,
2049 rc.right - rc.left, rc.bottom - rc.top, 0);
2050
2051 result = SendMessageW(psInfo->proppage[index].hwndPage, WM_NOTIFY, 0, (LPARAM) &psn);
2052 if (!result)
2053 break;
2054 if (result == -1) {
2055 index+=skipdir;
2056 if (index < 0) {
2057 index = 0;
2058 WARN("Tried to skip before first property sheet page!\n");
2059 break;
2060 }
2061 if (index >= psInfo->nPages) {
2062 WARN("Tried to skip after last property sheet page!\n");
2063 index = psInfo->nPages-1;
2064 break;
2065 }
2066 }
2067 else if (result != 0)
2068 {
2069 int old_index = index;
2071 if(index >= psInfo->nPages) {
2072 index = old_index;
2073 WARN("Tried to skip to nonexistent page by res id\n");
2074 break;
2075 }
2076 continue;
2077 }
2078 }
2079
2080 /* Invalidate the header area */
2081 if ( (psInfo->ppshheader.dwFlags & (PSH_WIZARD97_OLD | PSH_WIZARD97_NEW)) &&
2082 (psInfo->ppshheader.dwFlags & PSH_HEADER) )
2083 {
2084 HWND hwndLineHeader = GetDlgItem(hwndDlg, IDC_SUNKEN_LINEHEADER);
2085 RECT r;
2086
2087 GetClientRect(hwndLineHeader, &r);
2088 MapWindowPoints(hwndLineHeader, hwndDlg, (LPPOINT) &r, 2);
2089 SetRect(&r, 0, 0, r.right + 1, r.top - 1);
2090
2091 InvalidateRect(hwndDlg, &r, TRUE);
2092 }
2093
2094 /*
2095 * Display the new page.
2096 */
2097 PROPSHEET_ShowPage(hwndDlg, index, psInfo);
2098
2099 if (psInfo->proppage[index].hasHelp)
2100 EnableWindow(hwndHelp, TRUE);
2101 else
2102 EnableWindow(hwndHelp, FALSE);
2103
2104 return TRUE;
2105}
static void PROPSHEET_GetPageRect(const PropSheetInfo *psInfo, HWND hwndDlg, RECT *rc, LPCPROPSHEETPAGEW ppshpage)
Definition: propsheet.c:229
#define HWND_TOP
Definition: winuser.h:1210
BOOL WINAPI InvalidateRect(_In_opt_ HWND, _In_opt_ LPCRECT, _In_ BOOL)

Referenced by PROPSHEET_Back(), PROPSHEET_DialogProc(), PROPSHEET_InsertPage(), PROPSHEET_IsDialogMessage(), PROPSHEET_Next(), PROPSHEET_RemovePage(), and PROPSHEET_SetCurSelId().

◆ PROPSHEET_SetCurSelId()

static void PROPSHEET_SetCurSelId ( HWND  hwndDlg,
int  id 
)
static

Definition at line 2112 of file propsheet.c.

2113{
2114 int idx;
2115 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2116
2117 idx = PROPSHEET_FindPageByResId(psInfo, id);
2118 if (idx < psInfo->nPages )
2119 {
2120 if (PROPSHEET_CanSetCurSel(hwndDlg) != FALSE)
2121 PROPSHEET_SetCurSel(hwndDlg, idx, 1, 0);
2122 }
2123}

Referenced by PROPSHEET_DialogProc().

◆ PROPSHEET_SetFinishTextA()

static void PROPSHEET_SetFinishTextA ( HWND  hwndDlg,
LPCSTR  lpszText 
)
static

Definition at line 2175 of file propsheet.c.

2176{
2177 PropSheetInfo* psInfo = GetPropW(hwndDlg, PropSheetInfoStr);
2178 HWND hwndButton = GetDlgItem(hwndDlg, IDC_FINISH_BUTTON);
2179
2180 TRACE("'%s'\n", lpszText);
2181 /* Set text, show and enable the Finish button */
2182 SetWindowTextA(hwndButton, lpszText);
2183 ShowWindow(hwndButton, SW_SHOW);
2184 EnableWindow(hwndButton, TRUE);
2185
2186 /* Make it default pushbutton */
2188
2189 /* Hide Back button */
2190 hwndButton = GetDlgItem(hwndDlg,