mirror of
				https://github.com/pbatard/rufus.git
				synced 2024-08-14 23:57:05 +00:00 
			
		
		
		
	[core] display a notice about Legacy in the protective MBR for GPT
* This should help Windows users who create a GPT/UEFI drive and try to use it in BIOS/Legacy * Also make sure that we take into account the split space for both "SELECT" and "DOWNLOAD"
This commit is contained in:
		
							parent
							
								
									789373ed59
								
							
						
					
					
						commit
						28c1d6eb31
					
				
					 11 changed files with 200 additions and 10 deletions
				
			
		|  | @ -70,6 +70,8 @@ | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_95b.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_95b.h" /> | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_dos.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_dos.h" /> | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_dos_f2.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_dos_f2.h" /> | ||||||
|  |     <ClInclude Include="..\src\ms-sys\inc\mbr_gpt_rufus.h" /> | ||||||
|  |     <ClInclude Include="..\src\ms-sys\inc\mbr_gpt_syslinux.h" /> | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_grub.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_grub.h" /> | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_grub2.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_grub2.h" /> | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\mbr_kolibri.h" /> |     <ClInclude Include="..\src\ms-sys\inc\mbr_kolibri.h" /> | ||||||
|  |  | ||||||
|  | @ -152,6 +152,12 @@ | ||||||
|     <ClInclude Include="..\src\ms-sys\inc\br_fat32pe_0x1800.h"> |     <ClInclude Include="..\src\ms-sys\inc\br_fat32pe_0x1800.h"> | ||||||
|       <Filter>Header Files</Filter> |       <Filter>Header Files</Filter> | ||||||
|     </ClInclude> |     </ClInclude> | ||||||
|  |     <ClInclude Include="..\src\ms-sys\inc\mbr_gpt_rufus.h"> | ||||||
|  |       <Filter>Header Files</Filter> | ||||||
|  |     </ClInclude> | ||||||
|  |     <ClInclude Include="..\src\ms-sys\inc\mbr_gpt_syslinux.h"> | ||||||
|  |       <Filter>Header Files</Filter> | ||||||
|  |     </ClInclude> | ||||||
|   </ItemGroup> |   </ItemGroup> | ||||||
|   <ItemGroup> |   <ItemGroup> | ||||||
|     <ClCompile Include="..\src\ms-sys\br.c"> |     <ClCompile Include="..\src\ms-sys\br.c"> | ||||||
|  |  | ||||||
|  | @ -1,12 +1,13 @@ | ||||||
| o Version 3.5 (2019.03.??) | o Version 3.5 (2019.03.??) | ||||||
|     Add a feature to download official retail Windows 8.1 or Windows 10 ISOs from Rufus |     Add a feature to download official retail Windows 8.1 or Windows 10 ISOs | ||||||
|     Add Windows To Go support for MCT generated Windows ISOs |     Add Windows To Go support for MCT generated Windows ISOs | ||||||
|     Add a notice about the 'WppRecorder.sys' Microsoft bug for Windows 10 1809 ISOs |     Add a notice about the 'WppRecorder.sys' Microsoft bug for Windows 10 1809 ISOs | ||||||
|     Add a notice about trying to format a drive larger than 2 TB in MBR mode |     Add a notice about trying to format a drive larger than 2 TB in MBR mode | ||||||
|  |     Add a notice about Legacy boot when trying to boot UEFI-only media in Legacy mode | ||||||
|     Report the full PID and command line of detected blocking processes in the log |     Report the full PID and command line of detected blocking processes in the log | ||||||
|     Fix a potential silent abort when the drive is in use |     Fix a potential silent abort when the drive is in use | ||||||
|     Fix 'Quick Format' option always being active |     Fix 'Quick Format' option always being active | ||||||
|     Fix potentially changing default file system selection after selecting an ISO |     Fix some unwanted file system changes occurring after an ISO had been selected | ||||||
| 
 | 
 | ||||||
