mirror of
https://github.com/pbatard/rufus.git
synced 2024-08-14 23:57:05 +00:00
[ui] don't remove the checkboxes when formatting
* Previous patch was creating an issue when creating an XP bootable drive for instance * Also use our IsChecked() macro rather than IsDlgButtonChecked()
This commit is contained in:
parent
8ffd87e77a
commit
54b7fdcddc
2 changed files with 35 additions and 33 deletions
56
src/rufus.c
56
src/rufus.c
|
@ -502,21 +502,23 @@ static void SetMBRProps(void)
|
||||||
IGNORE_RETVAL(ComboBox_SetCurSel(hDiskID, needs_masquerading?1:0));
|
IGNORE_RETVAL(ComboBox_SetCurSel(hDiskID, needs_masquerading?1:0));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void EnableAdvancedBootOptions(BOOL enable)
|
static void EnableAdvancedBootOptions(BOOL enable, BOOL remove_checkboxes)
|
||||||
{
|
{
|
||||||
int bt = GETBIOSTYPE((int)ComboBox_GetItemData(hPartitionScheme, ComboBox_GetCurSel(hPartitionScheme)));
|
int bt = GETBIOSTYPE((int)ComboBox_GetItemData(hPartitionScheme, ComboBox_GetCurSel(hPartitionScheme)));
|
||||||
BOOL actual_enable = ((bt==BT_UEFI)||(selection_default>=DT_IMG)||!IsDlgButtonChecked(hMainDialog, IDC_BOOT))?FALSE:enable;
|
BOOL actual_enable = ((bt==BT_UEFI)||(selection_default>=DT_IMG)||!IsChecked(IDC_BOOT))?FALSE:enable;
|
||||||
static UINT uXPartChecked = BST_UNCHECKED;
|
static UINT uXPartChecked = BST_UNCHECKED;
|
||||||
|
|
||||||
// Store/Restore the checkbox states
|
if (remove_checkboxes) {
|
||||||
if (IsWindowEnabled(GetDlgItem(hMainDialog, IDC_RUFUS_MBR)) && !actual_enable) {
|
// Store/Restore the checkbox states
|
||||||
uMBRChecked = IsDlgButtonChecked(hMainDialog, IDC_RUFUS_MBR);
|
if (IsWindowEnabled(GetDlgItem(hMainDialog, IDC_RUFUS_MBR)) && !actual_enable) {
|
||||||
CheckDlgButton(hMainDialog, IDC_RUFUS_MBR, BST_UNCHECKED);
|
uMBRChecked = IsChecked(IDC_RUFUS_MBR);
|
||||||
uXPartChecked = IsDlgButtonChecked(hMainDialog, IDC_EXTRA_PARTITION);
|
CheckDlgButton(hMainDialog, IDC_RUFUS_MBR, BST_UNCHECKED);
|
||||||
CheckDlgButton(hMainDialog, IDC_EXTRA_PARTITION, BST_UNCHECKED);
|
uXPartChecked = IsChecked(IDC_EXTRA_PARTITION);
|
||||||
} else if (!IsWindowEnabled(GetDlgItem(hMainDialog, IDC_RUFUS_MBR)) && actual_enable) {
|
CheckDlgButton(hMainDialog, IDC_EXTRA_PARTITION, BST_UNCHECKED);
|
||||||
CheckDlgButton(hMainDialog, IDC_RUFUS_MBR, uMBRChecked);
|
} else if (!IsWindowEnabled(GetDlgItem(hMainDialog, IDC_RUFUS_MBR)) && actual_enable) {
|
||||||
CheckDlgButton(hMainDialog, IDC_EXTRA_PARTITION, uXPartChecked);
|
CheckDlgButton(hMainDialog, IDC_RUFUS_MBR, uMBRChecked);
|
||||||
|
CheckDlgButton(hMainDialog, IDC_EXTRA_PARTITION, uXPartChecked);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_EXTRA_PARTITION), actual_enable);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_EXTRA_PARTITION), actual_enable);
|
||||||
|
@ -524,7 +526,7 @@ static void EnableAdvancedBootOptions(BOOL enable)
|
||||||
EnableWindow(hDiskID, actual_enable);
|
EnableWindow(hDiskID, actual_enable);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void EnableBootOptions(BOOL enable)
|
static void EnableBootOptions(BOOL enable, BOOL remove_checkboxes)
|
||||||
{
|
{
|
||||||
int fs = (int)ComboBox_GetItemData(hFileSystem, ComboBox_GetCurSel(hFileSystem));
|
int fs = (int)ComboBox_GetItemData(hFileSystem, ComboBox_GetCurSel(hFileSystem));
|
||||||
BOOL actual_enable = ((fs != FS_FAT16) && (fs != FS_FAT32) && (fs != FS_NTFS) && (selection_default == DT_IMG))?FALSE:enable;
|
BOOL actual_enable = ((fs != FS_FAT16) && (fs != FS_FAT32) && (fs != FS_NTFS) && (selection_default == DT_IMG))?FALSE:enable;
|
||||||
|
@ -532,7 +534,7 @@ static void EnableBootOptions(BOOL enable)
|
||||||
EnableWindow(hBoot, actual_enable);
|
EnableWindow(hBoot, actual_enable);
|
||||||
EnableWindow(hBootType, actual_enable);
|
EnableWindow(hBootType, actual_enable);
|
||||||
EnableWindow(hSelectISO, actual_enable);
|
EnableWindow(hSelectISO, actual_enable);
|
||||||
EnableAdvancedBootOptions(actual_enable);
|
EnableAdvancedBootOptions(actual_enable, remove_checkboxes);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void SetPartitionSchemeTooltip(void)
|
static void SetPartitionSchemeTooltip(void)
|
||||||
|
@ -588,7 +590,7 @@ static BOOL PopulateProperties(int ComboIndex)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
SetTargetSystem();
|
SetTargetSystem();
|
||||||
SetFSFromISO();
|
SetFSFromISO();
|
||||||
EnableBootOptions(TRUE);
|
EnableBootOptions(TRUE, TRUE);
|
||||||
|
|
||||||
// Set a proposed label according to the size (eg: "256MB", "8GB")
|
// Set a proposed label according to the size (eg: "256MB", "8GB")
|
||||||
safe_sprintf(SelectedDrive.proposed_label, sizeof(SelectedDrive.proposed_label),
|
safe_sprintf(SelectedDrive.proposed_label, sizeof(SelectedDrive.proposed_label),
|
||||||
|
@ -1002,7 +1004,7 @@ static void EnableControls(BOOL bEnable)
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_START), bEnable);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_START), bEnable);
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_ABOUT), bEnable);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_ABOUT), bEnable);
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_BADBLOCKS), bEnable);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_BADBLOCKS), bEnable);
|
||||||
EnableBootOptions(bEnable);
|
EnableBootOptions(bEnable, FALSE);
|
||||||
EnableWindow(hSelectISO, bEnable);
|
EnableWindow(hSelectISO, bEnable);
|
||||||
EnableWindow(hNBPasses, bEnable);
|
EnableWindow(hNBPasses, bEnable);
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_ADVANCED), bEnable);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_ADVANCED), bEnable);
|
||||||
|
@ -2003,9 +2005,9 @@ static INT_PTR CALLBACK MainCallback(HWND hDlg, UINT message, WPARAM wParam, LPA
|
||||||
break;
|
break;
|
||||||
fs = (int)ComboBox_GetItemData(hFileSystem, ComboBox_GetCurSel(hFileSystem));
|
fs = (int)ComboBox_GetItemData(hFileSystem, ComboBox_GetCurSel(hFileSystem));
|
||||||
bt = GETBIOSTYPE((int)ComboBox_GetItemData(hPartitionScheme, ComboBox_GetCurSel(hPartitionScheme)));
|
bt = GETBIOSTYPE((int)ComboBox_GetItemData(hPartitionScheme, ComboBox_GetCurSel(hPartitionScheme)));
|
||||||
if ((selection_default == DT_IMG) && IsDlgButtonChecked(hMainDialog, IDC_BOOT)) {
|
if ((selection_default == DT_IMG) && IsChecked(IDC_BOOT)) {
|
||||||
ToggleImage(FALSE);
|
ToggleImage(FALSE);
|
||||||
EnableAdvancedBootOptions(FALSE);
|
EnableAdvancedBootOptions(FALSE, TRUE);
|
||||||
SetBoot(fs, bt);
|
SetBoot(fs, bt);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -2013,7 +2015,7 @@ static INT_PTR CALLBACK MainCallback(HWND hDlg, UINT message, WPARAM wParam, LPA
|
||||||
// Disable/restore the quick format control depending on large FAT32
|
// Disable/restore the quick format control depending on large FAT32
|
||||||
if ((fs == FS_FAT32) && ((SelectedDrive.DiskSize > LARGE_FAT32_SIZE) || (force_large_fat32))) {
|
if ((fs == FS_FAT32) && ((SelectedDrive.DiskSize > LARGE_FAT32_SIZE) || (force_large_fat32))) {
|
||||||
if (IsWindowEnabled(GetDlgItem(hMainDialog, IDC_QUICKFORMAT))) {
|
if (IsWindowEnabled(GetDlgItem(hMainDialog, IDC_QUICKFORMAT))) {
|
||||||
uQFChecked = IsDlgButtonChecked(hMainDialog, IDC_QUICKFORMAT);
|
uQFChecked = IsChecked(IDC_QUICKFORMAT);
|
||||||
CheckDlgButton(hMainDialog, IDC_QUICKFORMAT, BST_CHECKED);
|
CheckDlgButton(hMainDialog, IDC_QUICKFORMAT, BST_CHECKED);
|
||||||
EnableWindow(GetDlgItem(hMainDialog, IDC_QUICKFORMAT), FALSE);
|
EnableWindow(GetDlgItem(hMainDialog, IDC_QUICKFORMAT), FALSE);
|
||||||
}
|
}
|
||||||
|
@ -2024,7 +2026,7 @@ static INT_PTR CALLBACK MainCallback(HWND hDlg, UINT message, WPARAM wParam, LPA
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (fs < 0) {
|
if (fs < 0) {
|
||||||
EnableBootOptions(TRUE);
|
EnableBootOptions(TRUE, TRUE);
|
||||||
SetMBRProps();
|
SetMBRProps();
|
||||||
// Remove the SysLinux and ReactOS options if they exists
|
// Remove the SysLinux and ReactOS options if they exists
|
||||||
if (ComboBox_GetItemData(hBootType, ComboBox_GetCount(hBootType)-1) == (DT_MAX-1)) {
|
if (ComboBox_GetItemData(hBootType, ComboBox_GetCount(hBootType)-1) == (DT_MAX-1)) {
|
||||||
|
@ -2038,31 +2040,31 @@ static INT_PTR CALLBACK MainCallback(HWND hDlg, UINT message, WPARAM wParam, LPA
|
||||||
if (IsWindowEnabled(hBoot)) {
|
if (IsWindowEnabled(hBoot)) {
|
||||||
// unlikely to be supported by BIOSes => don't bother
|
// unlikely to be supported by BIOSes => don't bother
|
||||||
IGNORE_RETVAL(ComboBox_SetCurSel(hBootType, 0));
|
IGNORE_RETVAL(ComboBox_SetCurSel(hBootType, 0));
|
||||||
uBootChecked = IsDlgButtonChecked(hMainDialog, IDC_BOOT);
|
uBootChecked = IsChecked(IDC_BOOT);
|
||||||
CheckDlgButton(hDlg, IDC_BOOT, BST_UNCHECKED);
|
CheckDlgButton(hDlg, IDC_BOOT, BST_UNCHECKED);
|
||||||
EnableBootOptions(FALSE);
|
EnableBootOptions(FALSE, TRUE);
|
||||||
} else if (IsDlgButtonChecked(hMainDialog, IDC_BOOT)) {
|
} else if (IsChecked(IDC_BOOT)) {
|
||||||
uBootChecked = TRUE;
|
uBootChecked = TRUE;
|
||||||
CheckDlgButton(hDlg, IDC_BOOT, BST_UNCHECKED);
|
CheckDlgButton(hDlg, IDC_BOOT, BST_UNCHECKED);
|
||||||
}
|
}
|
||||||
SetMBRProps();
|
SetMBRProps();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
EnableAdvancedBootOptions(TRUE);
|
EnableAdvancedBootOptions(TRUE, TRUE);
|
||||||
SetBoot(fs, bt);
|
SetBoot(fs, bt);
|
||||||
SetMBRProps();
|
SetMBRProps();
|
||||||
break;
|
break;
|
||||||
case IDC_BOOT:
|
case IDC_BOOT:
|
||||||
EnableAdvancedBootOptions(TRUE);
|
EnableAdvancedBootOptions(TRUE, TRUE);
|
||||||
if (selection_default == DT_IMG)
|
if (selection_default == DT_IMG)
|
||||||
ToggleImage(!IsDlgButtonChecked(hMainDialog, IDC_BOOT));
|
ToggleImage(!IsChecked(IDC_BOOT));
|
||||||
break;
|
break;
|
||||||
case IDC_BOOTTYPE:
|
case IDC_BOOTTYPE:
|
||||||
if (HIWORD(wParam) != CBN_SELCHANGE)
|
if (HIWORD(wParam) != CBN_SELCHANGE)
|
||||||
break;
|
break;
|
||||||
selection_default = (int) ComboBox_GetItemData(hBootType, ComboBox_GetCurSel(hBootType));
|
selection_default = (int) ComboBox_GetItemData(hBootType, ComboBox_GetCurSel(hBootType));
|
||||||
EnableAdvancedBootOptions(TRUE);
|
EnableAdvancedBootOptions(TRUE, TRUE);
|
||||||
ToggleImage(!IsDlgButtonChecked(hMainDialog, IDC_BOOT) || (selection_default != DT_IMG));
|
ToggleImage(!IsChecked(IDC_BOOT) || (selection_default != DT_IMG));
|
||||||
if ((selection_default == DT_ISO) || (selection_default == DT_IMG)) {
|
if ((selection_default == DT_ISO) || (selection_default == DT_IMG)) {
|
||||||
if ((iso_path == NULL) || (iso_report.label[0] == 0)) {
|
if ((iso_path == NULL) || (iso_report.label[0] == 0)) {
|
||||||
// Set focus to the Select ISO button
|
// Set focus to the Select ISO button
|
||||||
|
|
12
src/rufus.rc
12
src/rufus.rc
|
@ -32,7 +32,7 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL
|
||||||
|
|
||||||
IDD_DIALOG DIALOGEX 12, 12, 206, 329
|
IDD_DIALOG DIALOGEX 12, 12, 206, 329
|
||||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
CAPTION "Rufus 1.4.6.437"
|
CAPTION "Rufus 1.4.6.438"
|
||||||
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||||
BEGIN
|
BEGIN
|
||||||
DEFPUSHBUTTON "Start",IDC_START,94,291,50,14
|
DEFPUSHBUTTON "Start",IDC_START,94,291,50,14
|
||||||
|
@ -165,7 +165,7 @@ END
|
||||||
RTL_IDD_DIALOG DIALOGEX 12, 12, 206, 329
|
RTL_IDD_DIALOG DIALOGEX 12, 12, 206, 329
|
||||||
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | DS_CENTER | WS_POPUP | WS_CAPTION | WS_SYSMENU
|
||||||
EXSTYLE WS_EX_RTLREADING | WS_EX_APPWINDOW | WS_EX_LAYOUTRTL
|
EXSTYLE WS_EX_RTLREADING | WS_EX_APPWINDOW | WS_EX_LAYOUTRTL
|
||||||
CAPTION "Rufus 1.4.6.437"
|
CAPTION "Rufus 1.4.6.438"
|
||||||
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
FONT 8, "MS Shell Dlg", 400, 0, 0x1
|
||||||
BEGIN
|
BEGIN
|
||||||
DEFPUSHBUTTON "Start",IDC_START,94,291,50,14
|
DEFPUSHBUTTON "Start",IDC_START,94,291,50,14
|
||||||
|
@ -427,8 +427,8 @@ END
|
||||||
//
|
//
|
||||||
|
|
||||||
VS_VERSION_INFO VERSIONINFO
|
VS_VERSION_INFO VERSIONINFO
|
||||||
FILEVERSION 1,4,6,437
|
FILEVERSION 1,4,6,438
|
||||||
PRODUCTVERSION 1,4,6,437
|
PRODUCTVERSION 1,4,6,438
|
||||||
FILEFLAGSMASK 0x3fL
|
FILEFLAGSMASK 0x3fL
|
||||||
#ifdef _DEBUG
|
#ifdef _DEBUG
|
||||||
FILEFLAGS 0x1L
|
FILEFLAGS 0x1L
|
||||||
|
@ -445,13 +445,13 @@ BEGIN
|
||||||
BEGIN
|
BEGIN
|
||||||
VALUE "CompanyName", "Akeo Consulting (http://akeo.ie)"
|
VALUE "CompanyName", "Akeo Consulting (http://akeo.ie)"
|
||||||
VALUE "FileDescription", "Rufus"
|
VALUE "FileDescription", "Rufus"
|
||||||
VALUE "FileVersion", "1.4.6.437"
|
VALUE "FileVersion", "1.4.6.438"
|
||||||
VALUE "InternalName", "Rufus"
|
VALUE "InternalName", "Rufus"
|
||||||
VALUE "LegalCopyright", "© 2011-2014 Pete Batard (GPL v3)"
|
VALUE "LegalCopyright", "© 2011-2014 Pete Batard (GPL v3)"
|
||||||
VALUE "LegalTrademarks", "http://www.gnu.org/copyleft/gpl.html"
|
VALUE "LegalTrademarks", "http://www.gnu.org/copyleft/gpl.html"
|
||||||
VALUE "OriginalFilename", "rufus.exe"
|
VALUE "OriginalFilename", "rufus.exe"
|
||||||
VALUE "ProductName", "Rufus"
|
VALUE "ProductName", "Rufus"
|
||||||
VALUE "ProductVersion", "1.4.6.437"
|
VALUE "ProductVersion", "1.4.6.438"
|
||||||
END
|
END
|
||||||
END
|
END
|
||||||
BLOCK "VarFileInfo"
|
BLOCK "VarFileInfo"
|
||||||
|
|
Loading…
Reference in a new issue