| o Version 3.4 (2018.12.05) | o Version 3.4 (2018.12.05) | ||||||
|     Set the default image selection directory to Downloads\ instead of My Documents\ |     Set the default image selection directory to Downloads\ instead of My Documents\ | ||||||
|  |  | ||||||
							
								
								
									
										100
									
								
								res/mbr/gpt.S
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										100
									
								
								res/mbr/gpt.S
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,100 @@ | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* GPT - A protective MBR that displays a notice if a user attempts to boot a   */ | ||||||
|  | /*       GPT drive in BIOS/Legacy mode.                                         */ | ||||||
|  | /*                                                                              */ | ||||||
|  | /* Copyright (c) 2019 Pete Batard <pete@akeo.ie>                                */ | ||||||
|  | /*                                                                              */ | ||||||
|  | /* This program is free software; you can redistribute it and/or modify it      */ | ||||||
|  | /* under the terms of the GNU General Public License as published by the Free   */ | ||||||
|  | /* Software Foundation, either version 3 of the License, or (at your option)    */ | ||||||
|  | /* any later version.                                                           */ | ||||||
|  | /*                                                                              */ | ||||||
|  | /* This program is distributed in the hope that it will be useful, but WITHOUT  */ | ||||||
|  | /* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or        */ | ||||||
|  | /* FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for    */ | ||||||
|  | /* more details.                                                                */ | ||||||
|  | /*                                                                              */ | ||||||
|  | /* You should have received a copy of the GNU General Public License along with */ | ||||||
|  | /* this program; if not, see <http://www.gnu.org/licenses/>.                    */ | ||||||
|  | /*                                                                              */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | 
 | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* GNU Assembler Settings:                                                      */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | .intel_syntax noprefix
 | ||||||
|  | .code16 | ||||||
|  | /********************************************************************************/ | ||||||
|  | 
 | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* Constants:                                                                   */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | MBR_ADDR      = 0x7c00 | ||||||
|  | MBR_SIZE      = 0x200 | ||||||
|  | MBR_RESERVED  = 0x1b8	# Start of the reserved section (partition table, etc.) | ||||||
|  | PT_MAX        = 0x04	# Number of partition entries in the partition table | ||||||
|  | PT_ENTRY_SIZE = 0x10	# Size of a partition entry in the partition table | ||||||
|  | 
 | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* MBR: This section resides at 0x00007c00 and is exactly 512 bytes             */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | .section main, "ax" | ||||||
|  | .globl mbr
 | ||||||
|  | mbr: | ||||||
|  | 	inc  cx | ||||||
|  | 	dec  bx | ||||||
|  | 	inc  bp | ||||||
|  | 	dec  di | ||||||
|  | 	cld | ||||||
|  | 	xor  ax, ax | ||||||
|  | 	mov  ds, ax | ||||||
|  | 	mov  si, offset sep | ||||||
|  | 	call print_string | ||||||
|  | 	mov  si, offset hdr | ||||||
|  | 	call print_string | ||||||
|  | 	mov  si, offset sep | ||||||
|  | 	call print_string | ||||||
|  | 	mov  si, offset txt | ||||||
|  | 	call print_string | ||||||
|  | 	hlt | ||||||
|  | 
 | ||||||
|  | print_string: | ||||||
|  | 	lodsb | ||||||
|  | 	cmp  al, 0x00 | ||||||
|  | 	jz   0f | ||||||
|  | 	mov  ah, 0x0e | ||||||
|  | 	mov  bx, 0x0007 | ||||||
|  | 	int  0x10 | ||||||
|  | 	jmp  print_string | ||||||
|  | 0:	ret | ||||||
|  | 
 | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* Data section                                                                 */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | sep: | ||||||
|  | 		.string "****************************************\r\n" | ||||||
|  | hdr: | ||||||
|  | 		.string "*** ERROR: LEGACY BOOT OF UEFI MEDIA ***\r\n" | ||||||
|  | txt: | ||||||
|  | 		.ascii "\r\n" \ | ||||||
|  | 		"This drive can only boot in UEFI mode.\r\n" \ | ||||||
|  | 		"It can not boot in BIOS/Legacy mode.\r\n" \ | ||||||
|  | 		"\r\n" \ | ||||||
|  | 		"If you want to boot this drive in BIOS/Legacy mode, you\r\n" \ | ||||||
|  | 		"should recreate it in Rufus using the following settings:\r\n" \ | ||||||
|  | 		"* Partition scheme -> MBR\r\n" \ | ||||||
|  | 		"* Target system -> BIOS...\r\n" \ | ||||||
|  | 		"\0" | ||||||
|  | 
 | ||||||
|  | /********************************************************************************/ | ||||||
|  | /* From offset 0x1b8, the MBR contains the partition table and signature data   */ | ||||||
|  | /********************************************************************************/ | ||||||
|  | 		.org MBR_RESERVED
 | ||||||
|  | disk_signature: | ||||||
|  | 		.space 0x04
 | ||||||
|  | filler: | ||||||
|  | 		.space 0x02
 | ||||||
|  | partition_table: | ||||||
|  | 		.space PT_ENTRY_SIZE * PT_MAX | ||||||
|  | mbr_signature: | ||||||
|  | 		.word 0xAA55
 | ||||||
							
								
								
									
										
											BIN
										
									
								
								res/mbr/gpt.bin
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								res/mbr/gpt.bin
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							
							
								
								
									
										14
									
								
								src/format.c
									
										
									
									
									
								
							
							
						
						
									
										14
									
								
								src/format.c
									
										
									
									
									
								
							|  | @ -889,6 +889,15 @@ static BOOL WriteMBR(HANDLE hPhysicalDrive) | ||||||
| 	if (SelectedDrive.SectorSize < 512) | 	if (SelectedDrive.SectorSize < 512) | ||||||
| 		goto out; | 		goto out; | ||||||
| 
 | 
 | ||||||
|  | 	if (pt == PARTITION_STYLE_GPT) { | ||||||
|  | 		// Add a notice in the protective MBR
 | ||||||
|  | 		fake_fd._handle = (char*)hPhysicalDrive; | ||||||
|  | 		set_bytes_per_sector(SelectedDrive.SectorSize); | ||||||
|  | 		uprintf(using_msg, "Rufus protective"); | ||||||
|  | 		r = write_rufus_gpt_mbr(fp); | ||||||
|  | 		goto notify; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	// FormatEx rewrites the MBR and removes the LBA attribute of FAT16
 | 	// FormatEx rewrites the MBR and removes the LBA attribute of FAT16
 | ||||||
| 	// and FAT32 partitions - we need to correct this in the MBR
 | 	// and FAT32 partitions - we need to correct this in the MBR
 | ||||||
| 	buffer = (unsigned char*)_mm_malloc(SelectedDrive.SectorSize, 16); | 	buffer = (unsigned char*)_mm_malloc(SelectedDrive.SectorSize, 16); | ||||||
|  | @ -1018,6 +1027,9 @@ static BOOL WriteSBR(HANDLE hPhysicalDrive) | ||||||
| 	FAKE_FD fake_fd = { 0 }; | 	FAKE_FD fake_fd = { 0 }; | ||||||
| 	FILE* fp = (FILE*)&fake_fd; | 	FILE* fp = (FILE*)&fake_fd; | ||||||
| 
 | 
 | ||||||
|  | 	if (pt == PARTITION_STYLE_GPT) | ||||||
|  | 		return TRUE; | ||||||
|  | 
 | ||||||
| 	fake_fd._handle = (char*)hPhysicalDrive; | 	fake_fd._handle = (char*)hPhysicalDrive; | ||||||
| 	set_bytes_per_sector(SelectedDrive.SectorSize); | 	set_bytes_per_sector(SelectedDrive.SectorSize); | ||||||
| 	// Ensure that we have sufficient space for the SBR
 | 	// Ensure that we have sufficient space for the SBR
 | ||||||
|  | @ -1997,7 +2009,7 @@ DWORD WINAPI FormatThread(void* param) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Thanks to Microsoft, we must fix the MBR AFTER the drive has been formatted
 | 	// Thanks to Microsoft, we must fix the MBR AFTER the drive has been formatted
 | ||||||
| 	if (pt == PARTITION_STYLE_MBR) { | 	if ((pt == PARTITION_STYLE_MBR) || ((bt != BT_NON_BOOTABLE) && (pt == PARTITION_STYLE_GPT))) { | ||||||
| 		PrintInfoDebug(0, MSG_228);	// "Writing master boot record..."
 | 		PrintInfoDebug(0, MSG_228);	// "Writing master boot record..."
 | ||||||
| 		if ((!WriteMBR(hPhysicalDrive)) || (!WriteSBR(hPhysicalDrive))) { | 		if ((!WriteMBR(hPhysicalDrive)) || (!WriteSBR(hPhysicalDrive))) { | ||||||
| 			if (!IS_ERROR(FormatStatus)) | 			if (!IS_ERROR(FormatStatus)) | ||||||
|  |  | ||||||
|  | @ -148,6 +148,15 @@ int is_rufus_mbr(FILE *fp) | ||||||
|       is_br(fp); |       is_br(fp); | ||||||
| } /* is_rufus_mbr */ | } /* is_rufus_mbr */ | ||||||
| 
 | 
 | ||||||
|  | int is_rufus_gpt_mbr(FILE *fp) | ||||||
|  | { | ||||||
|  | #include "mbr_gpt_rufus.h" | ||||||
|  | 
 | ||||||
|  |     return | ||||||
|  |        contains_data(fp, 0x0, mbr_gpt_rufus_0x0, sizeof(mbr_gpt_rufus_0x0)) && | ||||||
|  |        is_br(fp); | ||||||
|  | } /* is_rufus_gpt_mbr */ | ||||||
|  | 
 | ||||||
| int is_reactos_mbr(FILE *fp) | int is_reactos_mbr(FILE *fp) | ||||||
| { | { | ||||||
|    #include "mbr_reactos.h" |    #include "mbr_reactos.h" | ||||||
|  | @ -289,6 +298,15 @@ int write_rufus_mbr(FILE *fp) | ||||||
|       write_bootmark(fp); |       write_bootmark(fp); | ||||||
| } /* write_rufus_mbr */ | } /* write_rufus_mbr */ | ||||||
| 
 | 
 | ||||||
|  | int write_rufus_gpt_mbr(FILE *fp) | ||||||
|  | { | ||||||
|  | #include "mbr_gpt_rufus.h" | ||||||
|  | 
 | ||||||
|  |     return | ||||||
|  |        write_data(fp, 0x0, mbr_gpt_rufus_0x0, sizeof(mbr_gpt_rufus_0x0)) && | ||||||
|  |        write_bootmark(fp); | ||||||
|  | } /* write_rufus_gpt_mbr */ | ||||||
|  | 
 | ||||||
| int write_reactos_mbr(FILE *fp) | int write_reactos_mbr(FILE *fp) | ||||||
| { | { | ||||||
|    #include "mbr_reactos.h" |    #include "mbr_reactos.h" | ||||||
|  |  | ||||||
|  | @ -54,6 +54,10 @@ int is_win7_mbr(FILE *fp); | ||||||
|    FALSE.The file position will change when this function is called! */ |    FALSE.The file position will change when this function is called! */ | ||||||
| int is_rufus_mbr(FILE *fp); | int is_rufus_mbr(FILE *fp); | ||||||
| 
 | 
 | ||||||
|  | /* returns TRUE if the file has a Rufus GPT master boot record, otherwise
 | ||||||
|  |    FALSE.The file position will change when this function is called! */ | ||||||
|  | int is_rufus_gpt_mbr(FILE *fp); | ||||||
|  | 
 | ||||||
| /* returns TRUE if the file has a ReactOS master boot record, otherwise
 | /* returns TRUE if the file has a ReactOS master boot record, otherwise
 | ||||||
|    FALSE.The file position will change when this function is called! */ |    FALSE.The file position will change when this function is called! */ | ||||||
| int is_reactos_mbr(FILE *fp); | int is_reactos_mbr(FILE *fp); | ||||||
|  | @ -107,6 +111,10 @@ int write_win7_mbr(FILE *fp); | ||||||
|    FALSE */ |    FALSE */ | ||||||
| int write_rufus_mbr(FILE *fp); | int write_rufus_mbr(FILE *fp); | ||||||
| 
 | 
 | ||||||
|  | /* Writes a Rufus GPT master boot record to a file, returns TRUE on success, otherwise
 | ||||||
|  |    FALSE */ | ||||||
|  | int write_rufus_gpt_mbr(FILE *fp); | ||||||
|  | 
 | ||||||
| /* Writes a ReactOS master boot record to a file, returns TRUE on success, otherwise
 | /* Writes a ReactOS master boot record to a file, returns TRUE on success, otherwise
 | ||||||
|    FALSE */ |    FALSE */ | ||||||
| int write_reactos_mbr(FILE *fp); | int write_reactos_mbr(FILE *fp); | ||||||
|  |  | ||||||
							
								
								
									
										41
									
								
								src/ms-sys/inc/mbr_gpt_rufus.h
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										41
									
								
								src/ms-sys/inc/mbr_gpt_rufus.h
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,41 @@ | ||||||
|  | /*
 | ||||||
|  |  * Rufus Protective MBR for GPT systems | ||||||
|  |  * https://github.com/pbatard/rufus/tree/master/res/mbr
 | ||||||
|  |  * Copyright © 2019 Pete Batard <pete@akeo.ie> | ||||||
|  |  */ | ||||||
|  | 
 | ||||||
|  | unsigned char mbr_gpt_rufus_0x0[] = { | ||||||
|  | 	0x41, 0x4B, 0x45, 0x4F, 0xFC, 0x31, 0xC0, 0x8E, 0xD8, 0xBE, 0x31, 0x7C, | ||||||
|  | 	0xE8, 0x13, 0x00, 0xBE, 0x5C, 0x7C, 0xE8, 0x0D, 0x00, 0xBE, 0x31, 0x7C, | ||||||
|  | 	0xE8, 0x07, 0x00, 0xBE, 0x87, 0x7C, 0xE8, 0x01, 0x00, 0xF4, 0xAC, 0x3C, | ||||||
|  | 	0x00, 0x74, 0x09, 0xB4, 0x0E, 0xBB, 0x07, 0x00, 0xCD, 0x10, 0xEB, 0xF2, | ||||||
|  | 	0xC3, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, | ||||||
|  | 	0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, | ||||||
|  | 	0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x2A, | ||||||
|  | 	0x2A, 0x2A, 0x2A, 0x2A, 0x2A, 0x0D, 0x0A, 0x00, 0x2A, 0x2A, 0x2A, 0x20, | ||||||
|  | 	0x45, 0x52, 0x52, 0x4F, 0x52, 0x3A, 0x20, 0x4C, 0x45, 0x47, 0x41, 0x43, | ||||||
|  | 	0x59, 0x20, 0x42, 0x4F, 0x4F, 0x54, 0x20, 0x4F, 0x46, 0x20, 0x55, 0x45, | ||||||
|  | 	0x46, 0x49, 0x20, 0x4D, 0x45, 0x44, 0x49, 0x41, 0x20, 0x2A, 0x2A, 0x2A, | ||||||
|  | 	0x0D, 0x0A, 0x00, 0x0D, 0x0A, 0x54, 0x68, 0x69, 0x73, 0x20, 0x64, 0x72, | ||||||
|  | 	0x69, 0x76, 0x65, 0x20, 0x63, 0x61, 0x6E, 0x20, 0x6F, 0x6E, 0x6C, 0x79, | ||||||
|  | 	0x20, 0x62, 0x6F, 0x6F, 0x74, 0x20, 0x69, 0x6E, 0x20, 0x55, 0x45, 0x46, | ||||||
|  | 	0x49, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x2E, 0x0D, 0x0A, 0x49, 0x74, 0x20, | ||||||
|  | 	0x63, 0x61, 0x6E, 0x20, 0x6E, 0x6F, 0x74, 0x20, 0x62, 0x6F, 0x6F, 0x74, | ||||||
|  | 	0x20, 0x69, 0x6E, 0x20, 0x42, 0x49, 0x4F, 0x53, 0x2F, 0x4C, 0x65, 0x67, | ||||||
|  | 	0x61, 0x63, 0x79, 0x20, 0x6D, 0x6F, 0x64, 0x65, 0x2E, 0x0D, 0x0A, 0x0D, | ||||||
|  | 	0x0A, 0x49, 0x66, 0x20, 0x79, 0x6F, 0x75, 0x20, 0x77, 0x61, 0x6E, 0x74, | ||||||
|  | 	0x20, 0x74, 0x6F, 0x20, 0x62, 0x6F, 0x6F, 0x74, 0x20, 0x74, 0x68, 0x69, | ||||||
|  | 	0x73, 0x20, 0x64, 0x72, 0x69, 0x76, 0x65, 0x20, 0x69, 0x6E, 0x20, 0x42, | ||||||
|  | 	0x49, 0x4F, 0x53, 0x2F, 0x4C, 0x65, 0x67, 0x61, 0x63, 0x79, 0x20, 0x6D, | ||||||
|  | 	0x6F, 0x64, 0x65, 0x2C, 0x20, 0x79, 0x6F, 0x75, 0x0D, 0x0A, 0x73, 0x68, | ||||||
|  | 	0x6F, 0x75, 0x6C, 0x64, 0x20, 0x72, 0x65, 0x63, 0x72, 0x65, 0x61, 0x74, | ||||||
|  | 	0x65, 0x20, 0x69, 0x74, 0x20, 0x69, 0x6E, 0x20, 0x52, 0x75, 0x66, 0x75, | ||||||
|  | 	0x73, 0x20, 0x75, 0x73, 0x69, 0x6E, 0x67, 0x20, 0x74, 0x68, 0x65, 0x20, | ||||||
|  | 	0x66, 0x6F, 0x6C, 0x6C, 0x6F, 0x77, 0x69, 0x6E, 0x67, 0x20, 0x73, 0x65, | ||||||
|  | 	0x74, 0x74, 0x69, 0x6E, 0x67, 0x73, 0x3A, 0x0D, 0x0A, 0x2A, 0x20, 0x50, | ||||||
|  | 	0x61, 0x72, 0x74, 0x69, 0x74, 0x69, 0x6F, 0x6E, 0x20, 0x73, 0x63, 0x68, | ||||||
|  | 	0x65, 0x6D, 0x65, 0x20, 0x2D, 0x3E, 0x20, 0x4D, 0x42, 0x52, 0x0D, 0x0A, | ||||||
|  | 	0x2A, 0x20, 0x54, 0x61, 0x72, 0x67, 0x65, 0x74, 0x20, 0x73, 0x79, 0x73, | ||||||
|  | 	0x74, 0x65, 0x6D, 0x20, 0x2D, 0x3E, 0x20, 0x42, 0x49, 0x4F, 0x53, 0x2E, | ||||||
|  | 	0x2E, 0x2E, 0x0D, 0x0A, 0x00 | ||||||
|  | }; | ||||||
							
								
								
									
										10
									
								
								src/rufus.rc
									
										
									
									
									
								
							
							
						
						
									
										10
									
								
								src/rufus.rc
									
										
									
									
									
								
							|  | @ -33,7 +33,7 @@ LANGUAGE LANG_NEUTRAL, SUBLANG_NEUTRAL | ||||||
| IDD_DIALOG DIALOGEX 12, 12, 232, 326 | IDD_DIALOG DIALOGEX 12, 12, 232, 326 | ||||||
| STYLE DS_SETFONT | DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU | STYLE DS_SETFONT | DS_MODALFRAME | DS_CENTER | WS_MINIMIZEBOX | WS_POPUP | WS_CAPTION | WS_SYSMENU | ||||||
| EXSTYLE WS_EX_ACCEPTFILES | EXSTYLE WS_EX_ACCEPTFILES | ||||||
| CAPTION "Rufus 3.5.1472" | CAPTION "Rufus 3.5.1473" | ||||||
| FONT 9, "Segoe UI Symbol", 400, 0, 0x0 | FONT 9, "Segoe UI Symbol", 400, 0, 0x0 | ||||||
| BEGIN | BEGIN | ||||||
|     LTEXT           "Drive Properties",IDS_DRIVE_PROPERTIES_TXT,8,6,53,12,NOT WS_GROUP |     LTEXT           "Drive Properties",IDS_DRIVE_PROPERTIES_TXT,8,6,53,12,NOT WS_GROUP | ||||||
|  | @ -394,8 +394,8 @@ END | ||||||
| // | // | ||||||
| 
 | 
 | ||||||
| VS_VERSION_INFO VERSIONINFO | VS_VERSION_INFO VERSIONINFO | ||||||
|  FILEVERSION 3,5,1472,0 |  FILEVERSION 3,5,1473,0 | ||||||
|  PRODUCTVERSION 3,5,1472,0 |  PRODUCTVERSION 3,5,1473,0 | ||||||
|  FILEFLAGSMASK 0x3fL |  FILEFLAGSMASK 0x3fL | ||||||
| #ifdef _DEBUG | #ifdef _DEBUG | ||||||
|  FILEFLAGS 0x1L |  FILEFLAGS 0x1L | ||||||
|  | @ -413,13 +413,13 @@ BEGIN | ||||||
|             VALUE "Comments", "https://akeo.ie" |             VALUE "Comments", "https://akeo.ie" | ||||||
|             VALUE "CompanyName", "Akeo Consulting" |             VALUE "CompanyName", "Akeo Consulting" | ||||||
|             VALUE "FileDescription", "Rufus" |             VALUE "FileDescription", "Rufus" | ||||||
|             VALUE "FileVersion", "3.5.1472" |             VALUE "FileVersion", "3.5.1473" | ||||||
|             VALUE "InternalName", "Rufus" |             VALUE "InternalName", "Rufus" | ||||||
|             VALUE "LegalCopyright", "© 2011-2019 Pete Batard (GPL v3)" |             VALUE "LegalCopyright", "© 2011-2019 Pete Batard (GPL v3)" | ||||||
|             VALUE "LegalTrademarks", "https://www.gnu.org/copyleft/gpl.html" |             VALUE "LegalTrademarks", "https://www.gnu.org/copyleft/gpl.html" | ||||||
|             VALUE "OriginalFilename", "rufus-3.5.exe" |             VALUE "OriginalFilename", "rufus-3.5.exe" | ||||||
|             VALUE "ProductName", "Rufus" |             VALUE "ProductName", "Rufus" | ||||||
|             VALUE "ProductVersion", "3.5.1472" |             VALUE "ProductVersion", "3.5.1473" | ||||||
|         END |         END | ||||||
|     END |     END | ||||||
|     BLOCK "VarFileInfo" |     BLOCK "VarFileInfo" | ||||||
|  |  | ||||||
							
								
								
									
										6
									
								
								src/ui.c
									
										
									
									
									
								
							
							
						
						
									
										6
									
								
								src/ui.c
									
										
									
									
									
								
							|  | @ -155,8 +155,10 @@ void GetMainButtonsWidth(HWND hDlg) | ||||||
| 	MapWindowPoints(NULL, hDlg, (POINT*)&rc, 2); | 	MapWindowPoints(NULL, hDlg, (POINT*)&rc, 2); | ||||||
| 	bw = rc.right - rc.left; | 	bw = rc.right - rc.left; | ||||||
| 
 | 
 | ||||||
| 	for (i = 0; i < ARRAYSIZE(main_button_ids); i++) | 	for (i = 0; i < ARRAYSIZE(main_button_ids); i++) { | ||||||
| 		bw = max(bw, GetTextWidth(hDlg, main_button_ids[i]) + cbw); | 		// Make sure we add extra space for the SELECT split button (i == 0) if Fido is enabled
 | ||||||
|  | 		bw = max(bw, GetTextWidth(hDlg, main_button_ids[i]) + ((enable_fido && i == 0) ? (3 * cbw) / 2 : cbw)); | ||||||
|  | 	} | ||||||
| 	// The 'CLOSE' button is also be used to display 'CANCEL' and we sometimes
 | 	// The 'CLOSE' button is also be used to display 'CANCEL' and we sometimes
 | ||||||
| 	// want to add "DOWNLOAD" into the Select split button => measure that too.
 | 	// want to add "DOWNLOAD" into the Select split button => measure that too.
 | ||||||
| 	bw = max(bw, GetTextSize(GetDlgItem(hDlg, IDCANCEL), lmprintf(MSG_007)).cx + cbw); | 	bw = max(bw, GetTextSize(GetDlgItem(hDlg, IDCANCEL), lmprintf(MSG_007)).cx + cbw); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue